diff options
author | Luke Granger-Brown <git@lukegb.com> | 2020-06-19 00:26:47 +0100 |
---|---|---|
committer | Michael Muré <batolettre@gmail.com> | 2020-06-27 23:01:09 +0200 |
commit | e5a316e40c377a8563e92f62b0773ed34321a91a (patch) | |
tree | 4788a8135201a1d3c0f05014ff1c8c2ca4060c57 /graphql/graphqlidentity/graphqlidentity.go | |
parent | 766aff2b2f9db339d7c42321fe6cd37309631be3 (diff) | |
download | git-bug-e5a316e40c377a8563e92f62b0773ed34321a91a.tar.gz |
Pull out context-stuff from identity into graphqlidentity package
Diffstat (limited to 'graphql/graphqlidentity/graphqlidentity.go')
-rw-r--r-- | graphql/graphqlidentity/graphqlidentity.go | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/graphql/graphqlidentity/graphqlidentity.go b/graphql/graphqlidentity/graphqlidentity.go new file mode 100644 index 00000000..6851c4a8 --- /dev/null +++ b/graphql/graphqlidentity/graphqlidentity.go @@ -0,0 +1,39 @@ +// Package graphqlidentity contains helpers for managing identities within the GraphQL API. +package graphqlidentity + +import ( + "context" + + "github.com/MichaelMure/git-bug/cache" + "github.com/MichaelMure/git-bug/entity" + "github.com/MichaelMure/git-bug/identity" + "github.com/MichaelMure/git-bug/repository" +) + +// identityCtxKey is a unique context key, accessible only in this package. +var identityCtxKey = &struct{}{} + +// AttachToContext attaches an Identity to a context. +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. +// 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 r.ResolveIdentity(id) +} + +// ForContextUncached retrieves an Identity from the context, or nil if no identity is present. +// 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 identity.ReadLocal(repo, id) +} |