X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=lib%2Fxdsserver%2Fapiv1-sdks.go;h=58154abe3be8d29fb2a6bb5a944114b70eb4c3e7;hb=5dc2ff003106f0ced38caadb06033f24c792f9b9;hp=ba32dc9d9b0c068799154ffd3708179d843a9fa9;hpb=f2eecfb601acc6c67fb52bf2edda93505bc44da5;p=src%2Fxds%2Fxds-server.git diff --git a/lib/xdsserver/apiv1-sdks.go b/lib/xdsserver/apiv1-sdks.go index ba32dc9..58154ab 100644 --- a/lib/xdsserver/apiv1-sdks.go +++ b/lib/xdsserver/apiv1-sdks.go @@ -1,5 +1,5 @@ /* - * Copyright (C) 2017 "IoT.bzh" + * Copyright (C) 2017-2018 "IoT.bzh" * Author Sebastien Douheret * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -20,9 +20,9 @@ package xdsserver import ( "net/http" + common "gerrit.automotivelinux.org/gerrit/src/xds/xds-common.git" + "gerrit.automotivelinux.org/gerrit/src/xds/xds-server.git/lib/xsapiv1" "github.com/gin-gonic/gin" - common "github.com/iotbzh/xds-common/golib" - "github.com/iotbzh/xds-server/lib/xsapiv1" ) // getSdks returns all SDKs configuration @@ -74,8 +74,13 @@ func (s *APIService) installSdk(c *gin.Context) { return } - sdk, err := s.sdks.Install(id, args.Filename, args.Force, args.Timeout, sess) + //increment lock xds counter: it will be decremented, + //when SDK is installed in file sdk.go in function ExitCB + //at line 308 or when install is aborted in following function + LockXdsUpdateCounter(s.Context, true) + sdk, err := s.sdks.Install(id, args.Filename, args.Force, args.Timeout, args.InstallArgs, sess) if err != nil { + LockXdsUpdateCounter(s.Context, false) common.APIError(c, err.Error()) return } @@ -103,6 +108,7 @@ func (s *APIService) abortInstallSdk(c *gin.Context) { return } + LockXdsUpdateCounter(s.Context, false) c.JSON(http.StatusOK, sdk) } @@ -123,10 +129,12 @@ func (s *APIService) removeSdk(c *gin.Context) { s.Log.Debugln("Remove SDK id ", id) + LockXdsUpdateCounter(s.Context, true) delEntry, err := s.sdks.Remove(id, -1, sess) if err != nil { common.APIError(c, err.Error()) return } + LockXdsUpdateCounter(s.Context, false) c.JSON(http.StatusOK, delEntry) }