You've already forked joplin
							
							
				mirror of
				https://github.com/laurent22/joplin.git
				synced 2025-10-31 00:07:48 +02:00 
			
		
		
		
	API: Allow setting the ID of newly created notes.
This commit is contained in:
		| @@ -253,6 +253,12 @@ class Command extends BaseCommand { | ||||
| 				lines.push(''); | ||||
| 				lines.push('      curl --data \'{ "title": "Image test", "body": "Here is Joplin icon:", "image_data_url": ""}\' http://127.0.0.1:41184/notes'); | ||||
| 				lines.push(''); | ||||
| 				lines.push('### Creating a note with a specific ID'); | ||||
| 				lines.push(''); | ||||
| 				lines.push('When a new note is created, it is automatically assigned a new unique ID so **normally you do not need to set the ID**. However, if for some reason you want to set it, you can supply it as the `id` property. It needs to be a 32 characters long hexadecimal string. **Make sure it is unique**, for example by generating it using whatever GUID function is available in your programming language.'); | ||||
| 				lines.push(''); | ||||
| 				lines.push('      curl --data \'{ "id": "00a87474082744c1a8515da6aa5792d2", "title": "My note with custom ID"}\' http://127.0.0.1:41184/notes'); | ||||
| 				lines.push(''); | ||||
| 			} | ||||
|  | ||||
| 			lines.push('## PUT /' + tableName + '/:id'); | ||||
|   | ||||
| @@ -156,6 +156,20 @@ describe('services_rest_Api', function() { | ||||
| 		done(); | ||||
| 	}); | ||||
|  | ||||
| 	it('should create notes with supplied ID', async (done) => { | ||||
| 		let response = null; | ||||
| 		const f = await Folder.save({ title: "mon carnet" }); | ||||
| 		 | ||||
| 		response = await api.route('POST', 'notes', null, JSON.stringify({ | ||||
| 			id: '12345678123456781234567812345678', | ||||
| 			title: 'testing', | ||||
| 			parent_id: f.id, | ||||
| 		})); | ||||
| 		expect(response.id).toBe('12345678123456781234567812345678'); | ||||
|  | ||||
| 		done(); | ||||
| 	}); | ||||
|  | ||||
| 	it('should create notes with images', async (done) => { | ||||
| 		let response = null; | ||||
| 		const f = await Folder.save({ title: "mon carnet" }); | ||||
|   | ||||
| @@ -339,7 +339,9 @@ class Api { | ||||
|  | ||||
| 			this.logger().info('Request (' + requestId + '): Saving note...'); | ||||
|  | ||||
| 			note = await Note.save(note); | ||||
| 			const saveOptions = {}; | ||||
| 			if (note.id) saveOptions.isNew = true; | ||||
| 			note = await Note.save(note, saveOptions); | ||||
|  | ||||
| 			if (requestNote.tags) { | ||||
| 				const tagTitles = requestNote.tags.split(','); | ||||
| @@ -378,6 +380,8 @@ class Api { | ||||
| 			body: requestNote.body ? requestNote.body : '', | ||||
| 		}; | ||||
|  | ||||
| 		if (requestNote.id) output.id = requestNote.id; | ||||
|  | ||||
| 		if (requestNote.body_html) { | ||||
| 			// Parsing will not work if the HTML is not wrapped in a top level tag, which is not guaranteed | ||||
| 			// when getting the content from elsewhere. So here wrap it - it won't change anything to the final | ||||
|   | ||||
		Reference in New Issue
	
	Block a user