mirror of
				https://github.com/ClusterCockpit/cc-backend
				synced 2025-10-25 14:55:06 +02:00 
			
		
		
		
	Reject jobs if start time is within 24h
This commit is contained in:
		
							
								
								
									
										11
									
								
								api/rest.go
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								api/rest.go
									
									
									
									
									
								
							| @@ -284,15 +284,18 @@ func (api *RestApi) startJob(rw http.ResponseWriter, r *http.Request) { | ||||
| 	} | ||||
|  | ||||
| 	// Check if combination of (job_id, cluster_id, start_time) already exists: | ||||
| 	job, err := api.JobRepository.Find(&req.JobID, &req.Cluster, &req.StartTime) | ||||
| 	if err != nil && err != sql.ErrNoRows { | ||||
| 	job, err := api.JobRepository.Find(&req.JobID, &req.Cluster, nil) | ||||
|  | ||||
| 	if err != nil { | ||||
| 		handleError(fmt.Errorf("checking for duplicate failed: %w", err), http.StatusInternalServerError, rw) | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	if err != sql.ErrNoRows { | ||||
| 		handleError(fmt.Errorf("a job with that jobId, cluster and startTime already exists: dbid: %d", job.ID), http.StatusUnprocessableEntity, rw) | ||||
| 		return | ||||
| 		if (req.StartTime - job.StartTimeUnix) < 86400 { | ||||
| 			handleError(fmt.Errorf("a job with that jobId, cluster and startTime already exists: dbid: %d", job.ID), http.StatusUnprocessableEntity, rw) | ||||
| 			return | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	id, err := api.JobRepository.Start(&req) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user