package queries import ( "context" "errors" "time" "git.aiterp.net/rpdata/api/models/characters" "git.aiterp.net/rpdata/api/models/changekeys" "git.aiterp.net/rpdata/api/models/changes" "git.aiterp.net/rpdata/api/graph2/input" "git.aiterp.net/rpdata/api/internal/auth" "git.aiterp.net/rpdata/api/models/chapters" "git.aiterp.net/rpdata/api/models/comments" "git.aiterp.net/rpdata/api/models" ) // Queries func (r *resolver) Comment(ctx context.Context, id string) (models.Comment, error) { return comments.Find(id) } // Mutations func (r *mutationResolver) AddComment(ctx context.Context, input input.CommentAddInput) (models.Comment, error) { chapter, err := chapters.FindID(input.ChapterID) if err != nil { return models.Comment{}, errors.New("Chapter not found") } token := auth.TokenFromContext(ctx) if !token.Permitted("member", "story.edit") { return models.Comment{}, errors.New("Unauthorized") } if !chapter.CanComment() { return models.Comment{}, errors.New("You cannot comment on this chapter") } var characterPtr *models.Character if input.CharacterID != nil { character, err := characters.FindID(*input.CharacterID) if err != nil { return models.Comment{}, errors.New("Character not found") } else if character.Author != token.UserID { return models.Comment{}, errors.New("That is not your character") } characterPtr = &character } fictionalDate := time.Time{} if input.FictionalDate != nil { fictionalDate = *input.FictionalDate } subject := "" if input.Subject != nil { subject = *input.Subject } comment, err := comments.Add(chapter, subject, token.UserID, input.Source, input.CharacterName, characterPtr, time.Now(), fictionalDate) if err != nil { return models.Comment{}, errors.New("Failed to add comment: " + err.Error()) } go changes.Submit("Comment", "add", token.UserID, true, changekeys.Many(comment, chapter, models.Story{ID: chapter.StoryID}), comment, chapter) return comment, nil } func (r *mutationResolver) EditComment(ctx context.Context, input input.CommentEditInput) (models.Comment, error) { comment, err := comments.Find(input.CommentID) if err != nil { return models.Comment{}, errors.New("Comment not found") } token := auth.TokenFromContext(ctx) if !token.PermittedUser(comment.Author, "member", "story.edit") { return models.Comment{}, errors.New("You cannot edit this comment") } chapter, err := chapters.FindID(comment.ChapterID) if err != nil { return models.Comment{}, errors.New("Comment's chapter not found") } if !chapter.CanComment() { return models.Comment{}, errors.New("Comments are disabled or locked") } if input.ClearFictionalDate != nil && *input.ClearFictionalDate == true { input.FictionalDate = &time.Time{} } if input.CharacterID != nil && *input.CharacterID != "" { character, err := characters.FindID(*input.CharacterID) if err != nil { return models.Comment{}, errors.New("Character not found") } else if character.Author != token.UserID { return models.Comment{}, errors.New("That is not your character") } } comment, err = comments.Edit(comment, input.Source, input.CharacterName, input.CharacterID, input.Subject, input.FictionalDate) if err != nil { return models.Comment{}, errors.New("Could not post comment: " + err.Error()) } go changes.Submit("Comment", "edit", token.UserID, true, changekeys.Many(comment, chapter, models.Story{ID: chapter.StoryID}), comment, chapter) return comment, nil }