diff options
| author | mo khan <mo@mokhan.ca> | 2025-03-13 16:43:47 -0600 |
|---|---|---|
| committer | mo khan <mo@mokhan.ca> | 2025-03-13 16:43:47 -0600 |
| commit | c9f394fe7fa0a5a6504b5b80ae7019cffdf4bb14 (patch) | |
| tree | da1ef1c59264221c2c483ddd76401ee19cd1015c /pkg/authz/authz.go | |
| parent | b55a6617971fa50bb064480f78343e6c0bc59dbe (diff) | |
refactor: extract authz interface to test out different PaC libraries
Diffstat (limited to 'pkg/authz/authz.go')
| -rw-r--r-- | pkg/authz/authz.go | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/pkg/authz/authz.go b/pkg/authz/authz.go new file mode 100644 index 00000000..5a93a29c --- /dev/null +++ b/pkg/authz/authz.go @@ -0,0 +1,23 @@ +package authz + +import "net/http" + +type Authorizer interface { + Authorize(*http.Request) bool +} + +type AuthorizerFunc func(*http.Request) bool + +func (f AuthorizerFunc) Authorize(r *http.Request) bool { + return f(r) +} + +func HTTP(authorizer Authorizer, h http.Handler) http.Handler { + return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + if authorizer.Authorize(r) { + h.ServeHTTP(w, r) + } else { + w.WriteHeader(http.StatusForbidden) + } + }) +} |
