trilium/src/routes/api/image.js

52 lines
1.6 KiB
JavaScript
Raw Normal View History

"use strict";
const express = require('express');
const router = express.Router();
const sql = require('../../services/sql');
const auth = require('../../services/auth');
2018-02-11 13:18:59 +08:00
const image = require('../../services/image');
const multer = require('multer')();
const wrap = require('express-promise-wrap').wrap;
2018-01-08 03:07:59 +08:00
const RESOURCE_DIR = require('../../services/resource_dir').RESOURCE_DIR;
const fs = require('fs');
2018-01-07 22:59:05 +08:00
router.get('/:imageId/:filename', auth.checkApiAuthOrElectron, wrap(async (req, res, next) => {
const image = await sql.getRow("SELECT * FROM images WHERE imageId = ?", [req.params.imageId]);
if (!image) {
return res.status(404).send({});
}
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);
}));
2018-01-07 22:59:05 +08:00
router.post('', auth.checkApiAuthOrElectron, multer.single('upload'), wrap(async (req, res, next) => {
2018-01-29 10:57:46 +08:00
const sourceId = req.headers.source_id;
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) {
2018-01-07 22:22:55 +08:00
return res.status(404).send(`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 res.status(400).send("Unknown image type: " + file.mimetype);
}
2018-02-11 13:18:59 +08:00
const {fileName, imageId} = await image.saveImage(file, sourceId, noteId);
res.send({
uploaded: true,
url: `/api/images/${imageId}/${fileName}`
});
}));
module.exports = router;