From 703376841a993cd7dd0bbec3c017040f500811d6 Mon Sep 17 00:00:00 2001 From: tamaina Date: Wed, 11 Apr 2018 23:14:08 +0900 Subject: 可能な限り動画や画像のサムネイルを提供する MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/server/file/index.ts | 27 +++++++++++++-------------- 1 file changed, 13 insertions(+), 14 deletions(-) (limited to 'src/server') 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); -- cgit v1.2.3-freya From 760b90a84b55a1a3a8467684fbaa28f4f2832d69 Mon Sep 17 00:00:00 2001 From: tamaina Date: Wed, 11 Apr 2018 23:50:11 +0900 Subject: 🖌 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/server/file/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'src/server') diff --git a/src/server/file/index.ts b/src/server/file/index.ts index 3e8eed2c38..22370ddd0d 100644 --- a/src/server/file/index.ts +++ b/src/server/file/index.ts @@ -55,7 +55,7 @@ interface ISend { function thumbnail(data: stream.Readable, type: string, resize: number): ISend { const readable: stream.Readable = (() => { // 動画か画像であれば - if (/^(?:video|image)\/.*$/.test(type)) { + if (/^(?:video|image)\/.*$/.test(type) || type == 'application/xml') { // 0フレーム目を送る try { return gm(data).selectFrame(0).stream(); -- cgit v1.2.3-freya From 5172ef247bf5dbd9ef163241cedb565a47a85f4a Mon Sep 17 00:00:00 2001 From: tamaina Date: Thu, 12 Apr 2018 02:34:51 +0900 Subject: 動画はimagemagickで変換できない MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/server/file/index.ts | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'src/server') diff --git a/src/server/file/index.ts b/src/server/file/index.ts index 22370ddd0d..658117e3ac 100644 --- a/src/server/file/index.ts +++ b/src/server/file/index.ts @@ -54,8 +54,14 @@ interface ISend { function thumbnail(data: stream.Readable, type: string, resize: number): ISend { const readable: stream.Readable = (() => { - // 動画か画像であれば - if (/^(?:video|image)\/.*$/.test(type) || type == 'application/xml') { + // 動画であれば + if (/^video\/.*$/.test(type)) { + // 実装は先延ばし + // 使わないことになったストリームはしっかり取り壊す + data.destroy(); + return fs.createReadStream(`${__dirname}/assets/thumbnail-not-available.png`); + // 画像であれば + } else if (/^image\/.*$/.test(type) || type == 'application/xml') { // 0フレーム目を送る try { return gm(data).selectFrame(0).stream(); -- cgit v1.2.3-freya