mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-31 10:26:08 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			127 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			4.6 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');
 | |
| const sync_table = require('./sync_table');
 | |
| 
 | |
| 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 sync_table.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_tree_id = ?", [entity.note_tree_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 sync_table.addNoteTreeSync(entity.note_tree_id, sourceId);
 | |
| 
 | |
|             // not sure why this is here ...
 | |
|             await sql.addAudit(audit_category.UPDATE_TITLE, sourceId, entity.note_id);
 | |
|         });
 | |
| 
 | |
|         log.info("Update/sync note tree " + entity.note_tree_id);
 | |
|     }
 | |
|     else {
 | |
|         await eventLog.addNoteEvent(entity.note_tree_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 sync_table.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_tree_id = ?", [entity.ordering[key], key]);
 | |
|         });
 | |
| 
 | |
|         await sync_table.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 sync_table.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_path = ?", [entity.note_path]);
 | |
| 
 | |
|     if (orig === null || orig.date_accessed < entity.date_accessed) {
 | |
|         await sql.doInTransaction(async () => {
 | |
|             await sql.replace('recent_notes', entity);
 | |
| 
 | |
|             await sync_table.addRecentNoteSync(entity.note_id, sourceId);
 | |
|         });
 | |
|     }
 | |
| }
 | |
| 
 | |
| module.exports = {
 | |
|     updateNote,
 | |
|     updateNoteTree,
 | |
|     updateNoteHistory,
 | |
|     updateNoteReordering,
 | |
|     updateOptions,
 | |
|     updateRecentNotes
 | |
| }; |