'use strict'; /** * Module dependencies */ import it from '../../it'; import DriveFile from '../../models/drive-file'; import serialize from '../../serializers/drive-file'; /** * Get drive files * * @param {any} params * @param {any} user * @param {any} app * @return {Promise} */ module.exports = (params, user, app) => new Promise(async (res, rej) => { // Get 'limit' parameter const [limit, limitErr] = it(params.limit).expect.number().range(1, 100).default(10).qed(); if (limitErr) return rej('invalid limit param'); // Get 'since_id' parameter const [sinceId, sinceIdErr] = it(params.since_id).expect.id().qed(); if (sinceIdErr) return rej('invalid since_id param'); // Get 'max_id' parameter const [maxId, maxIdErr] = it(params.max_id).expect.id().qed(); if (maxIdErr) return rej('invalid max_id param'); // Check if both of since_id and max_id is specified if (sinceId && maxId) { return rej('cannot set since_id and max_id'); } // Get 'folder_id' parameter const [folderId, folderIdErr] = it(params.folder_id).expect.nullable.id().default(null).qed(); if (folderIdErr) return rej('invalid folder_id param'); // Construct query const sort = { _id: -1 }; const query = { user_id: user._id, folder_id: folderId } as any; if (sinceId) { sort._id = 1; query._id = { $gt: sinceId }; } else if (maxId) { query._id = { $lt: maxId }; } // Issue query const files = await DriveFile .find(query, { fields: { data: false }, limit: limit, sort: sort }); // Serialize res(await Promise.all(files.map(async file => await serialize(file)))); });