Initial commit
This commit is contained in:
62
internal/api/api.go
Normal file
62
internal/api/api.go
Normal file
@@ -0,0 +1,62 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"github.com/gin-gonic/gin"
|
||||
"net/http"
|
||||
"path/filepath"
|
||||
"photodisk/internal/auth"
|
||||
"photodisk/internal/config"
|
||||
"photodisk/internal/controller"
|
||||
)
|
||||
|
||||
func AuthMiddleware(c *gin.Context) {
|
||||
sessionId, err := c.Cookie("session_id")
|
||||
if sessionId == "" || err != nil {
|
||||
c.JSON(http.StatusUnauthorized, gin.H{"error": "Unauthorized"})
|
||||
c.Abort()
|
||||
return
|
||||
}
|
||||
|
||||
user, err := auth.CheckSession(sessionId)
|
||||
if err != nil {
|
||||
c.JSON(http.StatusUnauthorized, gin.H{"error": "Unauthorized"})
|
||||
c.Abort()
|
||||
return
|
||||
}
|
||||
|
||||
controller.SetUser(c, user)
|
||||
|
||||
c.Next()
|
||||
}
|
||||
|
||||
func Start(addr string) error {
|
||||
// Start the server
|
||||
r := gin.Default()
|
||||
r.GET("/ping", func(c *gin.Context) {
|
||||
c.JSON(http.StatusOK, gin.H{
|
||||
"message": "pong",
|
||||
})
|
||||
})
|
||||
|
||||
r.POST("/login", controller.Login)
|
||||
|
||||
r.POST("/albums/new", AuthMiddleware, controller.CreateAlbum)
|
||||
r.PUT("/albums/:id", AuthMiddleware, controller.UpdateAlbum)
|
||||
r.GET("/albums/:id", AuthMiddleware, controller.GetAlbum)
|
||||
r.DELETE("/albums/:id", AuthMiddleware, controller.DeleteAlbum)
|
||||
|
||||
r.GET("/albums", AuthMiddleware, controller.ListAlbums)
|
||||
|
||||
r.GET("/albums/:id/list", controller.ListImages)
|
||||
r.GET("/albums/:id/:image", controller.ServeImage)
|
||||
|
||||
r.POST("/album/:id/upload", AuthMiddleware, controller.UploadImage)
|
||||
|
||||
// Serve static files
|
||||
r.Static("/static", config.Get().Static)
|
||||
r.GET("/", func(c *gin.Context) {
|
||||
c.File(filepath.Join(config.Get().Static, "index.html"))
|
||||
})
|
||||
|
||||
return r.Run(addr) // listen and serve on 0.0.0.0:8080 (for windows "localhost:8080")
|
||||
}
|
||||
Reference in New Issue
Block a user