mirror of
				https://github.com/zadam/trilium.git
				synced 2025-11-04 05:28:59 +01:00 
			
		
		
		
	save image
This commit is contained in:
		
							parent
							
								
									6feb7ad1d5
								
							
						
					
					
						commit
						ec87856ef4
					
				@ -55,24 +55,41 @@ async function createNote(req) {
 | 
				
			|||||||
    return {};
 | 
					    return {};
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
async function createScreenshot(req) {
 | 
					async function createImage(req) {
 | 
				
			||||||
    console.log(req.body);
 | 
					    let {dataUrl, title, sourceUrl, pageUrl} = req.body;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    const {imageDataUrl, title, url} = req.body;
 | 
					    if (!dataUrl) {
 | 
				
			||||||
 | 
					        dataUrl = sourceUrl;
 | 
				
			||||||
 | 
					        sourceUrl = null;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    const prefix = "data:image/png;base64,";
 | 
					    if (!dataUrl.startsWith("data:image/")) {
 | 
				
			||||||
 | 
					        const message = "Unrecognized prefix: " + dataUrl.substr(0, Math.min(dataUrl.length, 100));
 | 
				
			||||||
 | 
					        log.info(message);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (imageDataUrl.startsWith(prefix)) {
 | 
					        return [400, message];
 | 
				
			||||||
        const buffer = Buffer.from(imageDataUrl.substr(prefix.length), 'base64');
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!title && sourceUrl) {
 | 
				
			||||||
 | 
					        title = path.basename(sourceUrl);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!title) {
 | 
				
			||||||
 | 
					        title = "clipped image";
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    const buffer = Buffer.from(dataUrl.split(",")[1], 'base64');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    const todayNote = await dateNoteService.getDateNote(dateUtils.localNowDate());
 | 
					    const todayNote = await dateNoteService.getDateNote(dateUtils.localNowDate());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        const {note} = await imageService.saveImage(buffer, title + ".png", todayNote.noteId, true);
 | 
					    const {note} = await imageService.saveImage(buffer, title, todayNote.noteId, true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        await note.setLabel('sourceUrl', url);
 | 
					    if (sourceUrl) {
 | 
				
			||||||
 | 
					        await note.setLabel('sourceUrl', sourceUrl);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    else {
 | 
					
 | 
				
			||||||
        console.log("Unrecognized prefix");
 | 
					    if (pageUrl) {
 | 
				
			||||||
 | 
					        await note.setLabel('pageUrl', pageUrl);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return {};
 | 
					    return {};
 | 
				
			||||||
@ -86,6 +103,6 @@ async function ping(req, res) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
module.exports = {
 | 
					module.exports = {
 | 
				
			||||||
    createNote,
 | 
					    createNote,
 | 
				
			||||||
    createScreenshot,
 | 
					    createImage,
 | 
				
			||||||
    ping
 | 
					    ping
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
@ -225,7 +225,7 @@ function register(app) {
 | 
				
			|||||||
    apiRoute(POST, '/api/login/protected', loginApiRoute.loginToProtectedSession);
 | 
					    apiRoute(POST, '/api/login/protected', loginApiRoute.loginToProtectedSession);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    route(POST, '/api/clipper/notes', [], clipperRoute.createNote, apiResultHandler);
 | 
					    route(POST, '/api/clipper/notes', [], clipperRoute.createNote, apiResultHandler);
 | 
				
			||||||
    route(POST, '/api/clipper/screenshot', [], clipperRoute.createScreenshot, apiResultHandler);
 | 
					    route(POST, '/api/clipper/image', [], clipperRoute.createImage, apiResultHandler);
 | 
				
			||||||
    route(GET, '/api/clipper/ping', [], clipperRoute.ping);
 | 
					    route(GET, '/api/clipper/ping', [], clipperRoute.ping);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    app.use('', router);
 | 
					    app.use('', router);
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user