mirror of
https://github.com/MisskeyIO/misskey
synced 2025-01-01 23:43:00 +09:00
84 lines
1.5 KiB
TypeScript
84 lines
1.5 KiB
TypeScript
import * as fs from 'fs';
|
|
const ms = require('ms');
|
|
import $ from 'cafy'; import ID from '../../../../../misc/cafy-id';
|
|
import { validateFileName, pack } from '../../../../../models/drive-file';
|
|
import create from '../../../../../services/drive/add-file';
|
|
import { ILocalUser } from '../../../../../models/user';
|
|
import getParams from '../../../get-params';
|
|
|
|
export const meta = {
|
|
desc: {
|
|
ja: 'ドライブにファイルをアップロードします。'
|
|
},
|
|
|
|
requireCredential: true,
|
|
|
|
limit: {
|
|
duration: ms('1hour'),
|
|
max: 100
|
|
},
|
|
|
|
withFile: true,
|
|
|
|
kind: 'drive-write',
|
|
|
|
params: {
|
|
folderId: $.type(ID).optional.nullable.note({
|
|
default: null,
|
|
desc: {
|
|
ja: 'フォルダID'
|
|
}
|
|
})
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Create a file
|
|
*/
|
|
export default async (file: any, params: any, user: ILocalUser): Promise<any> => {
|
|
if (file == null) {
|
|
throw 'file is required';
|
|
}
|
|
|
|
// 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)) {
|
|
throw 'invalid name';
|
|
}
|
|
} else {
|
|
name = null;
|
|
}
|
|
|
|
function cleanup() {
|
|
fs.unlink(file.path, () => {});
|
|
}
|
|
|
|
const [ps, psErr] = getParams(meta, params);
|
|
if (psErr) {
|
|
cleanup();
|
|
throw psErr;
|
|
}
|
|
|
|
try {
|
|
// Create file
|
|
const driveFile = await create(user, file.path, name, null, ps.folderId);
|
|
|
|
cleanup();
|
|
|
|
// Serialize
|
|
return pack(driveFile);
|
|
} catch (e) {
|
|
console.error(e);
|
|
|
|
cleanup();
|
|
|
|
throw e;
|
|
}
|
|
};
|