2024-09-07 18:12:58 -04:00
|
|
|
import Route from "../route.js";
|
|
|
|
import initDb from "../db.js";
|
|
|
|
|
|
|
|
let db = await initDb();
|
|
|
|
|
|
|
|
let main = new Route([], async function (req, res, input) {
|
2024-11-04 04:21:47 -05:00
|
|
|
let { route } = req.params;
|
|
|
|
let { id } = req.query;
|
2024-10-30 20:37:20 -04:00
|
|
|
|
2024-09-07 18:12:58 -04:00
|
|
|
let body = { ...req.cookies, ...req.body };
|
|
|
|
|
|
|
|
let { token } = body;
|
|
|
|
|
|
|
|
let match = await db.all('SELECT * FROM token WHERE token = ?', [
|
|
|
|
token || 'blah'
|
|
|
|
]);
|
|
|
|
|
|
|
|
let username = match[0] ? match[0].username : '!nobody';
|
|
|
|
|
|
|
|
let valid = await db.all('SELECT * FROM auth WHERE username = ?', [
|
|
|
|
username
|
|
|
|
]);
|
|
|
|
|
2024-11-04 04:21:47 -05:00
|
|
|
let isRead = false;
|
|
|
|
|
|
|
|
if (username) {
|
|
|
|
let msgs = await db.all('SELECT * FROM message WHERE username = ? AND read = ?', [
|
|
|
|
username,
|
|
|
|
'false'
|
|
|
|
]);
|
|
|
|
|
|
|
|
isRead = msgs.length > 0
|
|
|
|
}
|
|
|
|
|
2024-09-07 18:12:58 -04:00
|
|
|
return {
|
|
|
|
username,
|
2024-10-30 20:37:20 -04:00
|
|
|
valid: valid[0] ? valid[0].valid : 'noexist',
|
|
|
|
url: `${process.env.URL}/client/${route}?id=${id || ''}`,
|
|
|
|
icon: `${process.env.URL}/static/img/logo.png`,
|
|
|
|
rootUrl: process.env.URL,
|
2024-11-04 04:21:47 -05:00
|
|
|
ogType: 'website',
|
|
|
|
isRead: isRead ? 'unread' : 'read'
|
2024-09-07 18:12:58 -04:00
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
export default main;
|