const scriptService = require('./script'); const cls = require('./cls'); const sqlInit = require('./sql_init'); const config = require('./config'); const log = require('./log'); const sql = require("./sql"); const becca = require("../becca/becca"); const protectedSessionService = require("../services/protected_session"); const hiddenSubtreeService = require("./hidden_subtree"); function getRunAtHours(note) { try { return note.getLabelValues('runAtHour').map(hour => parseInt(hour)); } catch (e) { log.error(`Could not parse runAtHour for note ${note.noteId}: ${e.message}`); return []; } } function runNotesWithLabel(runAttrValue) { // TODO: should be refactored into becca search const noteIds = sql.getColumn(` SELECT notes.noteId FROM notes JOIN attributes ON attributes.noteId = notes.noteId AND attributes.isDeleted = 0 AND attributes.type = 'label' AND attributes.name = 'run' AND attributes.value = ? WHERE notes.type = 'code' AND notes.isDeleted = 0`, [runAttrValue]); const notes = becca.getNotes(noteIds); const instanceName = config.General ? config.General.instanceName : null; const currentHours = new Date().getHours(); for (const note of notes) { const runOnInstances = note.getLabelValues('runOnInstance'); const runAtHours = getRunAtHours(note); if ((runOnInstances.length === 0 || runOnInstances.includes(instanceName)) && (runAtHours.length === 0 || runAtHours.includes(currentHours)) ) { scriptService.executeNoteNoException(note, {originEntity: note}); } } } sqlInit.dbReady.then(() => { cls.init(() => hiddenSubtreeService.checkHiddenSubtree()); if (!process.env.TRILIUM_SAFE_MODE) { setTimeout(cls.wrap(() => runNotesWithLabel('backendStartup')), 10 * 1000); setInterval(cls.wrap(() => runNotesWithLabel('hourly')), 3600 * 1000); setInterval(cls.wrap(() => runNotesWithLabel('daily')), 24 * 3600 * 1000); } setInterval(() => protectedSessionService.checkProtectedSessionExpiration(), 30000); });