Add post/get for account save data

This commit is contained in:
2026-01-21 18:26:23 -07:00
parent b6fb9a3318
commit 28ac702515
3 changed files with 152 additions and 0 deletions

View File

@@ -0,0 +1,59 @@
import { Context } from 'elysia'
import { getDatabaseConnection, jsonResponse } from '../../../../lib/util'
import { checkAuthorization } from '../../../../lib/bd/auth'
import { berryDashUserData, users } from '../../../../lib/tables'
import { eq } from 'drizzle-orm'
export async function handler (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
const authorizationToken = context.headers.authorization
const authResult = await checkAuthorization(authorizationToken as string, db1)
if (!authResult.valid) {
connection0.end()
connection1.end()
return jsonResponse(
{ success: false, message: 'Unauthorized', data: null },
401
)
}
const userId = authResult.id
const result = await db1
.select({
saveData: berryDashUserData.saveData,
token: berryDashUserData.token
})
.from(berryDashUserData)
.where(eq(berryDashUserData.id, userId))
.execute()
const result2 = await db0
.select({ username: users.username })
.from(users)
.where(eq(users.id, userId))
.execute()
connection0.end()
connection1.end()
if (!result || !result)
return jsonResponse(
{ success: false, message: 'Unauthorized', data: null },
401
)
let savedata = JSON.parse(result[0].saveData)
savedata.account.id = userId
savedata.account.name = result2[0].username
savedata.account.session = result[0].token
return jsonResponse({ success: true, message: null, data: savedata }, 200)
}

View File

@@ -0,0 +1,62 @@
import { Context } from 'elysia'
import { getDatabaseConnection, jsonResponse } from '../../../../lib/util'
import { checkAuthorization } from '../../../../lib/bd/auth'
import { berryDashUserData, users } from '../../../../lib/tables'
import { eq } from 'drizzle-orm'
type Body = {
saveData: string
}
export async function handler (context: Context) {
const dbInfo0 = getDatabaseConnection(0)
const dbInfo1 = getDatabaseConnection(1)
if (!dbInfo0 || !dbInfo1)
return jsonResponse(
{ success: false, message: 'Failed to connect to database' },
500
)
const { connection: connection0, db: db0 } = dbInfo0
const { connection: connection1, db: db1 } = dbInfo1
const authorizationToken = context.headers.authorization
const authResult = await checkAuthorization(authorizationToken as string, db1)
if (!authResult.valid) {
connection0.end()
connection1.end()
return jsonResponse({ success: false, message: 'Unauthorized' }, 401)
}
const userId = authResult.id
const body = context.body as Body
if (!body.saveData) {
connection0.end()
connection1.end()
return jsonResponse(
{ success: false, message: 'No valid save data provided' },
400
)
}
let userSaveData: any = {}
try {
userSaveData = JSON.parse(atob(body.saveData))
userSaveData.account.id = null
userSaveData.account.name = null
userSaveData.account.session = null
} catch {
return jsonResponse(
{ success: false, message: "Couldn't parse save data" },
400
)
}
await db1
.update(berryDashUserData)
.set({ saveData: JSON.stringify(userSaveData) })
.where(eq(berryDashUserData.id, userId))
.execute()
return jsonResponse({ success: true, message: null })
}