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

Unified Diff: filter/featureBreaker/user.go

Issue 1530533002: Add filters for user service. (Closed) Base URL: https://github.com/luci/gae.git@master
Patch Set: bug Created 5 years 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
« no previous file with comments | « filter/count/user.go ('k') | service/user/context.go » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: filter/featureBreaker/user.go
diff --git a/filter/featureBreaker/user.go b/filter/featureBreaker/user.go
new file mode 100644
index 0000000000000000000000000000000000000000..af409a0bd4fa2762f09a351584ff31683ec40e9c
--- /dev/null
+++ b/filter/featureBreaker/user.go
@@ -0,0 +1,66 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+package featureBreaker
+
+import (
+ "github.com/luci/gae/service/user"
+ "golang.org/x/net/context"
+)
+
+type userState struct {
+ *state
+
+ user.Interface
+}
+
+var _ user.Interface = (*userState)(nil)
+
+func (u *userState) CurrentOAuth(scopes ...string) (ret *user.User, err error) {
+ err = u.run(func() (err error) {
+ ret, err = u.Interface.CurrentOAuth(scopes...)
+ return
+ })
+ return
+}
+
+func (u *userState) LoginURL(dest string) (ret string, err error) {
+ err = u.run(func() (err error) {
+ ret, err = u.Interface.LoginURL(dest)
+ return
+ })
+ return
+}
+
+func (u *userState) LoginURLFederated(dest, identity string) (ret string, err error) {
+ err = u.run(func() (err error) {
+ ret, err = u.Interface.LoginURLFederated(dest, identity)
+ return
+ })
+ return
+}
+
+func (u *userState) LogoutURL(dest string) (ret string, err error) {
+ err = u.run(func() (err error) {
+ ret, err = u.Interface.LogoutURL(dest)
+ return
+ })
+ return
+}
+
+func (u *userState) OAuthConsumerKey() (ret string, err error) {
+ err = u.run(func() (err error) {
+ ret, err = u.Interface.OAuthConsumerKey()
+ return
+ })
+ return
+}
+
+// FilterUser installs a counter user filter in the context.
+func FilterUser(c context.Context, defaultError error) (context.Context, FeatureBreaker) {
+ state := newState(defaultError)
+ return user.AddFilters(c, func(ic context.Context, i user.Interface) user.Interface {
+ return &userState{state, i}
+ }), state
+}
« no previous file with comments | « filter/count/user.go ('k') | service/user/context.go » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698