WIP: started adding auth
This commit is contained in:
parent
02c85fcf28
commit
7905062cdc
47
auth/auth.go
Normal file
47
auth/auth.go
Normal file
@ -0,0 +1,47 @@
|
||||
package auth
|
||||
|
||||
import (
|
||||
"context"
|
||||
"net/http"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
"go.mongodb.org/mongo-driver/bson"
|
||||
"go.mongodb.org/mongo-driver/mongo"
|
||||
)
|
||||
|
||||
type Permission int
|
||||
|
||||
const (
|
||||
Start Permission = 1 << iota
|
||||
Stop
|
||||
Browse
|
||||
Create
|
||||
Delete
|
||||
RunCommand
|
||||
Admin
|
||||
)
|
||||
|
||||
type User struct {
|
||||
Username string `json:"username"`
|
||||
Email string `json:"email"`
|
||||
MaxOwnedServers int `json:"maxed_owned_servers"`
|
||||
Permissions []string `json:"permissions"`
|
||||
HashedPass string `json:"HashedPass"`
|
||||
}
|
||||
|
||||
type Connection struct {
|
||||
connection *mongo.Client
|
||||
}
|
||||
|
||||
func (con Connection) AuthorizedTo(requiredPermissions Permission) gin.HandlerFunc {
|
||||
return func(ctx *gin.Context) {
|
||||
authCookie, err := ctx.Request.Cookie("auth")
|
||||
if err != nil {
|
||||
ctx http.Response{
|
||||
Status: "403",
|
||||
Body: "Authorization Required",
|
||||
}
|
||||
}
|
||||
con.connection.Database("Backend").Collection("users").Find(context.TODO(), bson.D{})
|
||||
}
|
||||
}
|
3
auth/go.mod
Normal file
3
auth/go.mod
Normal file
@ -0,0 +1,3 @@
|
||||
module acooldomain.co/backend/auth
|
||||
|
||||
go 1.22.0
|
@ -1,7 +1,6 @@
|
||||
package users
|
||||
|
||||
import (
|
||||
"container/list"
|
||||
"context"
|
||||
"net/http"
|
||||
|
||||
@ -33,30 +32,6 @@ type Connection struct {
|
||||
connection *mongo.Client
|
||||
}
|
||||
|
||||
func TranslatePermission(permission Permission, permissions_list *list.List) {
|
||||
if Start&permission == Start {
|
||||
permissions_list.PushFront("start")
|
||||
}
|
||||
if Stop&permission == Stop {
|
||||
permissions_list.PushFront("stop")
|
||||
}
|
||||
if Browse&permission == Browse {
|
||||
permissions_list.PushFront("browse")
|
||||
}
|
||||
if Create&permission == Create {
|
||||
permissions_list.PushFront("create")
|
||||
}
|
||||
if Delete&permission == Delete {
|
||||
permissions_list.PushFront("delete")
|
||||
}
|
||||
if RunCommand&permission == RunCommand {
|
||||
permissions_list.PushFront("runcommand")
|
||||
}
|
||||
if Admin&permission == Admin {
|
||||
permissions_list.PushFront("admin")
|
||||
}
|
||||
}
|
||||
|
||||
func (con Connection) GetUsers(c *gin.Context) {
|
||||
users, err := con.connection.Database("Backend").Collection("Users").Find(context.TODO(), bson.D{})
|
||||
if err != nil {
|
||||
|
Loading…
x
Reference in New Issue
Block a user