From e4d497a9d656dae8cca039937452dae1d3c3ed82 Mon Sep 17 00:00:00 2001 From: Anton Litvinov Date: Tue, 23 Jul 2024 12:36:35 +0400 Subject: [PATCH] Fix unordered rewrite of active-services property, so that statuses of all services are written the last Signed-off-by: Anton Litvinov --- tequilapi/endpoints/service.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/tequilapi/endpoints/service.go b/tequilapi/endpoints/service.go index 3202896b69..04da406574 100644 --- a/tequilapi/endpoints/service.go +++ b/tequilapi/endpoints/service.go @@ -23,6 +23,7 @@ import ( "net/http" "strconv" "strings" + "sync" "github.com/gin-gonic/gin" "github.com/mysteriumnetwork/go-rest/apierror" @@ -43,6 +44,7 @@ type ServiceEndpoint struct { optionsParser map[string]services.ServiceOptionsParser proposalRepository proposalRepository tequilaApiClient *tequilapi_client.Client + activeServicesMu sync.Mutex } var ( @@ -249,6 +251,10 @@ func (se *ServiceEndpoint) ServiceStop(c *gin.Context) { } func (se *ServiceEndpoint) updateActiveServicesInUserConfig() { + // restrict concurrent update of ActiveServices property, so that statuses of all services are written the last + se.activeServicesMu.Lock() + defer se.activeServicesMu.Unlock() + runningInstances := se.serviceManager.List(false) activeServices := make([]string, len(runningInstances)) for i, service := range runningInstances {