summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/drive.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2018-03-29 14:51:06 +0900
committerGitHub <noreply@github.com>2018-03-29 14:51:06 +0900
commit0b5597c873d2d9d45be94a18e1b74f44d9925185 (patch)
tree8b4dac3a56cf703650c8207f9279028a8560a96b /src/server/api/endpoints/drive.ts
parentoops (diff)
parentResolve conflicts (diff)
downloadmisskey-0b5597c873d2d9d45be94a18e1b74f44d9925185.tar.gz
misskey-0b5597c873d2d9d45be94a18e1b74f44d9925185.tar.bz2
misskey-0b5597c873d2d9d45be94a18e1b74f44d9925185.zip
Merge pull request #1332 from syuilo/pr/1327
Pr/1327
Diffstat (limited to 'src/server/api/endpoints/drive.ts')
-rw-r--r--src/server/api/endpoints/drive.ts37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/server/api/endpoints/drive.ts b/src/server/api/endpoints/drive.ts
new file mode 100644
index 0000000000..eb21853916
--- /dev/null
+++ b/src/server/api/endpoints/drive.ts
@@ -0,0 +1,37 @@
+/**
+ * Module dependencies
+ */
+import DriveFile from '../models/drive-file';
+
+/**
+ * Get drive information
+ *
+ * @param {any} params
+ * @param {any} user
+ * @return {Promise<any>}
+ */
+module.exports = (params, user) => new Promise(async (res, rej) => {
+ // Calculate drive usage
+ const usage = ((await DriveFile
+ .aggregate([
+ { $match: { 'metadata.userId': user._id } },
+ {
+ $project: {
+ length: true
+ }
+ },
+ {
+ $group: {
+ _id: null,
+ usage: { $sum: '$length' }
+ }
+ }
+ ]))[0] || {
+ usage: 0
+ }).usage;
+
+ res({
+ capacity: user.driveCapacity,
+ usage: usage
+ });
+});