|
@@ -1,64 +1,63 @@
|
|
|
-import Elysia from 'elysia';
|
|
|
-import * as db from './postgres';
|
|
|
-import { Fortune } from './types';
|
|
|
+import { Elysia, t } from "elysia";
|
|
|
+import * as db from "./postgres";
|
|
|
+import { Fortune } from "./types";
|
|
|
|
|
|
-function rand () {
|
|
|
- return Math.ceil(Math.random() * 10000)
|
|
|
+function rand() {
|
|
|
+ return Math.ceil(Math.random() * 10000);
|
|
|
}
|
|
|
|
|
|
-function parseQueriesNumber (q?: string) {
|
|
|
- return Math.min(parseInt(q || '1') || 1, 500)
|
|
|
+function parseQueriesNumber(q?: string) {
|
|
|
+ return Math.min(parseInt(q || "1") || 1, 500);
|
|
|
}
|
|
|
|
|
|
-function renderTemplate (fortunes: Fortune[]) {
|
|
|
+function renderTemplate(fortunes: Fortune[]) {
|
|
|
const n = fortunes.length;
|
|
|
|
|
|
- let html = '';
|
|
|
+ let html = "";
|
|
|
for (let i = 0; i < n; i++) {
|
|
|
html += `<tr><td>${fortunes[i].id}</td><td>${Bun.escapeHTML(
|
|
|
- fortunes[i].message
|
|
|
+ fortunes[i].message,
|
|
|
)}</td></tr>`;
|
|
|
}
|
|
|
|
|
|
return `<!DOCTYPE html><html><head><title>Fortunes</title></head><body><table><tr><th>id</th><th>message</th></tr>${html}</table></body></html>`;
|
|
|
}
|
|
|
|
|
|
-const dbHandlers = new Elysia({
|
|
|
- name: 'db-handlers',
|
|
|
-})
|
|
|
- .onAfterHandle(({ set }) => {
|
|
|
- set.headers['server'] = 'Elysia';
|
|
|
+export const dbHandlers = new Elysia()
|
|
|
+ .headers({
|
|
|
+ server: "Elysia",
|
|
|
})
|
|
|
-
|
|
|
- .get('/db', () => db.find(rand()))
|
|
|
-
|
|
|
- .get('/fortunes', async ({ set }) => {
|
|
|
+ .get("/db", () => db.find(rand()))
|
|
|
+ .get("/fortunes", async (c) => {
|
|
|
const fortunes = await db.fortunes();
|
|
|
|
|
|
fortunes.push({
|
|
|
id: 0,
|
|
|
- message: 'Additional fortune added at request time.',
|
|
|
+ message: "Additional fortune added at request time.",
|
|
|
+ });
|
|
|
+
|
|
|
+ fortunes.sort((a, b) => {
|
|
|
+ if (a.message < b.message) return -1;
|
|
|
+
|
|
|
+ return 1;
|
|
|
});
|
|
|
|
|
|
- fortunes.sort((a, b) => (a.message < b.message ? -1 : 1));
|
|
|
+ c.set.headers["content-type"] = "text/html; charset=utf-8";
|
|
|
|
|
|
- set.headers['content-type'] = 'text/html; charset=utf-8';
|
|
|
return renderTemplate(fortunes);
|
|
|
})
|
|
|
-
|
|
|
- .get('/queries', async ({ query }) => {
|
|
|
- const num = parseQueriesNumber(query.queries)
|
|
|
+ .get("/queries", (c) => {
|
|
|
+ const num = parseQueriesNumber(c.query.queries);
|
|
|
const worldPromises = new Array(num);
|
|
|
|
|
|
for (let i = 0; i < num; i++) {
|
|
|
worldPromises[i] = db.find(rand());
|
|
|
}
|
|
|
|
|
|
- return await Promise.all(worldPromises);
|
|
|
+ return Promise.all(worldPromises);
|
|
|
})
|
|
|
-
|
|
|
- .get('/updates', async ({ query }) => {
|
|
|
- const num = parseQueriesNumber(query.queries)
|
|
|
+ .get("/updates", async (c) => {
|
|
|
+ const num = parseQueriesNumber(c.query.queries);
|
|
|
const worldPromises = new Array(num);
|
|
|
|
|
|
for (let i = 0; i < num; i++) {
|
|
@@ -74,5 +73,3 @@ const dbHandlers = new Elysia({
|
|
|
await db.bulkUpdate(worlds);
|
|
|
return worlds;
|
|
|
});
|
|
|
-
|
|
|
-export default dbHandlers;
|