2020-11-16 19:37:52 +01:00
|
|
|
package auth
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"demodesk/neko/internal/types"
|
|
|
|
"demodesk/neko/internal/utils"
|
|
|
|
)
|
|
|
|
|
|
|
|
type key int
|
|
|
|
|
|
|
|
const (
|
2021-01-08 22:41:37 +01:00
|
|
|
keySessionCtx key = iota
|
2020-11-16 19:37:52 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func SetSession(r *http.Request, session types.Session) *http.Request {
|
|
|
|
ctx := context.WithValue(r.Context(), keySessionCtx, session)
|
|
|
|
return r.WithContext(ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
func GetSession(r *http.Request) types.Session {
|
|
|
|
return r.Context().Value(keySessionCtx).(types.Session)
|
|
|
|
}
|
|
|
|
|
|
|
|
func AdminsOnly(next http.Handler) http.Handler {
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
session := GetSession(r)
|
2021-03-14 00:45:51 +01:00
|
|
|
if !session.Profile().IsAdmin {
|
2021-03-21 21:32:52 +01:00
|
|
|
utils.HttpForbidden(w, "Only admin can do this.")
|
2020-11-16 19:37:52 +01:00
|
|
|
} else {
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func HostsOnly(next http.Handler) http.Handler {
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
session := GetSession(r)
|
|
|
|
if !session.IsHost() {
|
2020-11-28 15:00:21 +01:00
|
|
|
utils.HttpForbidden(w, "Only host can do this.")
|
2020-11-16 19:37:52 +01:00
|
|
|
} else {
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-03-21 21:26:53 +01:00
|
|
|
func CanWatchOnly(next http.Handler) http.Handler {
|
2020-11-16 19:37:52 +01:00
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
session := GetSession(r)
|
2021-03-21 21:26:53 +01:00
|
|
|
if !session.Profile().CanWatch {
|
2021-03-21 21:32:52 +01:00
|
|
|
utils.HttpForbidden(w, "Only sessions, that can watch.")
|
2020-11-16 19:37:52 +01:00
|
|
|
} else {
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2020-12-29 22:00:28 +01:00
|
|
|
|
|
|
|
func CanHostOnly(next http.Handler) http.Handler {
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
session := GetSession(r)
|
2021-03-14 00:45:51 +01:00
|
|
|
if !session.Profile().CanHost {
|
2021-03-21 21:32:52 +01:00
|
|
|
utils.HttpForbidden(w, "Only sessions, that can host.")
|
2020-12-29 22:00:28 +01:00
|
|
|
} else {
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2021-01-21 20:44:09 +01:00
|
|
|
|
2021-03-21 21:26:53 +01:00
|
|
|
func CanAccessClipboardOnly(next http.Handler) http.Handler {
|
2021-01-21 20:44:09 +01:00
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
session := GetSession(r)
|
2021-03-21 21:26:53 +01:00
|
|
|
if !session.Profile().CanAccessClipboard {
|
2021-03-21 21:32:52 +01:00
|
|
|
utils.HttpForbidden(w, "Only sessions, that can access clipboard.")
|
2021-01-21 20:44:09 +01:00
|
|
|
} else {
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|