2018-01-14 07:02:41 +08:00
|
|
|
"use strict";
|
|
|
|
|
2018-01-14 04:25:09 +08:00
|
|
|
const sql = require('./sql');
|
|
|
|
const utils = require('./utils');
|
|
|
|
const sync_table = require('./sync_table');
|
2018-01-27 12:40:48 +08:00
|
|
|
const protected_session = require('./protected_session');
|
2018-01-14 04:25:09 +08:00
|
|
|
|
2018-01-24 11:11:03 +08:00
|
|
|
async function getNoteAttributeMap(noteId) {
|
|
|
|
return await sql.getMap(`SELECT name, value FROM attributes WHERE note_id = ?`, [noteId]);
|
|
|
|
}
|
|
|
|
|
2018-01-14 04:25:09 +08:00
|
|
|
async function getNoteIdWithAttribute(name, value) {
|
2018-01-27 12:40:48 +08:00
|
|
|
return await sql.getFirstValue(`SELECT notes.note_id FROM notes JOIN attributes USING(note_id)
|
2018-01-14 04:25:09 +08:00
|
|
|
WHERE notes.is_deleted = 0 AND attributes.name = ? AND attributes.value = ?`, [name, value]);
|
|
|
|
}
|
|
|
|
|
2018-01-27 12:40:48 +08:00
|
|
|
async function getNoteWithAttribute(dataKey, name, value) {
|
|
|
|
const note = await sql.getFirst(`SELECT notes.* FROM notes JOIN attributes USING(note_id)
|
|
|
|
WHERE notes.is_deleted = 0 AND attributes.name = ? AND attributes.value = ?`, [name, value]);
|
|
|
|
|
|
|
|
if (!note) {
|
|
|
|
return note;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected_session.decryptNote(dataKey, note);
|
|
|
|
|
|
|
|
return note;
|
|
|
|
}
|
|
|
|
|
2018-01-26 12:49:03 +08:00
|
|
|
async function getNoteIdsWithAttribute(name) {
|
|
|
|
return await sql.getFirstColumn(`SELECT DISTINCT notes.note_id FROM notes JOIN attributes USING(note_id)
|
|
|
|
WHERE notes.is_deleted = 0 AND attributes.name = ?`, [name]);
|
|
|
|
}
|
|
|
|
|
2018-01-14 04:25:09 +08:00
|
|
|
async function createAttribute(noteId, name, value = null, sourceId = null) {
|
|
|
|
const now = utils.nowDate();
|
|
|
|
const attributeId = utils.newAttributeId();
|
|
|
|
|
|
|
|
await sql.insert("attributes", {
|
|
|
|
attribute_id: attributeId,
|
|
|
|
note_id: noteId,
|
|
|
|
name: name,
|
|
|
|
value: value,
|
|
|
|
date_modified: now,
|
|
|
|
date_created: now
|
|
|
|
});
|
|
|
|
|
|
|
|
await sync_table.addAttributeSync(attributeId, sourceId);
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
2018-01-24 11:11:03 +08:00
|
|
|
getNoteAttributeMap,
|
2018-01-14 04:25:09 +08:00
|
|
|
getNoteIdWithAttribute,
|
2018-01-27 12:40:48 +08:00
|
|
|
getNoteWithAttribute,
|
2018-01-26 12:49:03 +08:00
|
|
|
getNoteIdsWithAttribute,
|
2018-01-14 04:25:09 +08:00
|
|
|
createAttribute
|
|
|
|
};
|