1
0
Fork 0

[javascript] add database function to fetch all contracts

This commit is contained in:
Julien Dessaux 2023-09-08 22:34:22 +02:00
parent a9cd987c50
commit 2ae1d4e8fd
Signed by: adyxax
GPG key ID: F92E51B86E07177E

View file

@ -2,6 +2,7 @@ import db from './db.js';
const addContractStatement = db.prepare(`INSERT INTO contracts(data) VALUES (json(?));`);
const getContractStatement = db.prepare(`SELECT data FROM contracts WHERE data->>'id' = ?;`);
const getContractsStatement = db.prepare(`SELECT data FROM contracts WHERE data->>'fulfilled' = false;`);
const updateContractStatement = db.prepare(`UPDATE contracts SET data = json(:data) WHERE data->>'id' = :id;`);
export function getContract(id) {
@ -12,6 +13,11 @@ export function getContract(id) {
return JSON.parse(data.data);
}
export function getContracts() {
const data = getContractsStatement.all();
return data.map(contractData => JSON.parse(contractData.data));
}
export function setContract(data) {
if (getContract(data.id) === null) {
return addContractStatement.run(JSON.stringify(data)).lastInsertRowid;