Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(42)

Unified Diff: server/auth/middleware.go

Issue 2830443003: auth: Refactor how authentication methods are passed to server/auth library. (Closed)
Patch Set: nit Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: server/auth/middleware.go
diff --git a/server/auth/middleware.go b/server/auth/middleware.go
new file mode 100644
index 0000000000000000000000000000000000000000..53aa44e88ba3b3674c3549886b7ef2f636c51e9c
--- /dev/null
+++ b/server/auth/middleware.go
@@ -0,0 +1,26 @@
+// Copyright 2017 The LUCI Authors. All rights reserved.
+// Use of this source code is governed under the Apache License, Version 2.0
+// that can be found in the LICENSE file.
+
+package auth
+
+import (
+ "github.com/luci/luci-go/server/router"
+)
+
+// Authenticate returns a middleware that performs authentication.
+//
+// This is simplest form of this middleware that uses only one authentication
+// method. It is sufficient in most cases.
+//
+// This middleware either updates the context by injecting the authentication
+// state into it (enabling functions like CurrentIdentity and IsMember), or
+// aborts the request with an HTTP 401 or HTTP 500 error.
+//
+// Note that it passes through anonymous requests. CurrentIdentity returns
+// identity.AnonymousIdentity in this case. Use separate authorization layer to
+// further restrict the access, if necessary.
+func Authenticate(m Method) router.Middleware {
+ a := &Authenticator{Methods: []Method{m}}
+ return a.GetMiddleware()
+}

Powered by Google App Engine
This is Rietveld 408576698