mirror of
https://github.com/photoprism/photoprism.git
synced 2025-12-12 00:34:13 +01:00
This adds standard OAuth2 client credentials and bearer token support as well as scope-based authorization checks for REST API clients. Note that this initial implementation should not be used in production and that the access token limit has not been implemented yet. Signed-off-by: Michael Mayer <michael@photoprism.app>
This commit is contained in:
@@ -1,25 +1,10 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"github.com/gin-gonic/gin"
|
||||
|
||||
"github.com/photoprism/photoprism/internal/entity"
|
||||
"github.com/photoprism/photoprism/internal/get"
|
||||
"github.com/photoprism/photoprism/internal/session"
|
||||
"github.com/photoprism/photoprism/pkg/clean"
|
||||
)
|
||||
|
||||
// SessionID returns the session ID from the request context.
|
||||
func SessionID(c *gin.Context) (sessId string) {
|
||||
if c == nil {
|
||||
// Should never happen.
|
||||
return ""
|
||||
}
|
||||
|
||||
// Get the authentication token from the HTTP headers.
|
||||
return clean.ID(c.GetHeader(session.Header))
|
||||
}
|
||||
|
||||
// Session finds the client session for the given ID or returns nil otherwise.
|
||||
func Session(id string) *entity.Session {
|
||||
// Skip authentication if app is running in public mode.
|
||||
|
||||
Reference in New Issue
Block a user