package resolvers import ( "context" "errors" "time" "git.aiterp.net/rpdata/api/graph2/graphcore" "git.aiterp.net/rpdata/api/internal/auth" "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/chapters" "git.aiterp.net/rpdata/api/models/stories" ) func (r *queryResolver) Story(ctx context.Context, id string) (*models.Story, error) { story, err := stories.FindID(id) if err != nil { return nil, err } return &story, nil } func (r *queryResolver) Stories(ctx context.Context, filter *stories.Filter) ([]*models.Story, error) { if filter != nil { if filter.Unlisted != nil && *filter.Unlisted == true { token := auth.TokenFromContext(ctx) if !token.Authenticated() { return nil, errors.New("You are not permitted to view unlisted stories") } if !token.Permitted("story.unlisted") { filter.Author = &token.UserID } } } stories, err := stories.List(filter) if err != nil { return nil, err } stories2 := make([]*models.Story, len(stories)) for i := range stories { stories2[i] = &stories[i] } return stories2, nil } // Mutations func (r *mutationResolver) AddStory(ctx context.Context, input graphcore.StoryAddInput) (*models.Story, error) { token := auth.TokenFromContext(ctx) if token == nil || !token.Permitted("member", "story.add") { return nil, errors.New("Permission denied") } author := token.UserID if input.Author != nil && *input.Author != author { if !token.Permitted("story.add") { return nil, errors.New("You are not permitted to add a story in another author's name") } author = *input.Author } fictionalDate := time.Time{} if input.FictionalDate != nil { fictionalDate = *input.FictionalDate } listed := input.Listed != nil && *input.Listed open := input.Open != nil && *input.Open tags := make([]models.Tag, len(input.Tags)) for i := range input.Tags { tags[i] = *input.Tags[i] } story, err := stories.Add(input.Name, author, input.Category, listed, open, tags, time.Now(), fictionalDate) if err != nil { return nil, errors.New("Failed to add story: " + err.Error()) } go changes.Submit("Story", "add", token.UserID, story.Listed, changekeys.Listed(story), story) return &story, nil } func (r *mutationResolver) AddStoryTag(ctx context.Context, input graphcore.StoryTagAddInput) (*models.Story, error) { token := auth.TokenFromContext(ctx) story, err := stories.FindID(input.ID) if err != nil { return nil, errors.New("Story not found") } if story.Open { if !token.Permitted("member") { return nil, errors.New("You are not permitted to edit this story") } } else { if !token.PermittedUser(story.Author, "member", "story.edit") { return nil, errors.New("You are not permitted to edit this story") } } story, err = stories.AddTag(story, *input.Tag) if err != nil { return nil, errors.New("Failed to add story: " + err.Error()) } go changes.Submit("Story", "tag", token.UserID, story.Listed, changekeys.Listed(story), story, input.Tag) return &story, nil } func (r *mutationResolver) RemoveStoryTag(ctx context.Context, input graphcore.StoryTagRemoveInput) (*models.Story, error) { token := auth.TokenFromContext(ctx) story, err := stories.FindID(input.ID) if err != nil { return nil, errors.New("Story not found") } if story.Open { if !token.Permitted("member") { return nil, errors.New("You are not permitted to edit this story") } } else { if !token.PermittedUser(story.Author, "member", "story.edit") { return nil, errors.New("You are not permitted to edit this story") } } story, err = stories.RemoveTag(story, *input.Tag) if err != nil { return nil, errors.New("Failed to add story: " + err.Error()) } go changes.Submit("Story", "untag", token.UserID, story.Listed, changekeys.Listed(story), story, input.Tag) return &story, nil } func (r *mutationResolver) EditStory(ctx context.Context, input graphcore.StoryEditInput) (*models.Story, error) { token := auth.TokenFromContext(ctx) story, err := stories.FindID(input.ID) if err != nil { return nil, errors.New("Story not found") } if !token.PermittedUser(story.Author, "member", "story.edit") { return nil, errors.New("You are not permitted to remove this story") } if input.ClearFictionalDate != nil && *input.ClearFictionalDate { input.FictionalDate = &time.Time{} } story, err = stories.Edit(story, input.Name, input.Category, input.Listed, input.Open, input.FictionalDate) if err != nil { return nil, errors.New("Failed to add story: " + err.Error()) } go changes.Submit("Story", "edit", token.UserID, story.Listed, changekeys.Listed(story), story) return &story, nil } func (r *mutationResolver) RemoveStory(ctx context.Context, input graphcore.StoryRemoveInput) (*models.Story, error) { token := auth.TokenFromContext(ctx) story, err := stories.FindID(input.ID) if err != nil { return nil, errors.New("Story not found") } if !token.PermittedUser(story.Author, "member", "story.remove") { return nil, errors.New("You are not permitted to remove this story") } story, err = stories.Remove(story) if err != nil { return nil, err } err = chapters.RemoveStory(story) if err != nil { return nil, errors.New("Failed to remove chapters, but story is removed: " + err.Error()) } go changes.Submit("Story", "remove", token.UserID, story.Listed, changekeys.Listed(story), story) return &story, nil }