summaryrefslogtreecommitdiff
path: root/src/server/file
diff options
context:
space:
mode:
authortamaina <tamaina@hotmail.co.jp>2018-04-11 23:14:08 +0900
committerGitHub <noreply@github.com>2018-04-11 23:14:08 +0900
commit703376841a993cd7dd0bbec3c017040f500811d6 (patch)
treecfc6a6231c07e9d3bace3795d896b2bb74d8be30 /src/server/file
parentFix bug (diff)
downloadmisskey-703376841a993cd7dd0bbec3c017040f500811d6.tar.gz
misskey-703376841a993cd7dd0bbec3c017040f500811d6.tar.bz2
misskey-703376841a993cd7dd0bbec3c017040f500811d6.zip
可能な限り動画や画像のサムネイルを提供する
Diffstat (limited to 'src/server/file')
-rw-r--r--src/server/file/index.ts27
1 files changed, 13 insertions, 14 deletions
diff --git a/src/server/file/index.ts b/src/server/file/index.ts
index 8d21b0ba46..3e8eed2c38 100644
--- a/src/server/file/index.ts
+++ b/src/server/file/index.ts
@@ -54,23 +54,22 @@ interface ISend {
function thumbnail(data: stream.Readable, type: string, resize: number): ISend {
const readable: stream.Readable = (() => {
- // 画像ではない場合
- if (!/^image\/.*$/.test(type)) {
- // 使わないことにしたストリームはしっかり取り壊しておく
+ // 動画か画像であれば
+ if (/^(?:video|image)\/.*$/.test(type)) {
+ // 0フレーム目を送る
+ try {
+ return gm(data).selectFrame(0).stream();
+ // だめだったら
+ } catch (e) {
+ // 使わないことになったストリームはしっかり取り壊す
+ data.destroy();
+ return fs.createReadStream(`${__dirname}/assets/thumbnail-not-available.png`);
+ }
+ // 動画か画像以外
+ } else {
data.destroy();
return fs.createReadStream(`${__dirname}/assets/not-an-image.png`);
}
-
- const imageType = type.split('/')[1];
-
- // 画像でもPNGかJPEGでないならダメ
- if (imageType != 'png' && imageType != 'jpeg') {
- // 使わないことにしたストリームはしっかり取り壊しておく
- data.destroy();
- return fs.createReadStream(`${__dirname}/assets/thumbnail-not-available.png`);
- }
-
- return data;
})();
let g = gm(readable);