OAuth2: Add Client Credentials Authentication #213 #782 #808 #3730 #3943

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:
Michael Mayer
2023-12-12 18:42:50 +01:00
parent e80b07795c
commit 467f7b1585
78 changed files with 2474 additions and 406 deletions

22
pkg/clean/scope_test.go Normal file
View File

@@ -0,0 +1,22 @@
package clean
import (
"testing"
"github.com/stretchr/testify/assert"
)
func TestScope(t *testing.T) {
t.Run("Empty", func(t *testing.T) {
q := Scope("")
assert.Equal(t, "", q)
})
t.Run("Sanitized", func(t *testing.T) {
q := Scope(" foo:BAR webdav openid metrics !")
assert.Equal(t, "foo:bar metrics openid webdav", q)
})
t.Run("All", func(t *testing.T) {
q := Scope("*")
assert.Equal(t, "*", q)
})
}