| 
									
										
										
										
											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) => { | 
					
						
							| 
									
										
										
										
											2017-11-03 22:08:27 -04:00
										 |  |  |     await sync.sync(); | 
					
						
							| 
									
										
										
										
											2017-10-29 11:22:41 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     res.send({ | 
					
						
							| 
									
										
										
										
											2017-11-03 22:08:27 -04:00
										 |  |  |         success: true | 
					
						
							| 
									
										
										
										
											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-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-10-24 22:58:59 -04:00
										 |  |  | module.exports = router; |