[node] finished the great typescript rewrite
This commit is contained in:
parent
8107afbd90
commit
a1d6b03ec9
30 changed files with 1019 additions and 359 deletions
|
@ -1,5 +1,5 @@
|
|||
import { Contract } from '../model/contract.ts';
|
||||
import db from './db.ts';
|
||||
import { DbData, db } from './db.ts';
|
||||
|
||||
const addContractStatement = db.prepare(`INSERT INTO contracts(data) VALUES (json(?));`);
|
||||
const getContractStatement = db.prepare(`SELECT data FROM contracts WHERE data->>'id' = ?;`);
|
||||
|
@ -7,17 +7,17 @@ const getContractsStatement = db.prepare(`SELECT data FROM contracts WHERE data-
|
|||
const updateContractStatement = db.prepare(`UPDATE contracts SET data = json(:data) WHERE data->>'id' = :id;`);
|
||||
|
||||
export function getContract(id: string): Contract|null {
|
||||
const data = getContractStatement.get(id) as {data: string}|undefined;
|
||||
const data = getContractStatement.get(id) as DbData|undefined;
|
||||
if (!data) return null;
|
||||
return JSON.parse(data.data);
|
||||
}
|
||||
|
||||
export function getContracts(): Array<Contract> {
|
||||
const data = getContractsStatement.all() as Array<{data: string}>;
|
||||
const data = getContractsStatement.all() as Array<DbData>;
|
||||
return data.map(contractData => JSON.parse(contractData.data));
|
||||
}
|
||||
|
||||
export function setContract(data: Contract) {
|
||||
export function setContract(data: Contract): void {
|
||||
if (getContract(data.id) === null) {
|
||||
addContractStatement.run(JSON.stringify(data));
|
||||
} else {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue