Add admin authz middleware

This commit is contained in:
William Bouzourène 2024-12-30 14:46:01 +01:00
parent 6a91fe2c29
commit dc1bd10c8f
2 changed files with 35 additions and 0 deletions

View file

@ -91,6 +91,7 @@ func main() {
app.Use(middlewares.MfaEnrollMiddleware)
app.Use(middlewares.MfaVerifyMiddleware)
app.Use(middlewares.TemplatesMiddleware)
app.Use("/admin", middlewares.AuthzAdmin)
// Controllers
app.Get("/", controllers.Homepage)

View file

@ -0,0 +1,34 @@
package middlewares
import (
"git.readonly.ch/bouzoure/popvaud-people/helpers"
"git.readonly.ch/bouzoure/popvaud-people/models"
"github.com/gofiber/fiber/v2"
)
func AuthzAdmin(c *fiber.Ctx) error {
sess, err := helpers.GetSessionStore(c)
if err != nil {
return err
}
db, err := helpers.GetDatabase()
if err != nil {
return err
}
var allowAccess bool
userid := sess.Get("userid")
if userid != nil {
var user models.User
db.First(&user, "id = ?", userid.(uint))
allowAccess = user.IsAdmin
}
if !allowAccess {
return fiber.NewError(fiber.StatusForbidden, "Forbidden (authz_admin)")
}
return c.Next()
}