s3browser-backend/internal/gql/schema.go

291 lines
7.5 KiB
Go
Raw Normal View History

2021-09-24 13:39:23 +00:00
package gql
2021-07-26 12:52:36 +00:00
import (
"fmt"
"github.com/graph-gophers/dataloader"
"github.com/graphql-go/graphql"
2021-08-12 15:48:28 +00:00
2021-09-24 13:49:51 +00:00
s3errors "git.kapelle.org/niklas/s3browser/internal/errors"
2021-09-24 13:39:23 +00:00
helper "git.kapelle.org/niklas/s3browser/internal/helper"
types "git.kapelle.org/niklas/s3browser/internal/types"
2021-08-12 15:48:28 +00:00
log "github.com/sirupsen/logrus"
2021-07-26 12:52:36 +00:00
)
2021-09-24 13:39:23 +00:00
//GraphqlSchema generate the schema with its root query and mutation
func GraphqlSchema() (graphql.Schema, error) {
2021-07-26 12:52:36 +00:00
2021-08-06 23:19:36 +00:00
queryFields := graphql.Fields{
2021-07-26 12:52:36 +00:00
"files": &graphql.Field{
2021-08-10 09:22:10 +00:00
Type: graphql.NewNonNull(graphql.NewList(graphql.NewNonNull(graphqlFileType))),
2021-07-26 12:52:36 +00:00
Args: graphql.FieldConfigArgument{
"path": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-07-26 12:52:36 +00:00
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 15:03:06 +00:00
if !helper.IsAuthenticated(p.Context) {
2021-09-24 13:49:51 +00:00
return nil, s3errors.ErrNotAuthenticated
2021-09-14 14:51:01 +00:00
}
path, ok := p.Args["path"].(*types.ID)
2021-07-26 12:52:36 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
2021-07-26 12:52:36 +00:00
}
2021-08-12 15:48:28 +00:00
log.Debug("querry 'files': ", path)
2021-07-26 12:52:36 +00:00
loader := p.Context.Value("loader").(map[string]*dataloader.Loader)
thunk := loader["getFiles"].Load(p.Context, path)
2021-07-26 12:52:36 +00:00
return thunk()
},
},
2021-09-27 17:48:57 +00:00
"directories": &graphql.Field{
2021-08-10 09:22:10 +00:00
Type: graphql.NewNonNull(graphql.NewList(graphql.NewNonNull(graphqlDirType))),
2021-07-26 12:52:36 +00:00
Args: graphql.FieldConfigArgument{
"path": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-07-26 12:52:36 +00:00
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 15:03:06 +00:00
if !helper.IsAuthenticated(p.Context) {
2021-09-24 13:49:51 +00:00
return nil, s3errors.ErrNotAuthenticated
2021-09-14 14:51:01 +00:00
}
path, ok := p.Args["path"].(*types.ID)
2021-07-26 12:52:36 +00:00
if !ok {
return nil, nil
}
2021-08-12 15:48:28 +00:00
log.Debug("querry 'directorys': ", path)
2021-07-26 12:52:36 +00:00
loader := p.Context.Value("loader").(map[string]*dataloader.Loader)
thunk := loader["getDirs"].Load(p.Context, path)
2021-07-26 12:52:36 +00:00
return thunk()
},
},
"file": &graphql.Field{
Type: graphqlFileType,
Args: graphql.FieldConfigArgument{
"id": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-07-26 12:52:36 +00:00
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 15:03:06 +00:00
if !helper.IsAuthenticated(p.Context) {
2021-09-24 13:49:51 +00:00
return nil, s3errors.ErrNotAuthenticated
2021-09-14 14:51:01 +00:00
}
id, ok := p.Args["id"].(*types.ID)
2021-07-26 12:52:36 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
2021-08-12 15:48:28 +00:00
log.Debug("querry 'file': ", id)
2021-09-24 13:39:23 +00:00
return types.File{
ID: *id,
2021-07-26 12:52:36 +00:00
}, nil
},
},
"authorized": &graphql.Field{
Name: "authorized",
Type: graphql.NewNonNull(graphql.Boolean),
Description: "True if the user is authorized",
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 13:49:51 +00:00
auth := helper.IsAuthenticated(p.Context)
return auth, nil
},
},
2021-09-29 19:41:50 +00:00
"buckets": &graphql.Field{
Name: "buckets",
Type: graphql.NewNonNull(graphql.NewList(graphql.String)),
Description: "List available buckets",
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
if !helper.IsAuthenticated(p.Context) {
return nil, s3errors.ErrNotAuthenticated
}
loader := p.Context.Value("loader").(map[string]*dataloader.Loader)
// The only reason we use a dataloader with a empty key is that we want to cache the result
thunk := loader["listBuckets"].Load(p.Context, dataloader.StringKey(""))
return thunk()
},
},
2021-07-26 12:52:36 +00:00
}
2021-08-06 23:19:36 +00:00
mutationFields := graphql.Fields{
"delete": &graphql.Field{
Type: graphql.String,
Args: graphql.FieldConfigArgument{
"id": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-08-06 23:19:36 +00:00
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 15:03:06 +00:00
if !helper.IsAuthenticated(p.Context) {
2021-09-24 13:49:51 +00:00
return nil, s3errors.ErrNotAuthenticated
2021-09-14 14:51:01 +00:00
}
id, ok := p.Args["id"].(*types.ID)
2021-08-06 23:19:36 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
2021-08-12 15:48:28 +00:00
log.Debug("mutation 'delete': ", id)
return id, deleteMutation(p.Context, *id)
2021-08-06 23:19:36 +00:00
},
},
"copy": &graphql.Field{
Type: graphqlFileType,
Args: graphql.FieldConfigArgument{
"src": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-08-06 23:19:36 +00:00
},
"dest": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-08-06 23:19:36 +00:00
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 15:03:06 +00:00
if !helper.IsAuthenticated(p.Context) {
2021-09-24 13:49:51 +00:00
return nil, s3errors.ErrNotAuthenticated
2021-09-14 14:51:01 +00:00
}
src, ok := p.Args["src"].(*types.ID)
2021-08-06 23:19:36 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
dest, ok := p.Args["dest"].(*types.ID)
2021-08-06 23:19:36 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
2021-08-12 15:48:28 +00:00
log.Debug("mutation 'copy': ", src, "-->", dest)
return copyMutation(p.Context, *src, *dest)
2021-08-06 23:19:36 +00:00
},
},
"move": &graphql.Field{
Type: graphqlFileType,
Args: graphql.FieldConfigArgument{
"src": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-08-06 23:19:36 +00:00
},
"dest": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-08-06 23:19:36 +00:00
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 15:03:06 +00:00
if !helper.IsAuthenticated(p.Context) {
2021-09-24 13:49:51 +00:00
return nil, s3errors.ErrNotAuthenticated
2021-09-14 14:51:01 +00:00
}
src, ok := p.Args["src"].(*types.ID)
2021-08-06 23:19:36 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
dest, ok := p.Args["dest"].(*types.ID)
2021-08-06 23:19:36 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
2021-08-12 15:48:28 +00:00
log.Debug("mutation 'move': ", src, "-->", dest)
return moveMutation(p.Context, *src, *dest)
2021-08-06 23:19:36 +00:00
},
},
2021-08-16 17:57:48 +00:00
"createDir": &graphql.Field{
Type: graphql.NewNonNull(graphqlDirType),
Args: graphql.FieldConfigArgument{
"path": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-08-16 17:57:48 +00:00
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 15:03:06 +00:00
if !helper.IsAuthenticated(p.Context) {
2021-09-24 13:49:51 +00:00
return nil, s3errors.ErrNotAuthenticated
2021-09-14 14:51:01 +00:00
}
path, ok := p.Args["path"].(*types.ID)
2021-08-16 17:57:48 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
log.Debug("mutation 'createDir': ", path)
return createDirectory(p.Context, *path)
2021-08-16 17:57:48 +00:00
},
},
2021-08-20 19:38:22 +00:00
"deleteDir": &graphql.Field{
Type: graphql.NewNonNull(graphql.String),
Args: graphql.FieldConfigArgument{
"path": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(objIDType),
2021-08-20 19:38:22 +00:00
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
2021-09-24 15:03:06 +00:00
if !helper.IsAuthenticated(p.Context) {
2021-09-24 13:49:51 +00:00
return nil, s3errors.ErrNotAuthenticated
2021-09-14 14:51:01 +00:00
}
path, ok := p.Args["path"].(*types.ID)
2021-08-20 19:38:22 +00:00
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
log.Debug("mutation 'deleteDir': ", path)
return path, deleteDirectory(p.Context, *path)
2021-08-20 19:38:22 +00:00
},
},
2021-09-14 13:16:37 +00:00
"login": &graphql.Field{
2021-09-14 14:22:32 +00:00
Type: graphql.NewNonNull(graphqlLoginResultType),
2021-09-14 13:16:37 +00:00
Args: graphql.FieldConfigArgument{
"username": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(graphql.String),
},
"password": &graphql.ArgumentConfig{
Type: graphql.NewNonNull(graphql.String),
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
username, ok := p.Args["username"].(string)
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
password, ok := p.Args["password"].(string)
if !ok {
return nil, fmt.Errorf("Failed to parse args")
}
return login(p.Context, username, password)
},
},
2021-08-06 23:19:36 +00:00
}
2021-07-26 12:52:36 +00:00
rootQuery := graphql.ObjectConfig{
Name: "RootQuery",
2021-08-06 23:19:36 +00:00
Fields: queryFields,
}
rootMutation := graphql.ObjectConfig{
Name: "RootMutation",
Fields: mutationFields,
2021-07-26 12:52:36 +00:00
}
schemaConfig := graphql.SchemaConfig{
2021-08-06 23:19:36 +00:00
Query: graphql.NewObject(rootQuery),
Mutation: graphql.NewObject(rootMutation),
2021-07-26 12:52:36 +00:00
}
return graphql.NewSchema(schemaConfig)
}