Better core logic for JWT; supports a more generic structure

This commit is contained in:
Dane Everitt
2020-04-05 18:44:16 -07:00
parent cf2ef1a173
commit ccbb119948
3 changed files with 59 additions and 34 deletions

View File

@@ -0,0 +1,29 @@
package tokens
import (
"encoding/json"
"github.com/gbrlsnchs/jwt/v3"
)
type WebsocketPayload struct {
jwt.Payload
UserID json.Number `json:"user_id"`
ServerUUID string `json:"server_uuid"`
Permissions []string `json:"permissions"`
}
// Returns the JWT payload.
func (p *WebsocketPayload) GetPayload() *jwt.Payload {
return &p.Payload
}
// Checks if the given token payload has a permission string.
func (p *WebsocketPayload) HasPermission(permission string) bool {
for _, k := range p.Permissions {
if k == permission {
return true
}
}
return false
}