Notes/routes/api/sync.js

104 lines
3.3 KiB
JavaScript
Raw Normal View History

2017-10-24 22:58:59 -04:00
"use strict";
const express = require('express');
const router = express.Router();
const auth = require('../../services/auth');
2017-10-26 21:16:21 -04:00
const sync = require('../../services/sync');
2017-10-31 19:34:58 -04:00
const sql = require('../../services/sql');
2017-11-02 20:48:02 -04:00
const options = require('../../services/options');
2017-10-24 22:58:59 -04:00
2017-10-29 11:22:41 -04:00
router.post('/now', auth.checkApiAuth, async (req, res, next) => {
res.send(await sync.sync());
2017-10-29 11:22:41 -04:00
});
2017-10-31 19:34:58 -04:00
router.get('/changed', auth.checkApiAuth, async (req, res, next) => {
const lastSyncId = parseInt(req.query.lastSyncId);
2017-10-31 20:09:07 -04:00
const sourceId = req.query.sourceId;
2017-10-24 22:58:59 -04:00
2017-11-01 00:47:39 -04:00
res.send(await sql.getResults("SELECT * FROM sync WHERE id > ? AND source_id != ?", [lastSyncId, sourceId]));
2017-10-26 21:16:21 -04:00
});
2017-10-31 19:34:58 -04:00
router.get('/notes/:noteId', auth.checkApiAuth, async (req, res, next) => {
const noteId = req.params.noteId;
2017-10-26 21:16:21 -04:00
2017-10-31 19:34:58 -04:00
res.send({
entity: await sql.getSingleResult("SELECT * FROM notes WHERE note_id = ?", [noteId]),
links: await sql.getResults("SELECT * FROM links WHERE note_id = ?", [noteId])
});
2017-10-25 22:39:21 -04:00
});
2017-10-31 19:34:58 -04:00
router.get('/notes_tree/:noteId', auth.checkApiAuth, async (req, res, next) => {
2017-10-25 22:39:21 -04:00
const noteId = req.params.noteId;
2017-10-31 19:34:58 -04:00
res.send(await sql.getSingleResult("SELECT * FROM notes_tree WHERE note_id = ?", [noteId]));
});
router.get('/notes_history/:noteHistoryId', auth.checkApiAuth, async (req, res, next) => {
const noteHistoryId = req.params.noteHistoryId;
res.send(await sql.getSingleResult("SELECT * FROM notes_history WHERE note_history_id = ?", [noteHistoryId]));
2017-10-26 21:16:21 -04:00
});
2017-11-02 20:48:02 -04:00
router.get('/options/:optName', auth.checkApiAuth, async (req, res, next) => {
const optName = req.params.optName;
if (!options.SYNCED_OPTIONS.includes(optName)) {
res.send("This option can't be synced.");
}
else {
res.send(await sql.getSingleResult("SELECT * FROM options WHERE opt_name = ?", [optName]));
}
});
2017-11-02 22:55:22 -04:00
router.get('/notes_reordering/:noteParentId', auth.checkApiAuth, async (req, res, next) => {
const noteParentId = req.params.noteParentId;
res.send({
note_pid: noteParentId,
ordering: await sql.getMap("SELECT note_id, note_pos FROM notes_tree WHERE note_pid = ?", [noteParentId])
});
});
2017-11-05 00:16:02 -04:00
router.get('/recent_notes/:noteId', auth.checkApiAuth, async (req, res, next) => {
const noteId = req.params.noteId;
res.send(await sql.getSingleResult("SELECT * FROM recent_notes WHERE note_id = ?", [noteId]));
});
2017-10-29 22:22:30 -04:00
router.put('/notes', auth.checkApiAuth, async (req, res, next) => {
2017-10-31 20:44:32 -04:00
await sync.updateNote(req.body.entity, req.body.links, req.body.sourceId);
2017-10-29 22:22:30 -04:00
res.send({});
});
router.put('/notes_tree', auth.checkApiAuth, async (req, res, next) => {
2017-10-31 20:44:32 -04:00
await sync.updateNoteTree(req.body.entity, req.body.sourceId);
2017-10-29 22:22:30 -04:00
res.send({});
});
router.put('/notes_history', auth.checkApiAuth, async (req, res, next) => {
2017-10-31 20:44:32 -04:00
await sync.updateNoteHistory(req.body.entity, req.body.sourceId);
2017-10-25 22:39:21 -04:00
2017-10-26 21:16:21 -04:00
res.send({});
2017-10-24 22:58:59 -04:00
});
2017-11-02 22:55:22 -04:00
router.put('/notes_reordering', auth.checkApiAuth, async (req, res, next) => {
await sync.updateNoteReordering(req.body.entity, req.body.sourceId);
res.send({});
});
2017-11-02 20:48:02 -04:00
router.put('/options', auth.checkApiAuth, async (req, res, next) => {
await sync.updateOptions(req.body.entity, req.body.sourceId);
res.send({});
});
2017-11-05 00:16:02 -04:00
router.put('/recent_notes', auth.checkApiAuth, async (req, res, next) => {
await sync.updateRecentNotes(req.body.entity, req.body.sourceId);
res.send({});
});
2017-10-24 22:58:59 -04:00
module.exports = router;