mirror of
				https://github.com/ClusterCockpit/cc-backend
				synced 2025-10-22 21:45:05 +02:00 
			
		
		
		
	secure addJob with mutex
This commit is contained in:
		| @@ -57,6 +57,7 @@ type RestApi struct { | ||||
| 	Authentication    *auth.Authentication | ||||
| 	MachineStateDir   string | ||||
| 	OngoingArchivings sync.WaitGroup | ||||
| 	RepositoryMutex   sync.Mutex | ||||
| } | ||||
|  | ||||
| func (api *RestApi) MountRoutes(r *mux.Router) { | ||||
| @@ -362,6 +363,11 @@ func (api *RestApi) startJob(rw http.ResponseWriter, r *http.Request) { | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	// aquire lock to avoid race condition between API calls | ||||
| 	var unlockOnce sync.Once | ||||
| 	api.RepositoryMutex.Lock() | ||||
| 	defer unlockOnce.Do(api.RepositoryMutex.Unlock) | ||||
|  | ||||
| 	// Check if combination of (job_id, cluster_id, start_time) already exists: | ||||
| 	jobs, err := api.JobRepository.FindAll(&req.JobID, &req.Cluster, nil) | ||||
| 	if err != nil && err != sql.ErrNoRows { | ||||
| @@ -381,6 +387,8 @@ func (api *RestApi) startJob(rw http.ResponseWriter, r *http.Request) { | ||||
| 		handleError(fmt.Errorf("insert into database failed: %w", err), http.StatusInternalServerError, rw) | ||||
| 		return | ||||
| 	} | ||||
| 	// unlock here, adding Tags can be async | ||||
| 	unlockOnce.Do(api.RepositoryMutex.Unlock) | ||||
|  | ||||
| 	for _, tag := range req.Tags { | ||||
| 		if _, err := api.JobRepository.AddTagOrCreate(id, tag.Type, tag.Name); err != nil { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user