2018-03-31 21:07:58 +08:00
|
|
|
"use strict";
|
|
|
|
|
2018-01-30 12:17:44 +08:00
|
|
|
const sql = require('./sql');
|
2018-01-31 09:12:19 +08:00
|
|
|
const sync_table = require('../services/sync_table');
|
2018-01-30 12:17:44 +08:00
|
|
|
|
2018-03-31 22:51:37 +08:00
|
|
|
let entityConstructor;
|
|
|
|
|
|
|
|
async function setEntityConstructor(constructor) {
|
|
|
|
entityConstructor = constructor;
|
|
|
|
}
|
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
async function getEntities(query, params = []) {
|
|
|
|
const rows = await sql.getRows(query, params);
|
|
|
|
|
2018-03-31 22:51:37 +08:00
|
|
|
return rows.map(entityConstructor);
|
2018-03-31 21:07:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
async function getEntity(query, params = []) {
|
|
|
|
const row = await sql.getRowOrNull(query, params);
|
2018-01-30 12:17:44 +08:00
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
if (!row) {
|
|
|
|
return null;
|
2018-01-30 12:17:44 +08:00
|
|
|
}
|
|
|
|
|
2018-03-31 22:51:37 +08:00
|
|
|
return entityConstructor(row);
|
2018-03-31 21:07:58 +08:00
|
|
|
}
|
2018-01-30 12:17:44 +08:00
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
async function getNote(noteId) {
|
2018-03-31 22:51:37 +08:00
|
|
|
return await getEntity("SELECT * FROM notes WHERE noteId = ?", [noteId]);
|
2018-03-31 21:07:58 +08:00
|
|
|
}
|
2018-01-30 12:35:36 +08:00
|
|
|
|
2018-04-01 11:08:22 +08:00
|
|
|
async function getBranch(branchId) {
|
|
|
|
return await getEntity("SELECT * FROM branches WHERE branchId = ?", [branchId]);
|
|
|
|
}
|
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
async function updateEntity(entity) {
|
|
|
|
if (entity.beforeSaving) {
|
|
|
|
entity.beforeSaving();
|
|
|
|
}
|
2018-01-30 12:35:36 +08:00
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
const clone = Object.assign({}, entity);
|
2018-01-30 12:35:36 +08:00
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
delete clone.jsonContent;
|
2018-01-31 09:12:19 +08:00
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
await sql.replace(entity.constructor.tableName, clone);
|
2018-01-31 09:12:19 +08:00
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
const primaryKey = entity[entity.constructor.primaryKeyName];
|
|
|
|
|
|
|
|
await sync_table.addEntitySync(entity.constructor.tableName, primaryKey);
|
2018-01-30 12:17:44 +08:00
|
|
|
}
|
|
|
|
|
2018-03-31 21:07:58 +08:00
|
|
|
module.exports = {
|
|
|
|
getEntities,
|
|
|
|
getEntity,
|
|
|
|
getNote,
|
2018-04-01 11:08:22 +08:00
|
|
|
getBranch,
|
2018-03-31 22:51:37 +08:00
|
|
|
updateEntity,
|
|
|
|
setEntityConstructor
|
2018-03-31 21:07:58 +08:00
|
|
|
};
|