yumechi-no-kuni/src/services/drive/delete-file.ts

88 lines
3.1 KiB
TypeScript
Raw Normal View History

2018-07-23 16:21:21 -05:00
import * as Minio from 'minio';
2018-06-18 00:28:43 -05:00
import DriveFile, { DriveFileChunk, IDriveFile } from '../../models/drive-file';
import DriveFileThumbnail, { DriveFileThumbnailChunk } from '../../models/drive-file-thumbnail';
2018-07-23 16:21:21 -05:00
import config from '../../config';
import driveChart from '../../services/chart/drive';
import perUserDriveChart from '../../services/chart/per-user-drive';
import DriveFileWebpublic, { DriveFileWebpublicChunk } from '../../models/drive-file-webpublic';
export default async function(file: IDriveFile, isExpired = false) {
2018-07-24 18:01:12 -05:00
if (file.metadata.storage == 'minio') {
const minio = new Minio.Client(config.drive.config);
2018-08-15 17:17:04 -05:00
2018-08-16 07:23:31 -05:00
// 後方互換性のため、file.metadata.storageProps.key があるかどうかチェックしています。
// 将来的には const obj = file.metadata.storageProps.key; とします。
const obj = file.metadata.storageProps.key ? file.metadata.storageProps.key : `${config.drive.prefix}/${file.metadata.storageProps.id}`;
2018-07-24 18:01:12 -05:00
await minio.removeObject(config.drive.bucket, obj);
2018-08-15 17:17:04 -05:00
if (file.metadata.thumbnailUrl) {
2018-08-16 07:23:31 -05:00
// 後方互換性のため、file.metadata.storageProps.thumbnailKey があるかどうかチェックしています。
// 将来的には const thumbnailObj = file.metadata.storageProps.thumbnailKey; とします。
const thumbnailObj = file.metadata.storageProps.thumbnailKey ? file.metadata.storageProps.thumbnailKey : `${config.drive.prefix}/${file.metadata.storageProps.id}-thumbnail`;
2018-08-15 17:17:04 -05:00
await minio.removeObject(config.drive.bucket, thumbnailObj);
}
if (file.metadata.webpublicUrl) {
const webpublicObj = file.metadata.storageProps.webpublicKey ? file.metadata.storageProps.webpublicKey : `${config.drive.prefix}/${file.metadata.storageProps.id}-original`;
await minio.removeObject(config.drive.bucket, webpublicObj);
}
2018-07-24 18:01:12 -05:00
}
// チャンクをすべて削除
await DriveFileChunk.remove({
files_id: file._id
});
const set = {
metadata: {
deletedAt: new Date(),
isExpired: isExpired
}
} as any;
// リモートファイル期限切れ削除後は直リンクにする
if (isExpired && file.metadata && file.metadata._user && file.metadata._user.host != null) {
set.metadata.withoutChunks = true;
set.metadata.isRemote = true;
set.metadata.url = file.metadata.uri;
set.metadata.thumbnailUrl = undefined;
set.metadata.webpublicUrl = undefined;
}
await DriveFile.update({ _id: file._id }, {
$set: set
2018-07-24 18:01:12 -05:00
});
2018-07-24 18:01:12 -05:00
//#region サムネイルもあれば削除
const thumbnail = await DriveFileThumbnail.findOne({
'metadata.originalId': file._id
});
2018-07-24 18:01:12 -05:00
if (thumbnail) {
await DriveFileThumbnailChunk.remove({
files_id: thumbnail._id
});
2018-07-24 18:01:12 -05:00
await DriveFileThumbnail.remove({ _id: thumbnail._id });
}
2018-07-24 18:01:12 -05:00
//#endregion
2018-08-18 09:56:44 -05:00
//#region Web公開用もあれば削除
const webpublic = await DriveFileWebpublic.findOne({
'metadata.originalId': file._id
});
if (webpublic) {
await DriveFileWebpublicChunk.remove({
files_id: webpublic._id
});
await DriveFileWebpublic.remove({ _id: webpublic._id });
}
//#endregion
2018-08-18 09:56:44 -05:00
// 統計を更新
2018-10-22 15:36:35 -05:00
driveChart.update(file, false);
perUserDriveChart.update(file, false);
}