Semaphore/api/router.go
Matej Kramny b4cab16fda Improved UI
- Fixes #94
- Fixes admin permissions (needed to manipulate users)
2016-06-17 13:16:46 -07:00

195 lines
5.5 KiB
Go

package api
import (
"strings"
"github.com/ansible-semaphore/semaphore/api/projects"
"github.com/ansible-semaphore/semaphore/api/sockets"
"github.com/ansible-semaphore/semaphore/api/tasks"
"github.com/ansible-semaphore/semaphore/util"
"github.com/gin-gonic/gin"
"github.com/russross/blackfriday"
)
// Declare all routes
func Route(r *gin.Engine) {
r.GET("/api/ping", func(c *gin.Context) {
c.String(200, "PONG")
})
r.NoRoute(servePublic)
// set up the namespace
api := r.Group("/api")
func(api *gin.RouterGroup) {
api.POST("/login", login)
api.POST("/logout", logout)
}(api.Group("/auth"))
api.Use(authentication)
api.GET("/ws", sockets.Handler)
api.GET("/info", getSystemInfo)
api.GET("/upgrade", checkUpgrade)
api.POST("/upgrade", doUpgrade)
func(api *gin.RouterGroup) {
api.GET("", getUser)
// api.PUT("/user", misc.UpdateUser)
api.GET("/tokens", getAPITokens)
api.POST("/tokens", createAPIToken)
api.DELETE("/tokens/:token_id", expireAPIToken)
}(api.Group("/user"))
api.GET("/projects", projects.GetProjects)
api.POST("/projects", projects.AddProject)
api.GET("/events", getEvents)
api.GET("/users", getUsers)
api.POST("/users", addUser)
api.GET("/users/:user_id", getUserMiddleware, getUser)
api.PUT("/users/:user_id", getUserMiddleware, updateUser)
api.POST("/users/:user_id/password", getUserMiddleware, updateUserPassword)
api.DELETE("/users/:user_id", getUserMiddleware, deleteUser)
func(api *gin.RouterGroup) {
api.Use(projects.ProjectMiddleware)
api.GET("", projects.GetProject)
api.PUT("", projects.MustBeAdmin, projects.UpdateProject)
api.DELETE("", projects.MustBeAdmin, projects.DeleteProject)
api.GET("/events", getEvents)
api.GET("/users", projects.GetUsers)
api.POST("/users", projects.MustBeAdmin, projects.AddUser)
api.POST("/users/:user_id/admin", projects.MustBeAdmin, projects.UserMiddleware, projects.MakeUserAdmin)
api.DELETE("/users/:user_id/admin", projects.MustBeAdmin, projects.UserMiddleware, projects.MakeUserAdmin)
api.DELETE("/users/:user_id", projects.MustBeAdmin, projects.UserMiddleware, projects.RemoveUser)
api.GET("/keys", projects.GetKeys)
api.POST("/keys", projects.AddKey)
api.PUT("/keys/:key_id", projects.KeyMiddleware, projects.UpdateKey)
api.DELETE("/keys/:key_id", projects.KeyMiddleware, projects.RemoveKey)
api.GET("/repositories", projects.GetRepositories)
api.POST("/repositories", projects.AddRepository)
api.PUT("/repositories/:repository_id", projects.RepositoryMiddleware, projects.UpdateRepository)
api.DELETE("/repositories/:repository_id", projects.RepositoryMiddleware, projects.RemoveRepository)
api.GET("/inventory", projects.GetInventory)
api.POST("/inventory", projects.AddInventory)
api.PUT("/inventory/:inventory_id", projects.InventoryMiddleware, projects.UpdateInventory)
api.DELETE("/inventory/:inventory_id", projects.InventoryMiddleware, projects.RemoveInventory)
api.GET("/environment", projects.GetEnvironment)
api.POST("/environment", projects.AddEnvironment)
api.PUT("/environment/:environment_id", projects.EnvironmentMiddleware, projects.UpdateEnvironment)
api.DELETE("/environment/:environment_id", projects.EnvironmentMiddleware, projects.RemoveEnvironment)
api.GET("/templates", projects.GetTemplates)
api.POST("/templates", projects.AddTemplate)
api.PUT("/templates/:template_id", projects.TemplatesMiddleware, projects.UpdateTemplate)
api.DELETE("/templates/:template_id", projects.TemplatesMiddleware, projects.RemoveTemplate)
api.GET("/tasks", tasks.GetAll)
api.POST("/tasks", tasks.AddTask)
api.GET("/tasks/:task_id/output", tasks.GetTaskMiddleware, tasks.GetTaskOutput)
api.DELETE("/tasks/:task_id", tasks.GetTaskMiddleware, tasks.RemoveTask)
}(api.Group("/project/:project_id"))
}
func servePublic(c *gin.Context) {
path := c.Request.URL.Path
if strings.HasPrefix(path, "/api") {
c.Next()
return
}
if !strings.HasPrefix(path, "/public") {
if len(strings.Split(path, ".")) > 1 {
c.AbortWithStatus(404)
return
}
path = "/public/html/index.html"
}
path = strings.Replace(path, "/", "", 1)
split := strings.Split(path, ".")
suffix := split[len(split)-1]
res, err := util.Asset(path)
if err != nil {
c.Next()
return
}
contentType := "text/plain"
switch suffix {
case "png":
contentType = "image/png"
case "jpg", "jpeg":
contentType = "image/jpeg"
case "gif":
contentType = "image/gif"
case "js":
contentType = "application/javascript"
case "css":
contentType = "text/css"
case "woff":
contentType = "application/x-font-woff"
case "ttf":
contentType = "application/x-font-ttf"
case "otf":
contentType = "application/x-font-otf"
case "html":
contentType = "text/html"
}
c.Writer.Header().Set("content-type", contentType)
c.String(200, string(res))
}
func getSystemInfo(c *gin.Context) {
body := map[string]interface{}{
"version": util.Version,
"update": util.UpdateAvailable,
"config": map[string]string{
"dbHost": util.Config.MySQL.Hostname,
"dbName": util.Config.MySQL.DbName,
"dbUser": util.Config.MySQL.Username,
"path": util.Config.TmpPath,
"cmdPath": util.FindSemaphore(),
},
}
if util.UpdateAvailable != nil {
body["updateBody"] = string(blackfriday.MarkdownCommon([]byte(*util.UpdateAvailable.Body)))
}
c.JSON(200, body)
}
func checkUpgrade(c *gin.Context) {
if err := util.CheckUpdate(util.Version); err != nil {
c.JSON(500, err)
return
}
if util.UpdateAvailable != nil {
getSystemInfo(c)
return
}
c.AbortWithStatus(204)
}
func doUpgrade(c *gin.Context) {
util.DoUpgrade(util.Version)
}