summaryrefslogtreecommitdiff
path: root/src/server
diff options
context:
space:
mode:
Diffstat (limited to 'src/server')
-rw-r--r--src/server/api/endpoints/admin/emoji/add.ts6
-rw-r--r--src/server/api/endpoints/admin/emoji/update.ts6
-rw-r--r--src/server/proxy/proxy-media.ts85
3 files changed, 15 insertions, 82 deletions
diff --git a/src/server/api/endpoints/admin/emoji/add.ts b/src/server/api/endpoints/admin/emoji/add.ts
index 99439f89a6..c126c8380f 100644
--- a/src/server/api/endpoints/admin/emoji/add.ts
+++ b/src/server/api/endpoints/admin/emoji/add.ts
@@ -1,6 +1,7 @@
import $ from 'cafy';
import Emoji from '../../../../../models/emoji';
import define from '../../../define';
+import { detectUrlMine } from '../../../../../misc/detect-url-mine';
export const meta = {
desc: {
@@ -29,12 +30,15 @@ export const meta = {
};
export default define(meta, async (ps) => {
+ const type = await detectUrlMine(ps.url);
+
const emoji = await Emoji.insert({
updatedAt: new Date(),
name: ps.name,
host: null,
aliases: ps.aliases,
- url: ps.url
+ url: ps.url,
+ type,
});
return {
diff --git a/src/server/api/endpoints/admin/emoji/update.ts b/src/server/api/endpoints/admin/emoji/update.ts
index 38d90c65a3..8b1c07be9e 100644
--- a/src/server/api/endpoints/admin/emoji/update.ts
+++ b/src/server/api/endpoints/admin/emoji/update.ts
@@ -2,6 +2,7 @@ import $ from 'cafy';
import Emoji from '../../../../../models/emoji';
import define from '../../../define';
import ID from '../../../../../misc/cafy-id';
+import { detectUrlMine } from '../../../../../misc/detect-url-mine';
export const meta = {
desc: {
@@ -39,12 +40,15 @@ export default define(meta, async (ps) => {
if (emoji == null) throw new Error('emoji not found');
+ const type = await detectUrlMine(ps.url);
+
await Emoji.update({ _id: emoji._id }, {
$set: {
updatedAt: new Date(),
name: ps.name,
aliases: ps.aliases,
- url: ps.url
+ url: ps.url,
+ type,
}
});
diff --git a/src/server/proxy/proxy-media.ts b/src/server/proxy/proxy-media.ts
index 2eec2012f3..357715bb92 100644
--- a/src/server/proxy/proxy-media.ts
+++ b/src/server/proxy/proxy-media.ts
@@ -1,27 +1,19 @@
import * as fs from 'fs';
-import * as URL from 'url';
-import * as tmp from 'tmp';
import * as Koa from 'koa';
-import * as request from 'request';
-import fileType from 'file-type';
import { serverLogger } from '..';
-import config from '../../config';
import { IImage, ConvertToPng, ConvertToJpeg } from '../../services/drive/image-processor';
-import checkSvg from '../../misc/check-svg';
+import { createTemp } from '../../misc/create-temp';
+import { downloadUrl } from '../../misc/donwload-url';
+import { detectMine } from '../../misc/detect-mine';
export async function proxyMedia(ctx: Koa.BaseContext) {
const url = 'url' in ctx.query ? ctx.query.url : 'https://' + ctx.params.url;
// Create temp file
- const [path, cleanup] = await new Promise<[string, any]>((res, rej) => {
- tmp.file((e, path, fd, cleanup) => {
- if (e) return rej(e);
- res([path, cleanup]);
- });
- });
+ const [path, cleanup] = await createTemp();
try {
- await fetch(url, path);
+ await downloadUrl(url, path);
const [type, ext] = await detectMine(path);
@@ -54,70 +46,3 @@ export async function proxyMedia(ctx: Koa.BaseContext) {
cleanup();
}
}
-
-async function fetch(url: string, path: string) {
- await new Promise((res, rej) => {
- const writable = fs.createWriteStream(path);
-
- writable.on('finish', () => {
- res();
- });
-
- writable.on('error', error => {
- rej(error);
- });
-
- const requestUrl = URL.parse(url).pathname.match(/[^\u0021-\u00ff]/) ? encodeURI(url) : url;
-
- const req = request({
- url: requestUrl,
- proxy: config.proxy,
- timeout: 10 * 1000,
- headers: {
- 'User-Agent': config.userAgent
- }
- });
-
- req.pipe(writable);
-
- req.on('response', response => {
- if (response.statusCode !== 200) {
- writable.close();
- rej(response.statusCode);
- }
- });
-
- req.on('error', error => {
- writable.close();
- rej(error);
- });
- });
-}
-
-async function detectMine(path: string) {
- return new Promise<[string, string]>((res, rej) => {
- const readable = fs.createReadStream(path);
- readable
- .on('error', rej)
- .once('data', (buffer: Buffer) => {
- readable.destroy();
- const type = fileType(buffer);
- if (type) {
- if (type.mime == 'application/xml' && checkSvg(path)) {
- res(['image/svg+xml', 'svg']);
- } else {
- res([type.mime, type.ext]);
- }
- } else if (checkSvg(path)) {
- res(['image/svg+xml', 'svg']);
- } else {
- // 種類が同定できなかったら application/octet-stream にする
- res(['application/octet-stream', null]);
- }
- })
- .on('end', () => {
- // maybe 0 bytes
- res(['application/octet-stream', null]);
- });
- });
-}