diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2017-03-03 19:33:14 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2017-03-03 19:33:14 +0900 |
| commit | e2461a9314026d95d5baaea864c5282eed7c5504 (patch) | |
| tree | f7cc4fc93900572f55c4f48ed6a7f58026cd7264 /src/api/endpoints/drive/folders/update.ts | |
| parent | いい感じに (diff) | |
| download | misskey-e2461a9314026d95d5baaea864c5282eed7c5504.tar.gz misskey-e2461a9314026d95d5baaea864c5282eed7c5504.tar.bz2 misskey-e2461a9314026d95d5baaea864c5282eed7c5504.zip | |
wip
Diffstat (limited to 'src/api/endpoints/drive/folders/update.ts')
| -rw-r--r-- | src/api/endpoints/drive/folders/update.ts | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/src/api/endpoints/drive/folders/update.ts b/src/api/endpoints/drive/folders/update.ts new file mode 100644 index 0000000000..81d414354c --- /dev/null +++ b/src/api/endpoints/drive/folders/update.ts @@ -0,0 +1,105 @@ +'use strict'; + +/** + * Module dependencies + */ +import it from '../../../it'; +import DriveFolder from '../../../models/drive-folder'; +import { isValidFolderName } from '../../../models/drive-folder'; +import serialize from '../../../serializers/drive-file'; +import event from '../../../event'; + +/** + * Update a folder + * + * @param {any} params + * @param {any} user + * @return {Promise<any>} + */ +module.exports = (params, user) => + new Promise(async (res, rej) => +{ + // Get 'folder_id' parameter + const [folderId, folderIdErr] = it(params.folder_id).expect.id().required().qed(); + if (folderIdErr) return rej('invalid folder_id param'); + + // Fetch folder + const folder = await DriveFolder + .findOne({ + _id: folderId, + user_id: user._id + }); + + if (folder === null) { + return rej('folder-not-found'); + } + + // Get 'name' parameter + const [name, nameErr] = it(params.name).expect.string().validate(isValidFolderName).qed(); + if (nameErr) return rej('invalid name param'); + if (name) folder.name = name; + + // Get 'parent_id' parameter + const [parentId, parentIdErr] = it(params.parent_id).expect.nullable.id().qed(); + if (parentIdErr) return rej('invalid parent_id param'); + if (parentId !== undefined) { + if (parentId === null) { + folder.parent_id = null; + } else { + // Get parent folder + const parent = await DriveFolder + .findOne({ + _id: parentId, + user_id: user._id + }); + + if (parent === null) { + return rej('parent-folder-not-found'); + } + + // Check if the circular reference will occur + async function checkCircle(folderId) { + // Fetch folder + const folder2 = await DriveFolder.findOne({ + _id: folderId + }, { + _id: true, + parent_id: true + }); + + if (folder2._id.equals(folder._id)) { + return true; + } else if (folder2.parent_id) { + return await checkCircle(folder2.parent_id); + } else { + return false; + } + } + + if (parent.parent_id !== null) { + if (await checkCircle(parent.parent_id)) { + return rej('detected-circular-definition'); + } + } + + folder.parent_id = parent._id; + } + } + + // Update + DriveFolder.update(folder._id, { + $set: { + name: folder.name, + parent_id: folder.parent_id + } + }); + + // Serialize + const folderObj = await serialize(folder); + + // Response + res(folderObj); + + // Publish drive_folder_updated event + event(user._id, 'drive_folder_updated', folderObj); +}); |