You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
184 lines
4.8 KiB
184 lines
4.8 KiB
package queries
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"strings"
|
|
"time"
|
|
|
|
"git.aiterp.net/rpdata/api/models/channels"
|
|
|
|
"git.aiterp.net/rpdata/api/graph2/input"
|
|
"git.aiterp.net/rpdata/api/internal/auth"
|
|
"git.aiterp.net/rpdata/api/internal/loader"
|
|
"git.aiterp.net/rpdata/api/models"
|
|
"git.aiterp.net/rpdata/api/models/changekeys"
|
|
"git.aiterp.net/rpdata/api/models/changes"
|
|
"git.aiterp.net/rpdata/api/models/logs"
|
|
"github.com/99designs/gqlgen/graphql"
|
|
)
|
|
|
|
// Queries
|
|
|
|
func (r *resolver) Log(ctx context.Context, id string) (models.Log, error) {
|
|
return logs.FindID(id)
|
|
}
|
|
|
|
func (r *resolver) Logs(ctx context.Context, filter *logs.Filter) ([]models.Log, error) {
|
|
logs, err := logs.List(filter)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
reqCtx := graphql.GetRequestContext(ctx)
|
|
maybeCharacters := strings.Contains(reqCtx.RawQuery, "characters")
|
|
maybeChannels := strings.Contains(reqCtx.RawQuery, "channels")
|
|
|
|
if len(logs) >= 100 && (maybeCharacters || maybeChannels) {
|
|
loader := loader.FromContext(ctx)
|
|
if loader == nil {
|
|
return nil, errors.New("no loader")
|
|
}
|
|
|
|
for _, log := range logs {
|
|
if maybeChannels {
|
|
loader.PrimeChannels("name", log.ChannelName)
|
|
}
|
|
|
|
if maybeCharacters {
|
|
loader.PrimeCharacters("id", log.CharacterIDs...)
|
|
}
|
|
}
|
|
}
|
|
|
|
return logs, nil
|
|
}
|
|
|
|
// Mutations
|
|
|
|
func (r *mutationResolver) AddLog(ctx context.Context, input input.LogAddInput) (models.Log, error) {
|
|
token := auth.TokenFromContext(ctx)
|
|
if !token.Authenticated() || !token.Permitted("log.add") {
|
|
return models.Log{}, errors.New("You are not permitted to add logs")
|
|
}
|
|
|
|
open := input.Open != nil && *input.Open == true
|
|
title := ""
|
|
if input.Title != nil {
|
|
title = *input.Title
|
|
}
|
|
event := ""
|
|
if input.Event != nil {
|
|
event = *input.Event
|
|
}
|
|
description := ""
|
|
if input.Description != nil {
|
|
description = *input.Description
|
|
}
|
|
|
|
existingChannel, _ := channels.FindName(input.Channel)
|
|
|
|
log, err := logs.Add(input.Date, input.Channel, title, event, description, open)
|
|
if !token.Authenticated() || !token.Permitted("log.add") {
|
|
return models.Log{}, errors.New("Failed to create log: " + err.Error())
|
|
}
|
|
|
|
go func() {
|
|
if existingChannel.Name == "" {
|
|
channel, err := channels.FindName(input.Channel)
|
|
if err == nil {
|
|
changes.Submit("Channel", "add", token.UserID, true, changekeys.Listed(channel), channel)
|
|
}
|
|
}
|
|
|
|
changes.Submit("Log", "add", token.UserID, true, changekeys.Listed(log), log)
|
|
}()
|
|
|
|
return log, nil
|
|
}
|
|
|
|
func (r *mutationResolver) ImportLog(ctx context.Context, input input.LogImportInput) ([]models.Log, error) {
|
|
token := auth.TokenFromContext(ctx)
|
|
if !token.Authenticated() || !token.Permitted("log.add") {
|
|
return nil, errors.New("You are not permitted to add logs")
|
|
}
|
|
|
|
date := time.Time{}
|
|
if input.Date != nil {
|
|
date = *input.Date
|
|
}
|
|
|
|
tz := time.UTC
|
|
if input.Timezone != nil {
|
|
parsedTZ, err := time.LoadLocation(*input.Timezone)
|
|
if err != nil {
|
|
return nil, errors.New("Unknown timezone: " + *input.Timezone)
|
|
}
|
|
|
|
tz = parsedTZ
|
|
}
|
|
|
|
results, err := logs.Import(input.Importer, date, tz, input.ChannelName, input.Data)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
newLogs := make([]models.Log, 0, len(results))
|
|
for _, result := range results {
|
|
go func() {
|
|
changes.Submit("Log", "add", token.UserID, true, changekeys.Many(result.Log), result.Log)
|
|
changes.Submit("Post", "add", token.UserID, true, changekeys.Many(result.Log, result.Posts), result.Posts)
|
|
}()
|
|
|
|
log, err := logs.UpdateCharacters(result.Log, false)
|
|
if err != nil {
|
|
log = result.Log
|
|
}
|
|
|
|
newLogs = append(newLogs, log)
|
|
}
|
|
|
|
return newLogs, nil
|
|
}
|
|
|
|
func (r *mutationResolver) EditLog(ctx context.Context, input input.LogEditInput) (models.Log, error) {
|
|
token := auth.TokenFromContext(ctx)
|
|
if !token.Authenticated() || !token.Permitted("log.edit") {
|
|
return models.Log{}, errors.New("You are not permitted to edit logs")
|
|
}
|
|
|
|
log, err := logs.FindID(input.ID)
|
|
if err != nil {
|
|
return models.Log{}, errors.New("Log not found")
|
|
}
|
|
|
|
log, err = logs.Edit(log, input.Title, input.Event, input.Description, input.Open)
|
|
if err != nil {
|
|
return models.Log{}, errors.New("Failed to edit log: " + err.Error())
|
|
}
|
|
|
|
go changes.Submit("Log", "edit", token.UserID, true, changekeys.Listed(log), log)
|
|
|
|
return log, nil
|
|
}
|
|
|
|
func (r *mutationResolver) RemoveLog(ctx context.Context, input input.LogRemoveInput) (models.Log, error) {
|
|
token := auth.TokenFromContext(ctx)
|
|
if !token.Authenticated() || !token.Permitted("log.remove") {
|
|
return models.Log{}, errors.New("You are not permitted to remove logs")
|
|
}
|
|
|
|
log, err := logs.FindID(input.ID)
|
|
if err != nil {
|
|
return models.Log{}, errors.New("Log not found")
|
|
}
|
|
|
|
log, err = logs.Remove(log)
|
|
if err != nil {
|
|
return models.Log{}, errors.New("Failed to remove log: " + err.Error())
|
|
}
|
|
|
|
go changes.Submit("Log", "remove", token.UserID, true, changekeys.Listed(log), log)
|
|
|
|
return log, nil
|
|
}
|