2019-02-01 16:16:27 +01:00
|
|
|
import * as ms from 'ms';
|
2019-02-05 03:48:08 +01:00
|
|
|
import $ from 'cafy';
|
|
|
|
import ID, { transform } from '../../../../../misc/cafy-id';
|
2018-03-29 13:32:18 +02:00
|
|
|
import { validateFileName, pack } from '../../../../../models/drive-file';
|
2018-04-07 21:02:12 +02:00
|
|
|
import create from '../../../../../services/drive/add-file';
|
2018-11-02 05:47:44 +01:00
|
|
|
import define from '../../../define';
|
2019-02-03 10:16:57 +01:00
|
|
|
import { apiLogger } from '../../../logger';
|
2018-07-15 20:43:36 +02:00
|
|
|
|
|
|
|
export const meta = {
|
|
|
|
desc: {
|
2018-08-28 23:59:43 +02:00
|
|
|
'ja-JP': 'ドライブにファイルをアップロードします。',
|
|
|
|
'en-US': 'Upload a file to drive.'
|
2018-07-15 20:43:36 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
requireCredential: true,
|
|
|
|
|
|
|
|
limit: {
|
|
|
|
duration: ms('1hour'),
|
2018-10-31 15:03:14 +01:00
|
|
|
max: 120
|
2018-07-15 20:43:36 +02:00
|
|
|
},
|
|
|
|
|
2018-07-25 00:18:50 +02:00
|
|
|
requireFile: true,
|
2018-07-15 20:43:36 +02:00
|
|
|
|
|
|
|
kind: 'drive-write',
|
|
|
|
|
|
|
|
params: {
|
2018-11-01 19:32:24 +01:00
|
|
|
folderId: {
|
2019-02-13 08:33:07 +01:00
|
|
|
validator: $.optional.nullable.type(ID),
|
2018-11-01 19:32:24 +01:00
|
|
|
transform: transform,
|
|
|
|
default: null as any,
|
2018-07-15 20:43:36 +02:00
|
|
|
desc: {
|
2018-08-28 23:59:43 +02:00
|
|
|
'ja-JP': 'フォルダID'
|
2018-07-15 20:43:36 +02:00
|
|
|
}
|
2018-11-01 19:32:24 +01:00
|
|
|
},
|
2018-07-19 19:40:37 +02:00
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
isSensitive: {
|
2019-02-13 08:33:07 +01:00
|
|
|
validator: $.optional.or($.bool, $.str),
|
2018-10-20 08:50:13 +02:00
|
|
|
default: false,
|
2018-11-06 12:53:50 +01:00
|
|
|
transform: (v: any): boolean => v === true || v === 'true',
|
2018-07-19 19:40:37 +02:00
|
|
|
desc: {
|
2018-08-28 23:59:43 +02:00
|
|
|
'ja-JP': 'このメディアが「閲覧注意」(NSFW)かどうか',
|
|
|
|
'en-US': 'Whether this media is NSFW'
|
2018-07-19 19:40:37 +02:00
|
|
|
}
|
2018-11-01 19:32:24 +01:00
|
|
|
},
|
2018-10-20 08:50:13 +02:00
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
force: {
|
2019-02-13 08:33:07 +01:00
|
|
|
validator: $.optional.or($.bool, $.str),
|
2018-10-20 08:50:13 +02:00
|
|
|
default: false,
|
2018-11-06 12:53:50 +01:00
|
|
|
transform: (v: any): boolean => v === true || v === 'true',
|
2018-10-20 08:50:13 +02:00
|
|
|
desc: {
|
|
|
|
'ja-JP': 'true にすると、同じハッシュを持つファイルが既にアップロードされていても強制的にファイルを作成します。',
|
|
|
|
}
|
2018-11-01 19:32:24 +01:00
|
|
|
}
|
2018-07-15 20:43:36 +02:00
|
|
|
}
|
|
|
|
};
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2018-11-02 05:47:44 +01:00
|
|
|
export default define(meta, (ps, user, app, file, cleanup) => new Promise(async (res, rej) => {
|
2016-12-28 23:49:51 +01: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)) {
|
2018-11-02 05:47:44 +01:00
|
|
|
return rej('invalid name');
|
2016-12-28 23:49:51 +01:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
name = null;
|
|
|
|
}
|
|
|
|
|
2017-12-11 05:33:33 +01:00
|
|
|
try {
|
|
|
|
// Create file
|
2018-10-20 08:50:13 +02:00
|
|
|
const driveFile = await create(user, file.path, name, null, ps.folderId, ps.force, false, null, null, ps.isSensitive);
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2018-05-25 11:41:49 +02:00
|
|
|
cleanup();
|
|
|
|
|
2018-11-25 20:25:48 +01:00
|
|
|
res(pack(driveFile, { self: true }));
|
2017-12-11 05:33:33 +01:00
|
|
|
} catch (e) {
|
2019-02-03 10:16:57 +01:00
|
|
|
apiLogger.error(e);
|
2017-12-11 05:33:33 +01:00
|
|
|
|
2018-05-25 11:41:49 +02:00
|
|
|
cleanup();
|
|
|
|
|
2018-11-02 05:47:44 +01:00
|
|
|
rej(e);
|
2017-12-11 05:33:33 +01:00
|
|
|
}
|
2018-11-02 05:47:44 +01:00
|
|
|
}));
|