aboutsummaryrefslogtreecommitdiffstats
path: root/graphql/graphqlidentity
diff options
context:
space:
mode:
authorLuke Granger-Brown <git@lukegb.com>2020-06-19 00:35:56 +0100
committerMichael Muré <batolettre@gmail.com>2020-06-27 23:01:10 +0200
commit5f72b04ef8e84b1c367ca6874519706318e351f5 (patch)
tree6f73279d05130d3d6d83de1dad3a5b4ac25be080 /graphql/graphqlidentity
parente5a316e40c377a8563e92f62b0773ed34321a91a (diff)
downloadgit-bug-5f72b04ef8e84b1c367ca6874519706318e351f5.tar.gz
Use ErrNotAuthenticated
Diffstat (limited to 'graphql/graphqlidentity')
-rw-r--r--graphql/graphqlidentity/errors.go6
-rw-r--r--graphql/graphqlidentity/graphqlidentity.go10
2 files changed, 12 insertions, 4 deletions
diff --git a/graphql/graphqlidentity/errors.go b/graphql/graphqlidentity/errors.go
new file mode 100644
index 00000000..5ec58b32
--- /dev/null
+++ b/graphql/graphqlidentity/errors.go
@@ -0,0 +1,6 @@
+package graphqlidentity
+
+import "errors"
+
+// ErrNotAuthenticated is returned to the client if the user requests an action requiring authentication, and they are not authenticated.
+var ErrNotAuthenticated = errors.New("not authenticated or read-only")
diff --git a/graphql/graphqlidentity/graphqlidentity.go b/graphql/graphqlidentity/graphqlidentity.go
index 6851c4a8..36b496f3 100644
--- a/graphql/graphqlidentity/graphqlidentity.go
+++ b/graphql/graphqlidentity/graphqlidentity.go
@@ -18,22 +18,24 @@ func AttachToContext(ctx context.Context, u *identity.Identity) context.Context
return context.WithValue(ctx, identityCtxKey, u.Id())
}
-// ForContext retrieves an IdentityCache from the context, or nil if no identity is present.
+// ForContext retrieves an IdentityCache from the context.
+// If there is no identity in the context, ErrNotAuthenticated is returned.
// If an error occurs while resolving the identity (e.g. I/O error), then it will be returned.
func ForContext(ctx context.Context, r *cache.RepoCache) (*cache.IdentityCache, error) {
id, ok := ctx.Value(identityCtxKey).(entity.Id)
if !ok {
- return nil, nil
+ return nil, ErrNotAuthenticated
}
return r.ResolveIdentity(id)
}
-// ForContextUncached retrieves an Identity from the context, or nil if no identity is present.
+// ForContextUncached retrieves an Identity from the context.
+// If there is no identity in the context, ErrNotAuthenticated is returned.
// If an error occurs while resolving the identity (e.g. I/O error), then it will be returned.
func ForContextUncached(ctx context.Context, repo repository.Repo) (*identity.Identity, error) {
id, ok := ctx.Value(identityCtxKey).(entity.Id)
if !ok {
- return nil, nil
+ return nil, ErrNotAuthenticated
}
return identity.ReadLocal(repo, id)
}