101 lines
3.4 KiB
JavaScript
101 lines
3.4 KiB
JavaScript
import { AuthenticationError, UserInputError } from 'apollo-server-errors'
|
|
|
|
export default {
|
|
Query: {
|
|
me: async (parent, args, { models, me }) =>
|
|
me ? await models.user.findUnique({ where: { id: me.id } }) : null,
|
|
user: async (parent, { name }, { models }) => {
|
|
return await models.user.findUnique({ where: { name } })
|
|
},
|
|
users: async (parent, args, { models }) =>
|
|
await models.user.findMany(),
|
|
nameAvailable: async (parent, { name }, { models, me }) => {
|
|
if (!me) {
|
|
throw new AuthenticationError('you must be logged in')
|
|
}
|
|
|
|
return me.name === name || !(await models.user.findUnique({ where: { name } }))
|
|
},
|
|
recentlyStacked: async (parent, args, { models, me }) => {
|
|
if (!me) {
|
|
throw new AuthenticationError('you must be logged in')
|
|
}
|
|
|
|
const user = await models.user.findUnique({ where: { id: me.id } })
|
|
|
|
const [{ sum }] = await models.$queryRaw(`
|
|
SELECT sum("Vote".sats)
|
|
FROM "Item"
|
|
LEFT JOIN "Vote" on "Vote"."itemId" = "Item".id
|
|
AND "Vote"."userId" <> $1
|
|
AND ("Vote".created_at > $2 OR $2 IS NULL)
|
|
AND "Vote".boost = false
|
|
WHERE "Item"."userId" = $1`, user.id, user.checkedNotesAt)
|
|
|
|
await models.user.update({ where: { id: me.id }, data: { checkedNotesAt: new Date() } })
|
|
return sum || 0
|
|
}
|
|
},
|
|
|
|
Mutation: {
|
|
setName: async (parent, { name }, { me, models }) => {
|
|
if (!me) {
|
|
throw new AuthenticationError('you must be logged in')
|
|
}
|
|
|
|
try {
|
|
await models.user.update({ where: { id: me.id }, data: { name } })
|
|
} catch (error) {
|
|
if (error.code === 'P2002') {
|
|
throw new UserInputError('name taken')
|
|
}
|
|
throw error
|
|
}
|
|
}
|
|
},
|
|
|
|
User: {
|
|
nitems: async (user, args, { models }) => {
|
|
return await models.item.count({ where: { userId: user.id, parentId: null } })
|
|
},
|
|
ncomments: async (user, args, { models }) => {
|
|
return await models.item.count({ where: { userId: user.id, parentId: { not: null } } })
|
|
},
|
|
stacked: async (user, args, { models }) => {
|
|
const [{ sum }] = await models.$queryRaw`
|
|
SELECT sum("Vote".sats)
|
|
FROM "Item"
|
|
LEFT JOIN "Vote" on "Vote"."itemId" = "Item".id AND "Vote"."userId" <> ${user.id} AND boost = false
|
|
WHERE "Item"."userId" = ${user.id}`
|
|
return sum || 0
|
|
},
|
|
sats: async (user, args, { models }) => {
|
|
return Math.floor(user.msats / 1000)
|
|
},
|
|
hasNewNotes: async (user, args, { models }) => {
|
|
// check if any votes have been cast for them since checkedNotesAt
|
|
const votes = await models.$queryRaw(`
|
|
SELECT "Vote".id, "Vote".created_at
|
|
FROM "Vote"
|
|
LEFT JOIN "Item" on "Vote"."itemId" = "Item".id
|
|
AND "Vote"."userId" <> $1
|
|
AND ("Vote".created_at > $2 OR $2 IS NULL)
|
|
AND "Vote".boost = false
|
|
WHERE "Item"."userId" = $1
|
|
LIMIT 1`, user.id, user.checkedNotesAt)
|
|
if (votes.length > 0) {
|
|
return true
|
|
}
|
|
|
|
// check if they have any replies since checkedNotesAt
|
|
const newReplies = await models.$queryRaw(`
|
|
SELECT "Item".id, "Item".created_at
|
|
From "Item"
|
|
JOIN "Item" p ON "Item"."parentId" = p.id AND p."userId" = $1
|
|
AND ("Item".created_at > $2 OR $2 IS NULL) AND "Item"."userId" <> $1
|
|
LIMIT 1`, user.id, user.checkedNotesAt)
|
|
return !!newReplies.length
|
|
}
|
|
}
|
|
}
|