Rewrote the api rate limiter with promises instead of callbacks
This commit is contained in:
parent
efdf50a55a
commit
9963ab79b7
6 changed files with 105 additions and 40 deletions
6
database/001_systems.sql
Normal file
6
database/001_systems.sql
Normal file
|
@ -0,0 +1,6 @@
|
|||
CREATE TABLE systems (
|
||||
id INTEGER PRIMARY KEY,
|
||||
symbol TEXT NOT NULL UNIQUE,
|
||||
data TEXT NOT NULL,
|
||||
updated DATE DEFAULT (datetime('now'))
|
||||
);
|
|
@ -3,6 +3,7 @@ import Database from 'better-sqlite3';
|
|||
|
||||
const allMigrations = [
|
||||
'database/000_init.sql',
|
||||
'database/001_systems.sql',
|
||||
];
|
||||
|
||||
const db = new Database(
|
||||
|
|
26
database/systems.js
Normal file
26
database/systems.js
Normal file
|
@ -0,0 +1,26 @@
|
|||
import db from './db.js';
|
||||
|
||||
const getSystemStatement = db.prepare(`SELECT data from systems where symbol = ?;`);
|
||||
const setSystemStatement = db.prepare(`INSERT INTO systems(symbol, data) VALUES (?, ?);`);
|
||||
|
||||
export function getSystem(symbol) {
|
||||
try {
|
||||
const data = getSystemStatement.get(symbol);
|
||||
if (data === undefined) {
|
||||
return null;
|
||||
}
|
||||
return JSON.parse(data.data);
|
||||
} catch (err) {
|
||||
console.log(err);
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
export function setSystem(symbol, data) {
|
||||
try {
|
||||
return setSystemStatement.run(symbol, JSON.stringify(data)).lastInsertRowid;
|
||||
} catch (err) {
|
||||
console.log(err);
|
||||
return null;
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue