import { Parse } from 'parse/node'; import PromiseRouter from '../PromiseRouter'; import * as middleware from "../middlewares"; export class LogsRouter extends PromiseRouter { mountRoutes() { this.route('GET','/scriptlog', middleware.promiseEnforceMasterKeyAccess, this.validateRequest, (req) => { return this.handleGET(req); }); } validateRequest(req) { if (!req.config || !req.config.loggerController) { throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Logger adapter is not availabe'); } } // Returns a promise for a {response} object. // query params: // level (optional) Level of logging you want to query for (info || error) // from (optional) Start time for the search. Defaults to 1 week ago. // until (optional) End time for the search. Defaults to current time. // order (optional) Direction of results returned, either “asc” or “desc”. Defaults to “desc”. // size (optional) Number of rows returned by search. Defaults to 10 // n same as size, overrides size if set handleGET(req) { const from = req.query.from; const until = req.query.until; let size = req.query.size; if (req.query.n) { size = req.query.n; } const order = req.query.order const level = req.query.level; const options = { from, until, size, order, level }; return req.config.loggerController.getLogs(options).then((result) => { return Promise.resolve({ response: result }); }) } } export default LogsRouter;