2019-01-19 02:50:38 +02:00
|
|
|
import $ from 'cafy';
|
|
|
|
import * as mongo from 'mongodb';
|
|
|
|
import ID, { transform } from '../../../../../misc/cafy-id';
|
|
|
|
import DriveFile, { pack, IDriveFile } from '../../../../../models/drive-file';
|
2018-11-02 06:47:44 +02:00
|
|
|
import define from '../../../define';
|
2019-01-19 02:50:38 +02:00
|
|
|
import config from '../../../../../config';
|
2016-12-29 00:49:51 +02:00
|
|
|
|
2018-07-16 22:36:44 +03:00
|
|
|
export const meta = {
|
2018-10-23 00:59:52 +03:00
|
|
|
stability: 'stable',
|
|
|
|
|
2018-07-16 22:36:44 +03:00
|
|
|
desc: {
|
2018-08-29 00:59:43 +03:00
|
|
|
'ja-JP': '指定したドライブのファイルの情報を取得します。',
|
|
|
|
'en-US': 'Get specified file of drive.'
|
2018-07-16 22:36:44 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
requireCredential: true,
|
|
|
|
|
2018-10-23 00:59:52 +03:00
|
|
|
kind: 'drive-read',
|
|
|
|
|
|
|
|
params: {
|
2018-11-01 20:32:24 +02:00
|
|
|
fileId: {
|
2019-01-19 02:50:38 +02:00
|
|
|
validator: $.type(ID).optional,
|
2018-11-01 20:32:24 +02:00
|
|
|
transform: transform,
|
2018-10-23 00:59:52 +03:00
|
|
|
desc: {
|
|
|
|
'ja-JP': '対象のファイルID',
|
|
|
|
'en-US': 'Target file ID'
|
|
|
|
}
|
2019-01-19 02:50:38 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
url: {
|
|
|
|
validator: $.str.optional,
|
|
|
|
desc: {
|
|
|
|
'ja-JP': '対象のファイルのURL',
|
|
|
|
'en-US': 'Target file URL'
|
|
|
|
}
|
2018-11-01 20:32:24 +02:00
|
|
|
}
|
2018-10-23 00:59:52 +03:00
|
|
|
}
|
2018-07-16 22:36:44 +03:00
|
|
|
};
|
|
|
|
|
2018-11-02 06:47:44 +02:00
|
|
|
export default define(meta, (ps, user) => new Promise(async (res, rej) => {
|
2019-01-19 02:50:38 +02:00
|
|
|
let file: IDriveFile;
|
|
|
|
|
|
|
|
if (ps.fileId) {
|
|
|
|
file = await DriveFile.findOne({
|
2018-10-23 00:59:52 +03:00
|
|
|
_id: ps.fileId,
|
2018-10-10 23:26:51 +03:00
|
|
|
'metadata.deletedAt': { $exists: false }
|
2016-12-29 00:49:51 +02:00
|
|
|
});
|
2019-01-19 02:50:38 +02:00
|
|
|
} else if (ps.url) {
|
|
|
|
const isInternalStorageUrl = ps.url.startsWith(config.drive_url);
|
|
|
|
if (isInternalStorageUrl) {
|
2019-01-19 02:52:27 +02:00
|
|
|
// Extract file ID from url
|
2019-01-19 02:50:38 +02:00
|
|
|
// e.g.
|
|
|
|
// http://misskey.local/files/foo?original=bar --> foo
|
|
|
|
const fileId = new mongo.ObjectID(ps.url.replace(config.drive_url, '').replace(/\?(.*)$/, '').replace(/\//g, ''));
|
|
|
|
file = await DriveFile.findOne({
|
|
|
|
_id: fileId,
|
|
|
|
'metadata.deletedAt': { $exists: false }
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
file = await DriveFile.findOne({
|
|
|
|
$or: [{
|
|
|
|
'metadata.url': ps.url
|
|
|
|
}, {
|
|
|
|
'metadata.webpublicUrl': ps.url
|
|
|
|
}, {
|
|
|
|
'metadata.thumbnailUrl': ps.url
|
|
|
|
}],
|
|
|
|
'metadata.deletedAt': { $exists: false }
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return rej('fileId or url required');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!user.isAdmin && !user.isModerator && !file.metadata.userId.equals(user._id)) {
|
|
|
|
return rej('access denied');
|
|
|
|
}
|
2016-12-29 00:49:51 +02:00
|
|
|
|
|
|
|
if (file === null) {
|
2018-10-23 00:59:52 +03:00
|
|
|
return rej('file-not-found');
|
2016-12-29 00:49:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Serialize
|
2018-02-02 01:21:30 +02:00
|
|
|
const _file = await pack(file, {
|
2018-11-25 21:25:48 +02:00
|
|
|
detail: true,
|
|
|
|
self: true
|
2017-11-06 09:09:51 +02:00
|
|
|
});
|
|
|
|
|
2018-10-23 00:59:52 +03:00
|
|
|
res(_file);
|
2018-11-02 06:47:44 +02:00
|
|
|
}));
|