trilium/src/routes/api/image.js

49 lines
1.3 KiB
JavaScript
Raw Normal View History

"use strict";
const sql = require('../../services/sql');
2018-02-11 13:18:59 +08:00
const image = require('../../services/image');
2018-01-08 03:07:59 +08:00
const RESOURCE_DIR = require('../../services/resource_dir').RESOURCE_DIR;
const fs = require('fs');
async function returnImage(req, res) {
const image = await sql.getRow("SELECT * FROM images WHERE imageId = ?", [req.params.imageId]);
if (!image) {
return res.sendStatus(404);
}
2018-01-08 03:07:59 +08:00
else if (image.data === null) {
res.set('Content-Type', 'image/png');
return res.send(fs.readFileSync(RESOURCE_DIR + '/db/image-deleted.png'));
}
res.set('Content-Type', 'image/' + image.format);
res.send(image.data);
}
async function uploadImage(req) {
2018-01-07 10:49:02 +08:00
const noteId = req.query.noteId;
const file = req.file;
const note = await sql.getRow("SELECT * FROM notes WHERE noteId = ?", [noteId]);
2018-01-07 10:49:02 +08:00
if (!note) {
return [404, `Note ${noteId} doesn't exist.`];
2018-01-07 10:49:02 +08:00
}
2018-01-07 22:22:55 +08:00
if (!["image/png", "image/jpeg", "image/gif"].includes(file.mimetype)) {
return [400, "Unknown image type: " + file.mimetype];
}
const {fileName, imageId} = await image.saveImage(file, noteId);
return {
uploaded: true,
url: `/api/images/${imageId}/${fileName}`
};
}
module.exports = {
returnImage,
uploadImage
};