Reorganized API + added db migrations
Read the README file for more informations
This commit is contained in:
128
backend/main.go
128
backend/main.go
@@ -12,7 +12,12 @@ import (
|
||||
_ "github.com/lib/pq"
|
||||
|
||||
"fr.latosa-escrima/api"
|
||||
"fr.latosa-escrima/api/blogs"
|
||||
"fr.latosa-escrima/api/core"
|
||||
"fr.latosa-escrima/api/events"
|
||||
"fr.latosa-escrima/api/media"
|
||||
"fr.latosa-escrima/api/shortcodes"
|
||||
"fr.latosa-escrima/api/users"
|
||||
"github.com/gorilla/csrf"
|
||||
)
|
||||
|
||||
@@ -21,22 +26,6 @@ var CORS_AllowOrigin string
|
||||
func handler(w http.ResponseWriter, r *http.Request) {
|
||||
fmt.Fprintf(w, "<html><body><h1>Hello, World!</h1></body></html>")
|
||||
}
|
||||
func Cors(next http.Handler) http.Handler {
|
||||
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||
// Allow all origins (can restrict to specific origins)
|
||||
w.Header().Set("Access-Control-Allow-Origin", CORS_AllowOrigin)
|
||||
// Allow certain HTTP methods (you can customize these as needed)
|
||||
w.Header().Set("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS, PATCH")
|
||||
// Allow certain headers (you can add more as needed)
|
||||
w.Header().Set("Access-Control-Allow-Headers", "Content-Type, Authorization, X-CSRF-Token")
|
||||
w.Header().Set("Access-Control-Allow-Credentials", "true")
|
||||
// Handle OPTIONS pre-flight request
|
||||
if r.Method == http.MethodOptions {
|
||||
return
|
||||
}
|
||||
next.ServeHTTP(w, r)
|
||||
})
|
||||
}
|
||||
|
||||
func main() {
|
||||
err := godotenv.Load()
|
||||
@@ -48,7 +37,6 @@ func main() {
|
||||
port := os.Getenv("BACKEND_DOCKER_PORT")
|
||||
hostname := os.Getenv("DATABASE_HOSTNAME")
|
||||
postgres_port := os.Getenv("POSTGRES_DOCKER_PORT")
|
||||
CORS_AllowOrigin = os.Getenv("CORS_AllowOrigin")
|
||||
if environ == "DEV" {
|
||||
port = os.Getenv("BACKEND_PORT")
|
||||
hostname = "localhost"
|
||||
@@ -85,67 +73,67 @@ func main() {
|
||||
Handler: handler,
|
||||
Middlewares: []core.Middleware{api.Methods("get")}},
|
||||
"/users/login": {
|
||||
Handler: api.HandleLogin,
|
||||
Handler: users.HandleLogin,
|
||||
Middlewares: []core.Middleware{api.Methods("POST")}},
|
||||
"/users/me": {
|
||||
Handler: api.HandleGetMe,
|
||||
Handler: users.HandleMe,
|
||||
Middlewares: []core.Middleware{api.Methods("GET"), api.AuthJWT}},
|
||||
"/users": {
|
||||
Handler: api.HandleGetUsers,
|
||||
Handler: users.HandleUsers,
|
||||
Middlewares: []core.Middleware{api.Methods("GET"), api.AuthJWT}},
|
||||
"/users/new": {
|
||||
Handler: api.HandleCreateUser,
|
||||
Handler: users.HandleNew,
|
||||
Middlewares: []core.Middleware{api.Methods("POST"), api.AuthJWT}},
|
||||
"/users/{user_uuid}": {
|
||||
Handler: api.HandleGetUser,
|
||||
Handler: users.HandleUser,
|
||||
Middlewares: []core.Middleware{api.Methods("GET"), api.AuthJWT}},
|
||||
"/users/{user_uuid}/delete": {
|
||||
Handler: api.HandleDeleteUser,
|
||||
Handler: users.HandleDelete,
|
||||
Middlewares: []core.Middleware{api.Methods("DELETE"), api.AuthJWT}},
|
||||
"/users/{user_uuid}/update": {
|
||||
Handler: api.HandleUpdateUser,
|
||||
Handler: users.HandleUpdate,
|
||||
Middlewares: []core.Middleware{api.Methods("PATCH"), api.AuthJWT}},
|
||||
"/events": {
|
||||
Handler: api.HangleGetEvents,
|
||||
"/events": {
|
||||
Handler: events.HandleEvents,
|
||||
Middlewares: []core.Middleware{api.Methods("GET")}},
|
||||
"/events/new": {
|
||||
Handler: api.HandleCreateEvent,
|
||||
Handler: events.HandleNew,
|
||||
Middlewares: []core.Middleware{api.Methods("POST")}},
|
||||
"/events/{event_uuid}": {
|
||||
Handler: api.HandleGetEvent,
|
||||
Handler: events.HandleEvent,
|
||||
Middlewares: []core.Middleware{api.Methods("GET")}},
|
||||
"/events/{event_uuid}/delete": {
|
||||
Handler: api.HandleDeleteEvent,
|
||||
Handler: events.HandleDelete,
|
||||
Middlewares: []core.Middleware{api.Methods("DELETE")}},
|
||||
"/events/{event_uuid}/update": {
|
||||
Handler: api.HandleUpdateEvent,
|
||||
Handler: events.HandleUpdate,
|
||||
Middlewares: []core.Middleware{api.Methods("PATCH")}},
|
||||
"/blogs/new": {
|
||||
Handler: api.HandleCreateBlog,
|
||||
Handler: blogs.HandleNew,
|
||||
Middlewares: []core.Middleware{api.Methods(("POST"))}},
|
||||
"/blogs/{uuid}": {
|
||||
Handler: api.HandleGetBlog,
|
||||
Handler: blogs.HandleBlog,
|
||||
Middlewares: []core.Middleware{api.Methods("GET")}},
|
||||
"/media/upload": {
|
||||
Handler: api.HandleUploadMedia,
|
||||
Handler: media.HandleUpload,
|
||||
Middlewares: []core.Middleware{api.Methods("POST"), api.AuthJWT}},
|
||||
"/media/verify": {
|
||||
Handler: api.HandleVerifyMedia,
|
||||
Handler: media.HandleVerify,
|
||||
Middlewares: []core.Middleware{api.Methods("POST"), api.AuthJWT},
|
||||
},
|
||||
// Paginated media response
|
||||
"/media/": {
|
||||
Handler: api.HandleGetMedia,
|
||||
Handler: media.HandleMedia,
|
||||
Middlewares: []core.Middleware{api.Methods("GET")},
|
||||
},
|
||||
// Unique element
|
||||
"/media/{media_uuid}": {
|
||||
Handler: api.HandleGetMediaDetails,
|
||||
Handler: media.HandleMediaDetails,
|
||||
Middlewares: []core.Middleware{api.Methods("GET")},
|
||||
},
|
||||
// Get the image, video, GIF etc.
|
||||
"/media/{media_uuid}/file": {
|
||||
Handler: api.HandleGetMediaFile,
|
||||
Handler: media.HandleMediaFile,
|
||||
Middlewares: []core.Middleware{api.Methods("GET")},
|
||||
},
|
||||
// "/media/{media_uuid}/update": {
|
||||
@@ -153,29 +141,81 @@ func main() {
|
||||
// Middlewares: []core.Middleware{api.Methods("PATCH"), api.AuthJWT},
|
||||
// },
|
||||
"/media/{media_uuid}/delete": {
|
||||
Handler: api.HandleDeleteMedia,
|
||||
Handler: media.HandleDelete,
|
||||
Middlewares: []core.Middleware{api.Methods("DELETE"), api.AuthJWT},
|
||||
},
|
||||
"/shortcodes/new": {
|
||||
Handler: api.HandleCreateShortcode,
|
||||
Handler: shortcodes.HandleNew,
|
||||
Middlewares: []core.Middleware{api.Methods("POST"), api.AuthJWT},
|
||||
},
|
||||
"/shortcodes/": {
|
||||
Handler: api.HandleGetShortcodes,
|
||||
Handler: shortcodes.HandleShortcodes,
|
||||
Middlewares: []core.Middleware{api.Methods("GET"), api.AuthJWT},
|
||||
},
|
||||
"/shortcodes/{shortcode}": {
|
||||
Handler: api.HandleGetShortcode,
|
||||
Handler: shortcodes.HandleShortcode,
|
||||
Middlewares: []core.Middleware{api.Methods("GET")},
|
||||
},
|
||||
"/shortcodes/{shortcode}/delete": {
|
||||
Handler: api.HandleDeleteShortcode,
|
||||
Handler: shortcodes.HandleDelete,
|
||||
Middlewares: []core.Middleware{api.Methods("DELETE"), api.AuthJWT},
|
||||
},
|
||||
"/shortcodes/{shortcode}/update": {
|
||||
Handler: api.HandleUpdateShortcode,
|
||||
Handler: shortcodes.HandleUpdate,
|
||||
Middlewares: []core.Middleware{api.Methods("PATCH"), api.AuthJWT},
|
||||
},
|
||||
// "/roles": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("GET"), api.AuthJWT},
|
||||
// },
|
||||
// "/roles/new": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("POST"), api.AuthJWT},
|
||||
// },
|
||||
// "/roles/{role_uuid}": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("GET"), api.AuthJWT},
|
||||
// },
|
||||
// "/roles/{role_uuid}/update": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("PATCH"), api.AuthJWT},
|
||||
// },
|
||||
// "/roles/{role_uuid}/delete": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("DELETE"), api.AuthJWT},
|
||||
// },
|
||||
// "/permissions": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("GET"), api.AuthJWT},
|
||||
// },
|
||||
// "/permissions/new": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("POST"), api.AuthJWT},
|
||||
// },
|
||||
// "/permissions/{permission_id}": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("PATCH"), api.AuthJWT},
|
||||
// },
|
||||
// "/permissions/{permission_id}/update": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("PATCH"), api.AuthJWT},
|
||||
// },
|
||||
// "/permissions/{permission_id}/delete": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("DELETE"), api.AuthJWT},
|
||||
// },
|
||||
// "/roles/{role_uuid}/permissions/": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("GET"), api.AuthJWT},
|
||||
// },
|
||||
// "/roles/{role_uuid}/permissions/{permission_id}/add": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("POST"), api.AuthJWT},
|
||||
// },
|
||||
// "/roles/{role_uuid}/permissions/{permission_id}/remove": {
|
||||
// Handler: nil,
|
||||
// Middlewares: []core.Middleware{api.Methods("POST"), api.AuthJWT},
|
||||
// },
|
||||
"/contact": {
|
||||
Handler: api.HandleContact,
|
||||
Middlewares: []core.Middleware{api.Methods("POST"), CSRFMiddleware},
|
||||
@@ -187,7 +227,7 @@ func main() {
|
||||
})
|
||||
|
||||
fmt.Printf("Serving on port %s\n", port)
|
||||
err = http.ListenAndServe(fmt.Sprintf(":%s", port), Cors(mux))
|
||||
err = http.ListenAndServe(fmt.Sprintf(":%s", port), api.CORS(mux))
|
||||
if err != nil {
|
||||
fmt.Printf("Error starting server: %s\n", err)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user