summaryrefslogtreecommitdiff
path: root/src/api/endpoints
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2017-11-14 05:27:08 +0900
committerGitHub <noreply@github.com>2017-11-14 05:27:08 +0900
commitc48f3e16ec0ec83300440d75ef074dcda63f32ed (patch)
tree368f281f97c84ba2a1b7d99ab80f7312912b461f /src/api/endpoints
parentRevert "Update README.md" (diff)
parentformat (diff)
downloadmisskey-c48f3e16ec0ec83300440d75ef074dcda63f32ed.tar.gz
misskey-c48f3e16ec0ec83300440d75ef074dcda63f32ed.tar.bz2
misskey-c48f3e16ec0ec83300440d75ef074dcda63f32ed.zip
Merge pull request #913 from syuilo/write-file-use-stream
ファイル書き込みをバッファを使用しない形にする
Diffstat (limited to 'src/api/endpoints')
-rw-r--r--src/api/endpoints/drive/files/create.ts22
-rw-r--r--src/api/endpoints/drive/files/upload_from_url.ts49
2 files changed, 43 insertions, 28 deletions
diff --git a/src/api/endpoints/drive/files/create.ts b/src/api/endpoints/drive/files/create.ts
index 7967c31187..7546eca309 100644
--- a/src/api/endpoints/drive/files/create.ts
+++ b/src/api/endpoints/drive/files/create.ts
@@ -1,7 +1,6 @@
/**
* Module dependencies
*/
-import * as fs from 'fs';
import $ from 'cafy';
import { validateFileName } from '../../../models/drive-file';
import serialize from '../../../serializers/drive-file';
@@ -15,15 +14,11 @@ import create from '../../../common/add-file-to-drive';
* @param {any} user
* @return {Promise<any>}
*/
-module.exports = (file, params, user) => new Promise(async (res, rej) => {
+module.exports = async (file, params, user): Promise<any> => {
if (file == null) {
- return rej('file is required');
+ throw 'file is required';
}
- // TODO: 非同期にしたい。Promise対応してないんだろうか...
- const buffer = fs.readFileSync(file.path);
- fs.unlink(file.path, (err) => { if (err) console.log(err); });
-
// Get 'name' parameter
let name = file.originalname;
if (name !== undefined && name !== null) {
@@ -33,7 +28,7 @@ module.exports = (file, params, user) => new Promise(async (res, rej) => {
} else if (name === 'blob') {
name = null;
} else if (!validateFileName(name)) {
- return rej('invalid name');
+ throw 'invalid name';
}
} else {
name = null;
@@ -41,14 +36,11 @@ module.exports = (file, params, user) => new Promise(async (res, rej) => {
// Get 'folder_id' parameter
const [folderId = null, folderIdErr] = $(params.folder_id).optional.nullable.id().$;
- if (folderIdErr) return rej('invalid folder_id param');
+ if (folderIdErr) throw 'invalid folder_id param';
// Create file
- const driveFile = await create(user, buffer, name, null, folderId);
+ const driveFile = await create(user, file.path, name, null, folderId);
// Serialize
- const fileObj = await serialize(driveFile);
-
- // Response
- res(fileObj);
-});
+ return serialize(driveFile);
+};
diff --git a/src/api/endpoints/drive/files/upload_from_url.ts b/src/api/endpoints/drive/files/upload_from_url.ts
index 46cfffb69c..519e0bdf65 100644
--- a/src/api/endpoints/drive/files/upload_from_url.ts
+++ b/src/api/endpoints/drive/files/upload_from_url.ts
@@ -2,11 +2,16 @@
* Module dependencies
*/
import * as URL from 'url';
-const download = require('download');
import $ from 'cafy';
import { validateFileName } from '../../../models/drive-file';
import serialize from '../../../serializers/drive-file';
import create from '../../../common/add-file-to-drive';
+import * as debug from 'debug';
+import * as tmp from 'tmp';
+import * as fs from 'fs';
+import * as request from 'request';
+
+const log = debug('misskey:endpoint:upload_from_url');
/**
* Create a file from a URL
@@ -15,11 +20,11 @@ import create from '../../../common/add-file-to-drive';
* @param {any} user
* @return {Promise<any>}
*/
-module.exports = (params, user) => new Promise(async (res, rej) => {
+module.exports = async (params, user): Promise<any> => {
// Get 'url' parameter
// TODO: Validate this url
const [url, urlErr] = $(params.url).string().$;
- if (urlErr) return rej('invalid url param');
+ if (urlErr) throw 'invalid url param';
let name = URL.parse(url).pathname.split('/').pop();
if (!validateFileName(name)) {
@@ -28,17 +33,35 @@ module.exports = (params, user) => new Promise(async (res, rej) => {
// Get 'folder_id' parameter
const [folderId = null, folderIdErr] = $(params.folder_id).optional.nullable.id().$;
- if (folderIdErr) return rej('invalid folder_id param');
+ if (folderIdErr) throw 'invalid folder_id param';
+
+ // Create temp file
+ const path = await new Promise((res: (string) => void, rej) => {
+ tmp.file((e, path) => {
+ if (e) return rej(e);
+ res(path);
+ });
+ });
- // Download file
- const data = await download(url);
+ // write content at URL to temp file
+ await new Promise((res, rej) => {
+ const writable = fs.createWriteStream(path);
+ request(url)
+ .on('error', rej)
+ .on('end', () => {
+ writable.close();
+ res(path);
+ })
+ .pipe(writable)
+ .on('error', rej);
+ });
- // Create file
- const driveFile = await create(user, data, name, null, folderId);
+ const driveFile = await create(user, path, name, null, folderId);
- // Serialize
- const fileObj = await serialize(driveFile);
+ // clean-up
+ fs.unlink(path, (e) => {
+ if (e) log(e.stack);
+ });
- // Response
- res(fileObj);
-});
+ return serialize(driveFile);
+};