2018-05-25 03:41:49 -06:00
|
|
|
import * as fs from 'fs';
|
2018-07-15 12:43:36 -06:00
|
|
|
const ms = require('ms');
|
2018-11-01 12:32:24 -06:00
|
|
|
import $ from 'cafy'; import ID, { transform } from '../../../../../misc/cafy-id';
|
2018-03-29 05:32:18 -06:00
|
|
|
import { validateFileName, pack } from '../../../../../models/drive-file';
|
2018-04-07 13:02:12 -06:00
|
|
|
import create from '../../../../../services/drive/add-file';
|
2018-06-17 18:54:53 -06:00
|
|
|
import { ILocalUser } from '../../../../../models/user';
|
2018-07-15 12:43:36 -06:00
|
|
|
import getParams from '../../../get-params';
|
|
|
|
|
|
|
|
export const meta = {
|
|
|
|
desc: {
|
2018-08-28 15:59:43 -06:00
|
|
|
'ja-JP': 'ドライブにファイルをアップロードします。',
|
|
|
|
'en-US': 'Upload a file to drive.'
|
2018-07-15 12:43:36 -06:00
|
|
|
},
|
|
|
|
|
|
|
|
requireCredential: true,
|
|
|
|
|
|
|
|
limit: {
|
|
|
|
duration: ms('1hour'),
|
2018-10-31 08:03:14 -06:00
|
|
|
max: 120
|
2018-07-15 12:43:36 -06:00
|
|
|
},
|
|
|
|
|
2018-07-24 16:18:50 -06:00
|
|
|
requireFile: true,
|
2018-07-15 12:43:36 -06:00
|
|
|
|
|
|
|
kind: 'drive-write',
|
|
|
|
|
|
|
|
params: {
|
2018-11-01 12:32:24 -06:00
|
|
|
folderId: {
|
|
|
|
validator: $.type(ID).optional.nullable,
|
|
|
|
transform: transform,
|
|
|
|
default: null as any,
|
2018-07-15 12:43:36 -06:00
|
|
|
desc: {
|
2018-08-28 15:59:43 -06:00
|
|
|
'ja-JP': 'フォルダID'
|
2018-07-15 12:43:36 -06:00
|
|
|
}
|
2018-11-01 12:32:24 -06:00
|
|
|
},
|
2018-07-19 11:40:37 -06:00
|
|
|
|
2018-11-01 12:32:24 -06:00
|
|
|
isSensitive: {
|
|
|
|
validator: $.bool.optional,
|
2018-10-20 00:50:13 -06:00
|
|
|
default: false,
|
2018-07-19 11:40:37 -06:00
|
|
|
desc: {
|
2018-08-28 15:59:43 -06:00
|
|
|
'ja-JP': 'このメディアが「閲覧注意」(NSFW)かどうか',
|
|
|
|
'en-US': 'Whether this media is NSFW'
|
2018-07-19 11:40:37 -06:00
|
|
|
}
|
2018-11-01 12:32:24 -06:00
|
|
|
},
|
2018-10-20 00:50:13 -06:00
|
|
|
|
2018-11-01 12:32:24 -06:00
|
|
|
force: {
|
|
|
|
validator: $.bool.optional,
|
2018-10-20 00:50:13 -06:00
|
|
|
default: false,
|
|
|
|
desc: {
|
|
|
|
'ja-JP': 'true にすると、同じハッシュを持つファイルが既にアップロードされていても強制的にファイルを作成します。',
|
|
|
|
}
|
2018-11-01 12:32:24 -06:00
|
|
|
}
|
2018-07-15 12:43:36 -06:00
|
|
|
}
|
|
|
|
};
|
2016-12-28 15:49:51 -07:00
|
|
|
|
2018-07-05 11:58:29 -06:00
|
|
|
export default async (file: any, params: any, user: ILocalUser): Promise<any> => {
|
2017-02-11 09:39:27 -07:00
|
|
|
if (file == null) {
|
2017-11-13 12:35:25 -07:00
|
|
|
throw 'file is required';
|
2017-02-11 09:39:27 -07:00
|
|
|
}
|
|
|
|
|
2016-12-28 15:49:51 -07:00
|
|
|
// Get 'name' parameter
|
|
|
|
let name = file.originalname;
|
|
|
|
if (name !== undefined && name !== null) {
|
|
|
|
name = name.trim();
|
|
|
|
if (name.length === 0) {
|
|
|
|
name = null;
|
|
|
|
} else if (name === 'blob') {
|
|
|
|
name = null;
|
|
|
|
} else if (!validateFileName(name)) {
|
2017-11-13 12:35:25 -07:00
|
|
|
throw 'invalid name';
|
2016-12-28 15:49:51 -07:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
name = null;
|
|
|
|
}
|
|
|
|
|
2018-05-25 03:41:49 -06:00
|
|
|
function cleanup() {
|
|
|
|
fs.unlink(file.path, () => {});
|
|
|
|
}
|
|
|
|
|
2018-07-15 12:43:36 -06:00
|
|
|
const [ps, psErr] = getParams(meta, params);
|
|
|
|
if (psErr) {
|
|
|
|
cleanup();
|
|
|
|
throw psErr;
|
|
|
|
}
|
|
|
|
|
2017-12-10 21:33:33 -07:00
|
|
|
try {
|
|
|
|
// Create file
|
2018-10-20 00:50:13 -06:00
|
|
|
const driveFile = await create(user, file.path, name, null, ps.folderId, ps.force, false, null, null, ps.isSensitive);
|
2016-12-28 15:49:51 -07:00
|
|
|
|
2018-05-25 03:41:49 -06:00
|
|
|
cleanup();
|
|
|
|
|
2017-12-10 21:33:33 -07:00
|
|
|
// Serialize
|
2018-02-01 16:21:30 -07:00
|
|
|
return pack(driveFile);
|
2017-12-10 21:33:33 -07:00
|
|
|
} catch (e) {
|
|
|
|
console.error(e);
|
|
|
|
|
2018-05-25 03:41:49 -06:00
|
|
|
cleanup();
|
|
|
|
|
2017-12-10 21:33:33 -07:00
|
|
|
throw e;
|
|
|
|
}
|
2017-11-13 12:35:25 -07:00
|
|
|
};
|