mirror of
https://github.com/wasp-lang/wasp.git
synced 2024-12-27 19:14:52 +03:00
104 lines
3.8 KiB
JavaScript
104 lines
3.8 KiB
JavaScript
import slug from 'slug'
|
|
|
|
import HttpError from '@wasp/core/HttpError.js'
|
|
|
|
|
|
export const createArticle = async ({ title, description, markdownContent, tags }, context) => {
|
|
if (!context.user) { throw new HttpError(403) }
|
|
|
|
// TODO: Nicer error handling! Right now everything is returned as 500 while it could be instead
|
|
// useful error message about username being taken / not unique, and other validation errors.
|
|
return await context.entities.Article.create({
|
|
data: {
|
|
title,
|
|
slug: slug(title) + '-' + (Math.random() * Math.pow(36, 6) | 0).toString(36),
|
|
description,
|
|
markdownContent,
|
|
user: { connect: { id: context.user.id } },
|
|
tags: { connectOrCreate: tags.map(tag => ({ where: tag, create: tag })) }
|
|
}
|
|
})
|
|
}
|
|
|
|
export const updateArticle = async ({ id, title, description, markdownContent, tags, favorited }, context) => {
|
|
if (!context.user) { throw new HttpError(403) }
|
|
|
|
// TODO: Nicer error handling! Right now everything is returned as 500 while it could be instead
|
|
// useful error message about username being taken / not unique, and other validation errors.
|
|
|
|
const article = await context.entities.Article.findFirst({
|
|
where: { id, user: { id: context.user.id }}, // TODO: This line is not fun to write.
|
|
include: { tags: true }
|
|
})
|
|
if (!article) {
|
|
throw new HttpError(404)
|
|
}
|
|
|
|
const subtractTags = (tags1, tags2) => tags1.filter(t1 => !tags2.find(t2 => t2.name === t1.name))
|
|
const tagsToAdd = tags ? subtractTags(tags, article.tags) : []
|
|
const tagsToRemove = tags ? subtractTags(article.tags, tags) : []
|
|
|
|
await context.entities.Article.update({
|
|
where: { id },
|
|
data: {
|
|
title,
|
|
description,
|
|
markdownContent,
|
|
tags: {
|
|
connectOrCreate: tagsToAdd.map(tag => ({ where: tag, create: tag })),
|
|
disconnect: tagsToRemove
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
export const deleteArticle = async ({ id }, context) => {
|
|
if (!context.user) { throw new HttpError(403) }
|
|
|
|
// TODO: Nicer error handling! Right now everything is returned as 500 while it could be instead
|
|
// useful error message about username being taken / not unique, and other validation errors.
|
|
await context.entities.Article.deleteMany({ // TODO: Prisma quirk: I use deleteMany instead of delete so I can specify user.
|
|
where: { id, user: { id: context.user.id }} // TODO: This line is not fun to write.
|
|
})
|
|
}
|
|
|
|
export const setArticleFavorited = async ({ id, favorited }, context) => {
|
|
if (!context.user) { throw new HttpError(403) }
|
|
|
|
await context.entities.Article.update({
|
|
where: { id },
|
|
data: {
|
|
favoritedBy: {
|
|
...(favorited === true ? { connect: { username: context.user.username } } :
|
|
favorited === false ? { disconnect: { username: context.user.username } } :
|
|
{}
|
|
)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
export const createComment = async ({ articleId, content }, context) => {
|
|
if (!context.user) { throw new HttpError(403) }
|
|
|
|
// TODO: Nicer error handling! Right now everything is returned as 500 while it could be instead
|
|
// useful error message about username being taken / not unique, and other validation errors.
|
|
return await context.entities.Comment.create({
|
|
data: {
|
|
content,
|
|
user: { connect: { id: context.user.id } },
|
|
article: { connect: { id: articleId } }
|
|
}
|
|
})
|
|
}
|
|
|
|
export const deleteComment = async ({ id }, context) => {
|
|
if (!context.user) { throw new HttpError(403) }
|
|
|
|
// TODO: Nicer error handling! Right now everything is returned as 500 while it could be instead
|
|
// useful error message about username being taken / not unique, and other validation errors.
|
|
await context.entities.Comment.deleteMany({ // TODO: Prisma quirk: I use deleteMany instead of delete so I can specify user.
|
|
where: { id, user: { id: context.user.id }} // TODO: This line is not fun to write.
|
|
})
|
|
}
|