2018-07-29 19:11:33 +03:00
|
|
|
package resolvers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2018-08-13 19:32:11 +03:00
|
|
|
|
2018-07-29 19:11:33 +03:00
|
|
|
"github.com/MichaelMure/git-bug/bug"
|
2018-09-02 17:36:48 +03:00
|
|
|
"github.com/MichaelMure/git-bug/cache"
|
2019-08-12 17:12:14 +03:00
|
|
|
"github.com/MichaelMure/git-bug/entity"
|
2018-07-29 21:58:22 +03:00
|
|
|
"github.com/MichaelMure/git-bug/graphql/connections"
|
2019-03-31 22:44:14 +03:00
|
|
|
"github.com/MichaelMure/git-bug/graphql/graph"
|
2018-07-29 20:37:06 +03:00
|
|
|
"github.com/MichaelMure/git-bug/graphql/models"
|
2019-03-31 22:44:14 +03:00
|
|
|
"github.com/MichaelMure/git-bug/identity"
|
2018-07-29 19:11:33 +03:00
|
|
|
)
|
|
|
|
|
2019-03-31 22:44:14 +03:00
|
|
|
var _ graph.RepositoryResolver = &repoResolver{}
|
|
|
|
|
2018-07-30 00:48:52 +03:00
|
|
|
type repoResolver struct{}
|
2018-07-29 19:11:33 +03:00
|
|
|
|
2019-04-09 18:43:17 +03:00
|
|
|
func (repoResolver) AllBugs(ctx context.Context, obj *models.Repository, after *string, before *string, first *int, last *int, queryStr *string) (*models.BugConnection, error) {
|
2018-08-01 20:24:19 +03:00
|
|
|
input := models.ConnectionInput{
|
|
|
|
Before: before,
|
|
|
|
After: after,
|
|
|
|
First: first,
|
|
|
|
Last: last,
|
|
|
|
}
|
2018-07-29 21:58:22 +03:00
|
|
|
|
2018-09-11 20:46:38 +03:00
|
|
|
var query *cache.Query
|
|
|
|
if queryStr != nil {
|
|
|
|
query2, err := cache.ParseQuery(*queryStr)
|
|
|
|
if err != nil {
|
2019-04-09 18:43:17 +03:00
|
|
|
return nil, err
|
2018-09-11 20:46:38 +03:00
|
|
|
}
|
|
|
|
query = query2
|
|
|
|
} else {
|
|
|
|
query = cache.NewQuery()
|
|
|
|
}
|
|
|
|
|
2018-07-29 21:58:22 +03:00
|
|
|
// Simply pass a []string with the ids to the pagination algorithm
|
2018-09-11 20:46:38 +03:00
|
|
|
source := obj.Repo.QueryBugs(query)
|
2018-07-29 21:58:22 +03:00
|
|
|
|
|
|
|
// The edger create a custom edge holding just the id
|
2019-08-12 17:12:14 +03:00
|
|
|
edger := func(id entity.Id, offset int) connections.Edge {
|
2018-07-29 21:58:22 +03:00
|
|
|
return connections.LazyBugEdge{
|
|
|
|
Id: id,
|
|
|
|
Cursor: connections.OffsetToCursor(offset),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// The conMaker will finally load and compile bugs from git to replace the selected edges
|
2019-08-12 17:12:14 +03:00
|
|
|
conMaker := func(lazyBugEdges []*connections.LazyBugEdge, lazyNode []entity.Id, info *models.PageInfo, totalCount int) (*models.BugConnection, error) {
|
2019-05-15 17:57:30 +03:00
|
|
|
edges := make([]*models.BugEdge, len(lazyBugEdges))
|
|
|
|
nodes := make([]*bug.Snapshot, len(lazyBugEdges))
|
2018-07-29 21:58:22 +03:00
|
|
|
|
|
|
|
for i, lazyBugEdge := range lazyBugEdges {
|
2018-07-30 00:48:52 +03:00
|
|
|
b, err := obj.Repo.ResolveBug(lazyBugEdge.Id)
|
2018-07-29 21:58:22 +03:00
|
|
|
|
|
|
|
if err != nil {
|
2019-04-09 18:43:17 +03:00
|
|
|
return nil, err
|
2018-07-29 21:58:22 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
snap := b.Snapshot()
|
|
|
|
|
2019-05-15 17:57:30 +03:00
|
|
|
edges[i] = &models.BugEdge{
|
2018-07-29 21:58:22 +03:00
|
|
|
Cursor: lazyBugEdge.Cursor,
|
2019-05-15 17:57:30 +03:00
|
|
|
Node: snap,
|
2018-07-29 21:58:22 +03:00
|
|
|
}
|
2019-05-15 17:57:30 +03:00
|
|
|
nodes[i] = snap
|
2018-07-29 21:58:22 +03:00
|
|
|
}
|
|
|
|
|
2019-04-09 18:43:17 +03:00
|
|
|
return &models.BugConnection{
|
2018-07-29 21:58:22 +03:00
|
|
|
Edges: edges,
|
2018-08-01 20:24:19 +03:00
|
|
|
Nodes: nodes,
|
2018-07-29 21:58:22 +03:00
|
|
|
PageInfo: info,
|
|
|
|
TotalCount: totalCount,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2019-03-31 22:44:14 +03:00
|
|
|
return connections.LazyBugCon(source, edger, conMaker, input)
|
2018-07-29 19:11:33 +03:00
|
|
|
}
|
|
|
|
|
2018-07-30 00:48:52 +03:00
|
|
|
func (repoResolver) Bug(ctx context.Context, obj *models.Repository, prefix string) (*bug.Snapshot, error) {
|
|
|
|
b, err := obj.Repo.ResolveBugPrefix(prefix)
|
2018-07-29 19:11:33 +03:00
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return b.Snapshot(), nil
|
|
|
|
}
|
2019-03-31 22:44:14 +03:00
|
|
|
|
2019-04-09 18:43:17 +03:00
|
|
|
func (repoResolver) AllIdentities(ctx context.Context, obj *models.Repository, after *string, before *string, first *int, last *int) (*models.IdentityConnection, error) {
|
2019-03-31 22:44:14 +03:00
|
|
|
input := models.ConnectionInput{
|
|
|
|
Before: before,
|
|
|
|
After: after,
|
|
|
|
First: first,
|
|
|
|
Last: last,
|
|
|
|
}
|
|
|
|
|
|
|
|
// Simply pass a []string with the ids to the pagination algorithm
|
|
|
|
source := obj.Repo.AllIdentityIds()
|
|
|
|
|
|
|
|
// The edger create a custom edge holding just the id
|
2019-08-12 17:12:14 +03:00
|
|
|
edger := func(id entity.Id, offset int) connections.Edge {
|
2019-03-31 22:44:14 +03:00
|
|
|
return connections.LazyIdentityEdge{
|
|
|
|
Id: id,
|
|
|
|
Cursor: connections.OffsetToCursor(offset),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// The conMaker will finally load and compile identities from git to replace the selected edges
|
2019-08-12 17:12:14 +03:00
|
|
|
conMaker := func(lazyIdentityEdges []*connections.LazyIdentityEdge, lazyNode []entity.Id, info *models.PageInfo, totalCount int) (*models.IdentityConnection, error) {
|
2019-05-15 17:57:30 +03:00
|
|
|
edges := make([]*models.IdentityEdge, len(lazyIdentityEdges))
|
2019-03-31 22:44:14 +03:00
|
|
|
nodes := make([]identity.Interface, len(lazyIdentityEdges))
|
|
|
|
|
|
|
|
for k, lazyIdentityEdge := range lazyIdentityEdges {
|
|
|
|
i, err := obj.Repo.ResolveIdentity(lazyIdentityEdge.Id)
|
|
|
|
|
|
|
|
if err != nil {
|
2019-04-09 18:43:17 +03:00
|
|
|
return nil, err
|
2019-03-31 22:44:14 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
ii := identity.Interface(i.Identity)
|
|
|
|
|
2019-05-15 17:57:30 +03:00
|
|
|
edges[k] = &models.IdentityEdge{
|
2019-03-31 22:44:14 +03:00
|
|
|
Cursor: lazyIdentityEdge.Cursor,
|
2019-05-15 17:57:30 +03:00
|
|
|
Node: i.Identity,
|
2019-03-31 22:44:14 +03:00
|
|
|
}
|
|
|
|
nodes[k] = ii
|
|
|
|
}
|
|
|
|
|
2019-04-09 18:43:17 +03:00
|
|
|
return &models.IdentityConnection{
|
2019-03-31 22:44:14 +03:00
|
|
|
Edges: edges,
|
|
|
|
Nodes: nodes,
|
|
|
|
PageInfo: info,
|
|
|
|
TotalCount: totalCount,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return connections.LazyIdentityCon(source, edger, conMaker, input)
|
|
|
|
}
|
|
|
|
|
2019-04-09 18:43:17 +03:00
|
|
|
func (repoResolver) Identity(ctx context.Context, obj *models.Repository, prefix string) (identity.Interface, error) {
|
2019-03-31 22:44:14 +03:00
|
|
|
i, err := obj.Repo.ResolveIdentityPrefix(prefix)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2019-04-09 18:43:17 +03:00
|
|
|
return i.Identity, nil
|
2019-03-31 22:44:14 +03:00
|
|
|
}
|
|
|
|
|
2019-04-09 18:43:17 +03:00
|
|
|
func (repoResolver) UserIdentity(ctx context.Context, obj *models.Repository) (identity.Interface, error) {
|
2019-03-31 22:44:14 +03:00
|
|
|
i, err := obj.Repo.GetUserIdentity()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2019-04-09 18:43:17 +03:00
|
|
|
return i.Identity, nil
|
2019-03-31 22:44:14 +03:00
|
|
|
}
|
2019-04-10 23:36:34 +03:00
|
|
|
|
2019-09-04 22:04:05 +03:00
|
|
|
func (resolver repoResolver) ValidLabels(ctx context.Context, obj *models.Repository, after *string, before *string, first *int, last *int) (*models.LabelConnection, error) {
|
|
|
|
input := models.ConnectionInput{
|
|
|
|
Before: before,
|
|
|
|
After: after,
|
|
|
|
First: first,
|
|
|
|
Last: last,
|
|
|
|
}
|
|
|
|
|
|
|
|
edger := func(label bug.Label, offset int) connections.Edge {
|
|
|
|
return models.LabelEdge{
|
|
|
|
Node: label,
|
|
|
|
Cursor: connections.OffsetToCursor(offset),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
conMaker := func(edges []*models.LabelEdge, nodes []bug.Label, info *models.PageInfo, totalCount int) (*models.LabelConnection, error) {
|
|
|
|
return &models.LabelConnection{
|
|
|
|
Edges: edges,
|
|
|
|
Nodes: nodes,
|
|
|
|
PageInfo: info,
|
|
|
|
TotalCount: totalCount,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return connections.LabelCon(obj.Repo.ValidLabels(), edger, conMaker, input)
|
2019-04-10 23:36:34 +03:00
|
|
|
}
|