76 lines
1.8 KiB
TypeScript
76 lines
1.8 KiB
TypeScript
import { Context } from 'elysia'
|
|
import {
|
|
genTimestamp,
|
|
getDatabaseConnection,
|
|
jsonResponse
|
|
} from '../../../../lib/util'
|
|
import { berryDashUserPosts, users } from '../../../../lib/tables'
|
|
import { and, desc, eq } from 'drizzle-orm'
|
|
|
|
export const handler = async (context: Context) => {
|
|
const dbInfo0 = getDatabaseConnection(0)
|
|
const dbInfo1 = getDatabaseConnection(1)
|
|
|
|
if (!dbInfo0 || !dbInfo1)
|
|
return jsonResponse(
|
|
{ success: false, message: 'Failed to connect to database', data: null },
|
|
500
|
|
)
|
|
const { connection: connection0, db: db0 } = dbInfo0
|
|
const { connection: connection1, db: db1 } = dbInfo1
|
|
|
|
let userIdQuery = context.query.userId
|
|
? parseInt(context.query.userId, 10)
|
|
: 0
|
|
|
|
const user = await db0
|
|
.select({ id: users.id })
|
|
.from(users)
|
|
.where(eq(users.id, userIdQuery))
|
|
.execute()
|
|
|
|
if (!user[0]) {
|
|
connection0.end()
|
|
connection1.end()
|
|
return jsonResponse(
|
|
{ success: false, message: 'User does not exist', data: null },
|
|
404
|
|
)
|
|
}
|
|
|
|
const userPosts = await db1
|
|
.select({
|
|
id: berryDashUserPosts.id,
|
|
content: berryDashUserPosts.content,
|
|
timestamp: berryDashUserPosts.timestamp,
|
|
votes: berryDashUserPosts.votes
|
|
})
|
|
.from(berryDashUserPosts)
|
|
.where(
|
|
and(
|
|
eq(berryDashUserPosts.userId, user[0].id),
|
|
eq(berryDashUserPosts.deletedAt, 0)
|
|
)
|
|
)
|
|
.orderBy(desc(berryDashUserPosts.id))
|
|
.execute()
|
|
|
|
const result = userPosts.map(post => {
|
|
let likes = 0
|
|
for (const vote of Object.values(JSON.parse(post.votes)) as boolean[])
|
|
likes += vote ? 1 : -1
|
|
|
|
return {
|
|
id: post.id,
|
|
content: atob(post.content),
|
|
timestamp: genTimestamp(post.timestamp) + ' ago',
|
|
likes
|
|
}
|
|
})
|
|
|
|
connection0.end()
|
|
connection1.end()
|
|
|
|
return result
|
|
}
|