| 
									
										
										
										
											2017-11-15 22:13:45 -05:00
										 |  |  | const sql = require('../services/sql'); | 
					
						
							|  |  |  | const data_encryption = require('../services/data_encryption'); | 
					
						
							|  |  |  | const password_encryption = require('../services/password_encryption'); | 
					
						
							|  |  |  | const readline = require('readline'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const cl = readline.createInterface(process.stdin, process.stdout); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function question(q) { | 
					
						
							|  |  |  |     return new Promise( (res, rej) => { | 
					
						
							|  |  |  |         cl.question( q, answer => { | 
					
						
							|  |  |  |             res(answer); | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = async () => { | 
					
						
							|  |  |  |     const password = await question("Enter password: "); | 
					
						
							|  |  |  |     const dataKey = await password_encryption.getDecryptedDataKey(password); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-23 11:02:38 -05:00
										 |  |  |     const protectedNotes = await sql.getAll("SELECT * FROM notes WHERE is_protected = 1"); | 
					
						
							| 
									
										
										
										
											2017-11-15 22:13:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (const note of protectedNotes) { | 
					
						
							|  |  |  |         const decryptedTitle = data_encryption.decrypt(dataKey, note.note_title); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-18 12:53:17 -05:00
										 |  |  |         note.note_title = data_encryption.encrypt(dataKey, "0" + note.note_id, decryptedTitle); | 
					
						
							| 
									
										
										
										
											2017-11-15 22:13:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         const decryptedText = data_encryption.decrypt(dataKey, note.note_text); | 
					
						
							| 
									
										
										
										
											2017-11-18 12:53:17 -05:00
										 |  |  |         note.note_text = data_encryption.encrypt(dataKey, "1" + note.note_id, decryptedText); | 
					
						
							| 
									
										
										
										
											2017-11-15 22:13:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         await sql.execute("UPDATE notes SET note_title = ?, note_text = ? WHERE note_id = ?", [note.note_title, note.note_text, note.note_id]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-23 11:02:38 -05:00
										 |  |  |     const protectedNotesHistory = await sql.getAll("SELECT * FROM notes_history WHERE is_protected = 1"); | 
					
						
							| 
									
										
										
										
											2017-11-15 22:13:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (const noteHistory of protectedNotesHistory) { | 
					
						
							|  |  |  |         const decryptedTitle = data_encryption.decrypt(dataKey, noteHistory.note_title); | 
					
						
							| 
									
										
										
										
											2017-11-18 12:53:17 -05:00
										 |  |  |         noteHistory.note_title = data_encryption.encrypt(dataKey, "0" + noteHistory.note_history_id, decryptedTitle); | 
					
						
							| 
									
										
										
										
											2017-11-15 22:13:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         const decryptedText = data_encryption.decrypt(dataKey, noteHistory.note_text); | 
					
						
							| 
									
										
										
										
											2017-11-18 12:53:17 -05:00
										 |  |  |         noteHistory.note_text = data_encryption.encrypt(dataKey, "1" + noteHistory.note_history_id, decryptedText); | 
					
						
							| 
									
										
										
										
											2017-11-15 22:13:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         await sql.execute("UPDATE notes SET note_title = ?, note_text = ? WHERE note_id = ?", [noteHistory.note_title, noteHistory.note_text, noteHistory.note_history_id]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; |