Add folder update support and ClientData field.
[src/xds/xds-server.git] / lib / apiv1 / apiv1.go
index 7359266..fffed2d 100644 (file)
@@ -16,19 +16,19 @@ type APIService struct {
        apiRouter *gin.RouterGroup
        sessions  *session.Sessions
        cfg       *xdsconfig.Config
-       mfolder   *model.Folder
+       mfolders  *model.Folders
        sdks      *crosssdk.SDKs
        log       *logrus.Logger
 }
 
 // New creates a new instance of API service
-func New(r *gin.Engine, sess *session.Sessions, cfg *xdsconfig.Config, mfolder *model.Folder, sdks *crosssdk.SDKs) *APIService {
+func New(r *gin.Engine, sess *session.Sessions, cfg *xdsconfig.Config, mfolders *model.Folders, sdks *crosssdk.SDKs) *APIService {
        s := &APIService{
                router:    r,
                sessions:  sess,
                apiRouter: r.Group("/api/v1"),
                cfg:       cfg,
-               mfolder:   mfolder,
+               mfolders:  mfolders,
                sdks:      sdks,
                log:       cfg.Log,
        }
@@ -39,20 +39,25 @@ func New(r *gin.Engine, sess *session.Sessions, cfg *xdsconfig.Config, mfolder *
        s.apiRouter.POST("/config", s.setConfig)
 
        s.apiRouter.GET("/folders", s.getFolders)
-       s.apiRouter.GET("/folder/:id", s.getFolder)
-       s.apiRouter.POST("/folder", s.addFolder)
-       s.apiRouter.DELETE("/folder/:id", s.delFolder)
+       s.apiRouter.GET("/folders/:id", s.getFolder)
+       s.apiRouter.PUT("/folders/:id", s.updateFolder)
+       s.apiRouter.POST("/folders", s.addFolder)
+       s.apiRouter.POST("/folders/sync/:id", s.syncFolder)
+       s.apiRouter.DELETE("/folders/:id", s.delFolder)
 
        s.apiRouter.GET("/sdks", s.getSdks)
-       s.apiRouter.GET("/sdk/:id", s.getSdk)
+       s.apiRouter.GET("/sdks/:id", s.getSdk)
 
        s.apiRouter.POST("/make", s.buildMake)
        s.apiRouter.POST("/make/:id", s.buildMake)
 
-       /* TODO: to be tested and then enabled
        s.apiRouter.POST("/exec", s.execCmd)
        s.apiRouter.POST("/exec/:id", s.execCmd)
-       */
+       s.apiRouter.POST("/signal", s.execSignalCmd)
+
+       s.apiRouter.GET("/events", s.eventsList)
+       s.apiRouter.POST("/events/register", s.eventsRegister)
+       s.apiRouter.POST("/events/unregister", s.eventsUnRegister)
 
        return s
 }