|
|
package resolver
import ( "context"
"git.aiterp.net/rpdata/api/internal/session" "git.aiterp.net/rpdata/api/model/file" "git.aiterp.net/rpdata/api/resolver/types" )
// FileArgs is an arg
type FileArgs struct { ID string }
// File implements the file query
func (r *QueryResolver) File(ctx context.Context, args *FileArgs) (*types.FileResolver, error) { file, err := file.FindID(args.ID) if err != nil { return nil, err }
return &types.FileResolver{F: file}, nil }
// FilesArgs is an arg
type FilesArgs struct { IncludePublic *bool MimeTypes *[]string }
// Files implements the file query
func (r *QueryResolver) Files(ctx context.Context, args *FilesArgs) ([]*types.FileResolver, error) { user := session.FromContext(ctx).User() author := "" if user != nil { author = user.ID }
public := args.IncludePublic != nil && *args.IncludePublic == true
mimeTypes := []string(nil) if args.MimeTypes != nil { mimeTypes = *args.MimeTypes }
files, err := file.List(author, public, mimeTypes) if err != nil { return nil, err }
resolvers := make([]*types.FileResolver, len(files)) for i := range files { resolvers[i] = &types.FileResolver{F: files[i]} }
return resolvers, nil }
// FileEditArgs is args for the editFile mutation
type FileEditArgs struct { Input *struct { ID string Name *string Public *bool } }
// EditFile resolves the editFile mutation
func (r *MutationResolver) EditFile(ctx context.Context, args *FileEditArgs) (*types.FileResolver, error) { input := args.Input
user := session.FromContext(ctx).User() if user == nil || !user.Permitted("member") { return nil, ErrUnauthorized }
file, err := file.FindID(input.ID) if err != nil { return nil, err } if file.Author != user.ID && !user.Permitted("file.edit") { return nil, ErrUnauthorized }
err = file.Edit(input.Name, input.Public) if err != nil { return nil, err }
return &types.FileResolver{F: file}, nil }
// RemoveFile resolves the removeFIle mutation
func (r *MutationResolver) RemoveFile(ctx context.Context, args *FileArgs) (*types.FileResolver, error) { user := session.FromContext(ctx).User() if user == nil || !user.Permitted("member") { return nil, ErrUnauthorized }
file, err := file.FindID(args.ID) if err != nil { return nil, err } if file.Author != user.ID && !user.Permitted("file.remove") { return nil, ErrUnauthorized }
err = file.Delete() if err != nil { return nil, err }
return &types.FileResolver{F: file}, nil }
|