|
|
package resolver
import ( "context" "errors" "time"
"git.aiterp.net/rpdata/api/loader" "git.aiterp.net/rpdata/api/model/change"
"git.aiterp.net/rpdata/api/internal/session" "git.aiterp.net/rpdata/api/model/log" )
// LogResolver for the Log graphql type
type LogResolver struct{ L log.Log }
// LogArgs is an arg
type LogArgs struct { ID *string }
// LogPostArgs is an arg
type LogPostArgs struct { Kinds *[]string }
// Log finds log
func (r *QueryResolver) Log(ctx context.Context, args *LogArgs) (*LogResolver, error) { var l log.Log var err error
switch { case args.ID != nil: l, err = log.FindID(*args.ID) default: err = ErrCannotResolve }
if err != nil { return nil, err }
return &LogResolver{L: l}, nil }
// LogQueryInput is an input
type LogQueryInput struct { Search *string Characters *[]string Channels *[]string Events *[]string Open *bool Limit *int32 }
// Logs lists logs
func (r *QueryResolver) Logs(ctx context.Context, args *struct{ Input *LogQueryInput }) ([]*LogResolver, error) { var logs []log.Log var err error
input := args.Input
if input != nil { // Parse input
limit := 100 search := "" if input.Search != nil { search = *input.Search limit = 0 } channels := []string(nil) if input.Channels != nil { channels = *input.Channels limit = 0 } characters := []string(nil) if input.Characters != nil { characters = *input.Characters limit = 0 } events := []string(nil) if input.Events != nil { events = *input.Events limit = 0 } if input.Limit != nil { limit = int(*input.Limit) } open := input.Open != nil && *input.Open == true
logs, err = log.ListSearch(search, channels, characters, events, open, limit) if err != nil { return nil, err } } else { logs, err = log.List(100) if err != nil { return nil, err } }
resolvers := make([]*LogResolver, len(logs)) for i := range logs { resolvers[i] = &LogResolver{L: logs[i]} }
return resolvers, nil }
// LogAddInput is an input
type LogAddInput struct { Date string Channel string Title *string Open *bool Event *string Description *string }
// AddLog resolves the addLog mutation
func (r *MutationResolver) AddLog(ctx context.Context, args *struct{ Input LogAddInput }) (*LogResolver, error) { user := session.FromContext(ctx).User() if user == nil || !user.Permitted("log.add") { return nil, ErrUnauthorized }
date, err := time.Parse(time.RFC3339Nano, args.Input.Date) if err != nil { return nil, err }
title := "" if args.Input.Title != nil { title = *args.Input.Title } event := "" if args.Input.Event != nil { event = *args.Input.Event } description := "" if args.Input.Description != nil { description = *args.Input.Description } open := args.Input.Open != nil && *args.Input.Open == true
log, err := log.New(date, args.Input.Channel, title, event, description, open) if err != nil { return nil, err }
change.Submit("Log", "add", user.ID, log.ID, map[string]interface{}{ "channel": log.Channel, "title": log.Title, "event": log.Event, "description": log.Description, "open": log.Open, })
return &LogResolver{L: log}, nil }
// LogEditInput is an input
type LogEditInput struct { ID string Title *string Event *string Description *string Open *bool }
// EditLog resolves the addLog mutation
func (r *MutationResolver) EditLog(ctx context.Context, args *struct{ Input LogEditInput }) (*LogResolver, error) { user := session.FromContext(ctx).User() if user == nil || !user.Permitted("log.edit") { return nil, ErrUnauthorized }
l, err := log.FindID(args.Input.ID) if err != nil { return nil, err }
err = l.Edit(args.Input.Title, args.Input.Event, args.Input.Description, args.Input.Open) if err != nil { return nil, err }
change.Submit("Log", "edit", user.ID, l.ID, map[string]interface{}{ "channel": l.Channel, "title": args.Input.Title, "event": args.Input.Event, "description": args.Input.Description, "open": args.Input.Open, })
return &LogResolver{L: l}, nil }
// RemoveLog resolves the removeLog mutation
func (r *MutationResolver) RemoveLog(ctx context.Context, args *struct{ ID string }) (*LogResolver, error) { user := session.FromContext(ctx).User() if user == nil || !user.Permitted("log.remove") { return nil, ErrUnauthorized }
l, err := log.FindID(args.ID) if err != nil { return nil, err }
err = log.Remove(args.ID) if err != nil { return nil, err }
change.Submit("Log", "add", user.ID, l.ID, map[string]interface{}{ "channel": l.Channel, "title": l.Title, "event": l.Event, "description": l.Description, "open": l.Open, })
return &LogResolver{L: l}, nil }
// ID resolves Log.id
func (r *LogResolver) ID() string { return r.L.ID }
// ShortID resolves Log.shortId
func (r *LogResolver) ShortID() string { return r.L.ShortID }
// Date resolves Log.date
func (r *LogResolver) Date() string { return r.L.Date.Format(time.RFC3339Nano) }
// ChannelName resolves Log.channelName
func (r *LogResolver) ChannelName() string { return r.L.Channel }
// Channel resolves Log.channe
func (r *LogResolver) Channel(ctx context.Context) (*ChannelResolver, error) { loader := loader.FromContext(ctx) if loader == nil { return nil, errors.New("no loader") }
channel, err := loader.Channel("name", r.L.Channel) if err != nil { return nil, err }
return &ChannelResolver{C: channel}, nil }
// Title resolves Log.title
func (r *LogResolver) Title() string { return r.L.Title }
// Event resolves Log.event
func (r *LogResolver) Event() string { return r.L.Event }
// Description resolves Log.description
func (r *LogResolver) Description() string { return r.L.Description }
// Open resolves Log.open
func (r *LogResolver) Open() bool { return r.L.Open }
// Characters resolves Log.characters
func (r *LogResolver) Characters(ctx context.Context) ([]*CharacterResolver, error) { loader := loader.FromContext(ctx) if loader == nil { return nil, errors.New("no loader") }
chars, err := loader.Characters("id", r.L.CharacterIDs...) if err != nil { return nil, err }
resolvers := make([]*CharacterResolver, 0, len(chars)) for i := range chars { if chars[i].ID == "" { continue }
resolvers = append(resolvers, &CharacterResolver{C: chars[i]}) }
return resolvers, nil }
// Posts resolves Log.posts
func (r *LogResolver) Posts(ctx context.Context, args *LogPostArgs) ([]*PostResolver, error) { var kinds []string if args.Kinds != nil { kinds = *args.Kinds }
posts, err := r.L.Posts(kinds...) if err != nil { return nil, err }
resolvers := make([]*PostResolver, len(posts)) for i := range posts { resolvers[i] = &PostResolver{posts[i]} }
return resolvers, nil }
|