mirror of
https://github.com/zadam/trilium.git
synced 2024-12-27 09:43:18 +08:00
433982e7bc
- when syncing note tree we don't overwrite is_expanded status
125 lines
No EOL
4.5 KiB
JavaScript
125 lines
No EOL
4.5 KiB
JavaScript
const sql = require('./sql');
|
|
const log = require('./log');
|
|
const options = require('./options');
|
|
const utils = require('./utils');
|
|
const audit_category = require('./audit_category');
|
|
const eventLog = require('./event_log');
|
|
const notes = require('./notes');
|
|
|
|
async function updateNote(entity, links, sourceId) {
|
|
const origNote = await sql.getSingleResult("select * from notes where note_id = ?", [entity.note_id]);
|
|
|
|
if (!origNote || origNote.date_modified <= entity.date_modified) {
|
|
await sql.doInTransaction(async () => {
|
|
await sql.replace("notes", entity);
|
|
|
|
await sql.remove("links", entity.note_id);
|
|
|
|
for (const link of links) {
|
|
delete link['lnk_id'];
|
|
|
|
await sql.insert('link', link);
|
|
}
|
|
|
|
await sql.addNoteSync(entity.note_id, sourceId);
|
|
await notes.addNoteAudits(origNote, entity, sourceId);
|
|
await eventLog.addNoteEvent(entity.note_id, "Synced note <note>");
|
|
});
|
|
|
|
log.info("Update/sync note " + entity.note_id);
|
|
}
|
|
else {
|
|
await eventLog.addNoteEvent(entity.note_id, "Sync conflict in note <note>, " + utils.formatTwoTimestamps(origNote.date_modified, entity.date_modified));
|
|
}
|
|
}
|
|
|
|
async function updateNoteTree(entity, sourceId) {
|
|
const orig = await sql.getSingleResultOrNull("select * from notes_tree where note_id = ?", [entity.note_id]);
|
|
|
|
if (orig === null || orig.date_modified < entity.date_modified) {
|
|
await sql.doInTransaction(async () => {
|
|
delete entity.is_expanded;
|
|
|
|
await sql.replace('notes_tree', entity);
|
|
|
|
await sql.addNoteTreeSync(entity.note_id, sourceId);
|
|
|
|
await sql.addAudit(audit_category.UPDATE_TITLE, sourceId, entity.note_id);
|
|
});
|
|
|
|
log.info("Update/sync note tree " + entity.note_id);
|
|
}
|
|
else {
|
|
await eventLog.addNoteEvent(entity.note_id, "Sync conflict in note tree <note>, " + utils.formatTwoTimestamps(orig.date_modified, entity.date_modified));
|
|
}
|
|
}
|
|
|
|
async function updateNoteHistory(entity, sourceId) {
|
|
const orig = await sql.getSingleResultOrNull("select * from notes_history where note_history_id = ?", [entity.note_history_id]);
|
|
|
|
if (orig === null || orig.date_modified_to < entity.date_modified_to) {
|
|
await sql.doInTransaction(async () => {
|
|
await sql.replace('notes_history', entity);
|
|
|
|
await sql.addNoteHistorySync(entity.note_history_id, sourceId);
|
|
});
|
|
|
|
log.info("Update/sync note history " + entity.note_history_id);
|
|
}
|
|
else {
|
|
await eventLog.addNoteEvent(entity.note_id, "Sync conflict in note history for <note>, " + utils.formatTwoTimestamps(orig.date_modified_to, entity.date_modified_to));
|
|
}
|
|
}
|
|
|
|
async function updateNoteReordering(entity, sourceId) {
|
|
await sql.doInTransaction(async () => {
|
|
Object.keys(entity.ordering).forEach(async key => {
|
|
await sql.execute("UPDATE notes_tree SET note_pos = ? WHERE note_id = ?", [entity.ordering[key], key]);
|
|
});
|
|
|
|
await sql.addNoteReorderingSync(entity.note_pid, sourceId);
|
|
await sql.addAudit(audit_category.CHANGE_POSITION, sourceId, entity.note_pid);
|
|
});
|
|
}
|
|
|
|
async function updateOptions(entity, sourceId) {
|
|
if (!options.SYNCED_OPTIONS.includes(entity.opt_name)) {
|
|
return;
|
|
}
|
|
|
|
const orig = await sql.getSingleResultOrNull("select * from options where opt_name = ?", [entity.opt_name]);
|
|
|
|
if (orig === null || orig.date_modified < entity.date_modified) {
|
|
await sql.doInTransaction(async () => {
|
|
await sql.replace('options', entity);
|
|
|
|
await sql.addOptionsSync(entity.opt_name, sourceId);
|
|
});
|
|
|
|
await eventLog.addEvent("Synced option " + entity.opt_name);
|
|
}
|
|
else {
|
|
await eventLog.addEvent("Sync conflict in options for " + entity.opt_name + ", " + utils.formatTwoTimestamps(orig.date_modified, entity.date_modified));
|
|
}
|
|
}
|
|
|
|
async function updateRecentNotes(entity, sourceId) {
|
|
const orig = await sql.getSingleResultOrNull("select * from recent_notes where note_id = ?", [entity.note_id]);
|
|
|
|
if (orig === null || orig.date_accessed < entity.date_accessed) {
|
|
await sql.doInTransaction(async () => {
|
|
await sql.replace('recent_notes', entity);
|
|
|
|
await sql.addRecentNoteSync(entity.note_id, sourceId);
|
|
});
|
|
}
|
|
}
|
|
|
|
module.exports = {
|
|
updateNote,
|
|
updateNoteTree,
|
|
updateNoteHistory,
|
|
updateNoteReordering,
|
|
updateOptions,
|
|
updateRecentNotes
|
|
}; |