144 lines
4.1 KiB
Go
144 lines
4.1 KiB
Go
// Package v1 List API.
|
|
//
|
|
// This documentation describes the List API.
|
|
//
|
|
// Schemes: http, https
|
|
// BasePath: /api/v1
|
|
// Version: 0.1
|
|
// License: GPLv3
|
|
//
|
|
// Consumes:
|
|
// - application/json
|
|
//
|
|
// Produces:
|
|
// - application/json
|
|
//
|
|
// Security:
|
|
// - AuthorizationHeaderToken :
|
|
//
|
|
// SecurityDefinitions:
|
|
// AuthorizationHeaderToken:
|
|
// type: apiKey
|
|
// name: Authorization
|
|
// in: header
|
|
//
|
|
// swagger:meta
|
|
|
|
package routes
|
|
|
|
import (
|
|
"github.com/labstack/echo"
|
|
"github.com/labstack/echo/middleware"
|
|
|
|
"code.vikunja.io/api/models"
|
|
apiv1 "code.vikunja.io/api/routes/api/v1"
|
|
_ "code.vikunja.io/api/routes/api/v1/swagger" // for docs generation
|
|
"code.vikunja.io/api/routes/crud"
|
|
)
|
|
|
|
// NewEcho registers a new Echo instance
|
|
func NewEcho() *echo.Echo {
|
|
e := echo.New()
|
|
|
|
// Logger
|
|
e.Use(middleware.LoggerWithConfig(middleware.LoggerConfig{
|
|
Format: "${time_rfc3339_nano}: ${remote_ip} ${method} ${status} ${uri} ${latency_human} - ${user_agent}\n",
|
|
}))
|
|
|
|
return e
|
|
}
|
|
|
|
// RegisterRoutes registers all routes for the application
|
|
func RegisterRoutes(e *echo.Echo) {
|
|
|
|
// TODO: Use proper cors middleware by echo
|
|
|
|
// Middleware for cors
|
|
e.Use(func(next echo.HandlerFunc) echo.HandlerFunc {
|
|
return func(c echo.Context) error {
|
|
res := c.Response()
|
|
res.Header().Set("Access-Control-Allow-Origin", "*")
|
|
res.Header().Set("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE")
|
|
res.Header().Set("Access-Control-Allow-Headers", "authorization,content-type")
|
|
res.Header().Set("Access-Control-Expose-Headers", "authorization,content-type")
|
|
return next(c)
|
|
}
|
|
})
|
|
|
|
// Swagger UI
|
|
e.Static("/swagger", "public/swagger")
|
|
|
|
// API Routes
|
|
a := e.Group("/api/v1")
|
|
|
|
// CORS_SHIT
|
|
a.OPTIONS("/login", SetCORSHeader)
|
|
a.OPTIONS("/register", SetCORSHeader)
|
|
a.OPTIONS("/users", SetCORSHeader)
|
|
a.OPTIONS("/users/:id", SetCORSHeader)
|
|
a.OPTIONS("/lists", SetCORSHeader)
|
|
a.OPTIONS("/lists/:id", SetCORSHeader)
|
|
|
|
a.POST("/login", apiv1.Login)
|
|
a.POST("/register", apiv1.RegisterUser)
|
|
|
|
// ===== Routes with Authetification =====
|
|
// Authetification
|
|
a.Use(middleware.JWT(models.Config.JWTLoginSecret))
|
|
a.POST("/tokenTest", apiv1.CheckToken)
|
|
|
|
listHandler := &crud.WebHandler{
|
|
CObject: &models.List{},
|
|
}
|
|
a.GET("/lists", listHandler.ReadAllWeb)
|
|
a.GET("/lists/:list", listHandler.ReadOneWeb)
|
|
a.POST("/lists/:list", listHandler.UpdateWeb)
|
|
a.DELETE("/lists/:list", listHandler.DeleteWeb)
|
|
a.PUT("/namespaces/:namespace/lists", listHandler.CreateWeb)
|
|
|
|
taskHandler := &crud.WebHandler{
|
|
CObject: &models.ListTask{},
|
|
}
|
|
a.PUT("/lists/:list", taskHandler.CreateWeb)
|
|
a.DELETE("/tasks/:listtask", taskHandler.DeleteWeb)
|
|
a.POST("/tasks/:listtask", taskHandler.UpdateWeb)
|
|
|
|
listTeamHandler := &crud.WebHandler{
|
|
CObject: &models.TeamList{},
|
|
}
|
|
a.GET("/lists/:list/teams", listTeamHandler.ReadAllWeb)
|
|
a.PUT("/lists/:list/teams", listTeamHandler.CreateWeb)
|
|
a.DELETE("/lists/:list/teams/:team", listTeamHandler.DeleteWeb)
|
|
|
|
namespaceHandler := &crud.WebHandler{
|
|
CObject: &models.Namespace{},
|
|
}
|
|
a.GET("/namespaces", namespaceHandler.ReadAllWeb)
|
|
a.PUT("/namespaces", namespaceHandler.CreateWeb)
|
|
a.GET("/namespaces/:namespace", namespaceHandler.ReadOneWeb)
|
|
a.POST("/namespaces/:namespace", namespaceHandler.UpdateWeb)
|
|
a.DELETE("/namespaces/:namespace", namespaceHandler.DeleteWeb)
|
|
a.GET("/namespaces/:namespace/lists", apiv1.GetListsByNamespaceID)
|
|
|
|
namespaceTeamHandler := &crud.WebHandler{
|
|
CObject: &models.TeamNamespace{},
|
|
}
|
|
a.GET("/namespaces/:namespace/teams", namespaceTeamHandler.ReadAllWeb)
|
|
a.PUT("/namespaces/:namespace/teams", namespaceTeamHandler.CreateWeb)
|
|
a.DELETE("/namespaces/:namespace/teams/:team", namespaceTeamHandler.DeleteWeb)
|
|
|
|
teamHandler := &crud.WebHandler{
|
|
CObject: &models.Team{},
|
|
}
|
|
a.GET("/teams", teamHandler.ReadAllWeb)
|
|
a.GET("/teams/:team", teamHandler.ReadOneWeb)
|
|
a.PUT("/teams", teamHandler.CreateWeb)
|
|
a.POST("/teams/:team", teamHandler.UpdateWeb)
|
|
a.DELETE("/teams/:team", teamHandler.DeleteWeb)
|
|
|
|
teamMemberHandler := &crud.WebHandler{
|
|
CObject: &models.TeamMember{},
|
|
}
|
|
a.PUT("/teams/:team/members", teamMemberHandler.CreateWeb)
|
|
a.DELETE("/teams/:team/members/:user", teamMemberHandler.DeleteWeb)
|
|
}
|