diff options
author | Sebastien Douheret <sebastien.douheret@iot.bzh> | 2017-11-29 08:54:00 +0100 |
---|---|---|
committer | Sebastien Douheret <sebastien.douheret@iot.bzh> | 2017-11-29 11:10:30 +0100 |
commit | 2f7828d01f4c4ca2909f95f098627cd5475ed225 (patch) | |
tree | b5e71920b813b95cae3e32044be08b99223348ec /lib/apiv1/folders.go | |
parent | 5caebfb4b7c3b73988f067082b219ce5b7f409ba (diff) |
Refit source files to have a public xs-apiv1 lib package.
Signed-off-by: Sebastien Douheret <sebastien.douheret@iot.bzh>
Diffstat (limited to 'lib/apiv1/folders.go')
-rw-r--r-- | lib/apiv1/folders.go | 131 |
1 files changed, 0 insertions, 131 deletions
diff --git a/lib/apiv1/folders.go b/lib/apiv1/folders.go deleted file mode 100644 index 073445c..0000000 --- a/lib/apiv1/folders.go +++ /dev/null @@ -1,131 +0,0 @@ -package apiv1 - -import ( - "net/http" - "os" - - "github.com/gin-gonic/gin" - common "github.com/iotbzh/xds-common/golib" - "github.com/iotbzh/xds-server/lib/folder" -) - -// getFolders returns all folders configuration -func (s *APIService) getFolders(c *gin.Context) { - c.JSON(http.StatusOK, s.mfolders.GetConfigArr()) -} - -// getFolder returns a specific folder configuration -func (s *APIService) getFolder(c *gin.Context) { - id, err := s.mfolders.ResolveID(c.Param("id")) - if err != nil { - common.APIError(c, err.Error()) - return - } - f := s.mfolders.Get(id) - if f == nil { - common.APIError(c, "Invalid id") - return - } - - c.JSON(http.StatusOK, (*f).GetConfig()) -} - -// addFolder adds a new folder to server config -func (s *APIService) addFolder(c *gin.Context) { - var cfgArg folder.FolderConfig - if c.BindJSON(&cfgArg) != nil { - common.APIError(c, "Invalid arguments") - return - } - - s.log.Debugln("Add folder config: ", cfgArg) - - newFld, err := s.mfolders.Add(cfgArg) - if err != nil { - common.APIError(c, err.Error()) - return - } - - // Create xds-project.conf file - // FIXME: move to folders.createUpdate func (but gin context needed) - fld := s.mfolders.Get(newFld.ID) - prjConfFile := (*fld).GetFullPath("xds-project.conf") - if !common.Exists(prjConfFile) { - fd, err := os.OpenFile(prjConfFile, os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0666) - if err != nil { - common.APIError(c, err.Error()) - return - } - fd.WriteString("# XDS project settings\n") - fd.WriteString("export XDS_SERVER_URL=" + c.Request.Host + "\n") - fd.WriteString("export XDS_PROJECT_ID=" + newFld.ID + "\n") - if newFld.DefaultSdk == "" { - sdks := s.sdks.GetAll() - newFld.DefaultSdk = sdks[0].ID - } - fd.WriteString("export XDS_SDK_ID=" + newFld.DefaultSdk + "\n") - fd.Close() - } - - c.JSON(http.StatusOK, newFld) -} - -// syncFolder force synchronization of folder files -func (s *APIService) syncFolder(c *gin.Context) { - id, err := s.mfolders.ResolveID(c.Param("id")) - if err != nil { - common.APIError(c, err.Error()) - return - } - s.log.Debugln("Sync folder id: ", id) - - err = s.mfolders.ForceSync(id) - if err != nil { - common.APIError(c, err.Error()) - return - } - - c.JSON(http.StatusOK, "") -} - -// delFolder deletes folder from server config -func (s *APIService) delFolder(c *gin.Context) { - id, err := s.mfolders.ResolveID(c.Param("id")) - if err != nil { - common.APIError(c, err.Error()) - return - } - - s.log.Debugln("Delete folder id ", id) - - delEntry, err := s.mfolders.Delete(id) - if err != nil { - common.APIError(c, err.Error()) - return - } - c.JSON(http.StatusOK, delEntry) -} - -// updateFolder update some field of a folder -func (s *APIService) updateFolder(c *gin.Context) { - id, err := s.mfolders.ResolveID(c.Param("id")) - if err != nil { - common.APIError(c, err.Error()) - return - } - - s.log.Debugln("Update folder id ", id) - - var cfgArg folder.FolderConfig - if c.BindJSON(&cfgArg) != nil { - common.APIError(c, "Invalid arguments") - return - } - - upFld, err := s.mfolders.Update(id, cfgArg) - if err != nil { - common.APIError(c, err.Error()) - return - } - c.JSON(http.StatusOK, upFld) -} |