blob: 57c640b9037749bd5538cd73fab0c92f04526cf8 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
import { Client } from "https://deno.land/x/mysql/mod.ts";
import { readFileStr } from "https://deno.land/std/fs/mod.ts";
export default class DBController {
async init() {
const conn = await this.connect();
try {
const sql = await readFileStr("./src/db/tables.sql");
const queries = sql.split(";");
queries.pop();
queries.forEach((query) => conn.execute(query));
console.log("Tables created");
} catch (e) {
console.error("Could not create tables");
throw e;
} finally {
conn.close();
}
}
async connect(): Promise<Client> {
try {
return await new Client().connect({
hostname: Deno.env.get("DBHost"),
username: Deno.env.get("DBUser"),
db: Deno.env.get("DBName"),
password: Deno.env.get("DBPassword"),
});
} catch (e) {
console.error("Could not connect to database");
throw e;
}
}
}
|