diff options
author | Luke Granger-Brown <git@lukegb.com> | 2020-06-19 00:35:56 +0100 |
---|---|---|
committer | Michael Muré <batolettre@gmail.com> | 2020-06-27 23:01:10 +0200 |
commit | 5f72b04ef8e84b1c367ca6874519706318e351f5 (patch) | |
tree | 6f73279d05130d3d6d83de1dad3a5b4ac25be080 /graphql/graphqlidentity | |
parent | e5a316e40c377a8563e92f62b0773ed34321a91a (diff) | |
download | git-bug-5f72b04ef8e84b1c367ca6874519706318e351f5.tar.gz |
Use ErrNotAuthenticated
Diffstat (limited to 'graphql/graphqlidentity')
-rw-r--r-- | graphql/graphqlidentity/errors.go | 6 | ||||
-rw-r--r-- | graphql/graphqlidentity/graphqlidentity.go | 10 |
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) } |