@forestadmin/agent 1.0.0-beta.8 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agent.d.ts +76 -0
- package/dist/agent.js +133 -0
- package/dist/framework-mounter.d.ts +43 -0
- package/dist/framework-mounter.js +157 -0
- package/dist/index.d.ts +7 -4
- package/dist/index.js +10 -21
- package/dist/routes/access/api-chart.d.ts +16 -0
- package/dist/routes/access/api-chart.js +47 -0
- package/dist/{agent/routes → routes}/access/chart.d.ts +1 -0
- package/dist/routes/access/chart.js +162 -0
- package/dist/{agent/routes → routes}/access/count-related.d.ts +0 -0
- package/dist/routes/access/count-related.js +31 -0
- package/dist/{agent/routes → routes}/access/count.d.ts +0 -0
- package/dist/routes/access/count.js +31 -0
- package/dist/{agent/routes → routes}/access/csv-related.d.ts +0 -0
- package/dist/routes/access/csv-related.js +33 -0
- package/dist/{agent/routes → routes}/access/csv.d.ts +0 -0
- package/dist/routes/access/csv.js +31 -0
- package/dist/{agent/routes → routes}/access/get.d.ts +0 -0
- package/dist/routes/access/get.js +29 -0
- package/dist/{agent/routes → routes}/access/list-related.d.ts +0 -0
- package/dist/routes/access/list-related.js +25 -0
- package/dist/{agent/routes → routes}/access/list.d.ts +0 -0
- package/dist/routes/access/list.js +22 -0
- package/dist/{agent/routes → routes}/base-route.d.ts +0 -1
- package/dist/routes/base-route.js +13 -0
- package/dist/{agent/routes → routes}/collection-route.d.ts +0 -0
- package/dist/{agent/routes → routes}/collection-route.js +1 -1
- package/dist/{agent/routes → routes}/index.d.ts +0 -0
- package/dist/routes/index.js +108 -0
- package/dist/{agent/routes → routes}/modification/action.d.ts +0 -1
- package/dist/routes/modification/action.js +104 -0
- package/dist/routes/modification/associate-related.d.ts +12 -0
- package/dist/routes/modification/associate-related.js +51 -0
- package/dist/{agent/routes → routes}/modification/create.d.ts +0 -0
- package/dist/routes/modification/create.js +83 -0
- package/dist/{agent/routes → routes}/modification/delete.d.ts +0 -0
- package/dist/routes/modification/delete.js +41 -0
- package/dist/{agent/routes → routes}/modification/dissociate-delete-related.d.ts +0 -0
- package/dist/routes/modification/dissociate-delete-related.js +89 -0
- package/dist/routes/modification/update-field.d.ts +9 -0
- package/dist/routes/modification/update-field.js +39 -0
- package/dist/{agent/routes → routes}/modification/update-relation.d.ts +0 -0
- package/dist/routes/modification/update-relation.js +59 -0
- package/dist/{agent/routes → routes}/modification/update.d.ts +0 -0
- package/dist/routes/modification/update.js +31 -0
- package/dist/{agent/routes → routes}/relation-route.d.ts +0 -0
- package/dist/{agent/routes → routes}/relation-route.js +1 -1
- package/dist/{agent/routes → routes}/security/authentication.d.ts +1 -3
- package/dist/routes/security/authentication.js +74 -0
- package/dist/{agent/routes → routes}/security/ip-whitelist.d.ts +0 -0
- package/dist/{agent/routes → routes}/security/ip-whitelist.js +1 -1
- package/dist/{agent/routes → routes}/security/scope-invalidation.d.ts +0 -0
- package/dist/{agent/routes → routes}/security/scope-invalidation.js +1 -1
- package/dist/{agent/routes → routes}/system/error-handling.d.ts +2 -0
- package/dist/routes/system/error-handling.js +75 -0
- package/dist/{agent/routes → routes}/system/healthcheck.d.ts +0 -0
- package/dist/{agent/routes → routes}/system/healthcheck.js +1 -1
- package/dist/{agent/routes → routes}/system/logger.d.ts +0 -0
- package/dist/{agent/routes → routes}/system/logger.js +2 -2
- package/dist/{agent/services → services}/index.d.ts +0 -0
- package/dist/{agent/services → services}/index.js +2 -2
- package/dist/{agent/services → services}/permissions.d.ts +0 -0
- package/dist/services/permissions.js +85 -0
- package/dist/{agent/services → services}/serializer.d.ts +0 -5
- package/dist/services/serializer.js +120 -0
- package/dist/types.d.ts +28 -3
- package/dist/types.js +21 -1
- package/dist/{agent/utils → utils}/body-parser.d.ts +0 -0
- package/dist/{agent/utils → utils}/body-parser.js +1 -1
- package/dist/utils/condition-tree-parser.d.ts +11 -0
- package/dist/utils/condition-tree-parser.js +53 -0
- package/dist/{agent/utils → utils}/context-filter-factory.d.ts +0 -0
- package/dist/{agent/utils → utils}/context-filter-factory.js +1 -2
- package/dist/{agent/utils → utils}/csv-generator.d.ts +2 -2
- package/dist/utils/csv-generator.js +39 -0
- package/dist/{agent/utils → utils}/csv-route-context.d.ts +0 -0
- package/dist/utils/csv-route-context.js +14 -0
- package/dist/{agent/utils → utils}/forest-http-api.d.ts +5 -3
- package/dist/utils/forest-http-api.js +180 -0
- package/dist/{agent/utils → utils}/forest-schema/action-values.d.ts +2 -2
- package/dist/utils/forest-schema/action-values.js +144 -0
- package/dist/{agent/utils → utils}/forest-schema/emitter.d.ts +2 -2
- package/dist/utils/forest-schema/emitter.js +70 -0
- package/dist/{agent/utils → utils}/forest-schema/filterable.d.ts +0 -0
- package/dist/{agent/utils → utils}/forest-schema/filterable.js +1 -1
- package/dist/{agent/utils → utils}/forest-schema/generator-actions.d.ts +1 -1
- package/dist/utils/forest-schema/generator-actions.js +99 -0
- package/dist/{agent/utils → utils}/forest-schema/generator-collection.d.ts +1 -1
- package/dist/{agent/utils → utils}/forest-schema/generator-collection.js +3 -3
- package/dist/{agent/utils → utils}/forest-schema/generator-fields.d.ts +1 -0
- package/dist/utils/forest-schema/generator-fields.js +160 -0
- package/dist/{agent/utils → utils}/forest-schema/generator-segments.d.ts +0 -0
- package/dist/{agent/utils → utils}/forest-schema/generator-segments.js +1 -1
- package/dist/{agent/utils → utils}/forest-schema/types.d.ts +10 -4
- package/dist/{agent/utils → utils}/forest-schema/types.js +1 -1
- package/dist/{agent/utils → utils}/forest-schema/validation.d.ts +1 -1
- package/dist/utils/forest-schema/validation.js +28 -0
- package/dist/{agent/utils → utils}/id.d.ts +0 -0
- package/dist/utils/id.js +43 -0
- package/dist/{agent/utils/http-driver-options.d.ts → utils/options-validator.d.ts} +4 -5
- package/dist/utils/options-validator.js +92 -0
- package/dist/{agent/utils → utils}/query-string.d.ts +2 -2
- package/dist/utils/query-string.js +134 -0
- package/package.json +14 -3
- package/CHANGELOG.md +0 -457
- package/dist/agent/forestadmin-http-driver.d.ts +0 -34
- package/dist/agent/forestadmin-http-driver.js +0 -72
- package/dist/agent/routes/access/chart.js +0 -147
- package/dist/agent/routes/access/count-related.js +0 -24
- package/dist/agent/routes/access/count.js +0 -24
- package/dist/agent/routes/access/csv-related.js +0 -33
- package/dist/agent/routes/access/csv.js +0 -30
- package/dist/agent/routes/access/get.js +0 -28
- package/dist/agent/routes/access/list-related.js +0 -26
- package/dist/agent/routes/access/list.js +0 -23
- package/dist/agent/routes/base-route.js +0 -16
- package/dist/agent/routes/index.js +0 -90
- package/dist/agent/routes/modification/action.js +0 -103
- package/dist/agent/routes/modification/associate-related.d.ts +0 -12
- package/dist/agent/routes/modification/associate-related.js +0 -49
- package/dist/agent/routes/modification/create.js +0 -81
- package/dist/agent/routes/modification/delete.js +0 -40
- package/dist/agent/routes/modification/dissociate-delete-related.js +0 -88
- package/dist/agent/routes/modification/update-relation.js +0 -53
- package/dist/agent/routes/modification/update.js +0 -29
- package/dist/agent/routes/security/authentication.js +0 -86
- package/dist/agent/routes/system/error-handling.js +0 -56
- package/dist/agent/services/permissions.js +0 -79
- package/dist/agent/services/serializer.js +0 -120
- package/dist/agent/types.d.ts +0 -23
- package/dist/agent/types.js +0 -22
- package/dist/agent/utils/csv-generator.js +0 -39
- package/dist/agent/utils/csv-route-context.js +0 -14
- package/dist/agent/utils/forest-http-api.js +0 -173
- package/dist/agent/utils/forest-schema/action-values.js +0 -144
- package/dist/agent/utils/forest-schema/emitter.js +0 -70
- package/dist/agent/utils/forest-schema/generator-actions.js +0 -99
- package/dist/agent/utils/forest-schema/generator-fields.js +0 -131
- package/dist/agent/utils/forest-schema/validation.js +0 -26
- package/dist/agent/utils/http-driver-options.js +0 -93
- package/dist/agent/utils/id.js +0 -43
- package/dist/agent/utils/query-string.js +0 -130
- package/dist/builder/agent.d.ts +0 -82
- package/dist/builder/agent.js +0 -123
- package/dist/builder/collection.d.ts +0 -148
- package/dist/builder/collection.js +0 -226
- package/dist/builder/types.d.ts +0 -5
- package/dist/builder/types.js +0 -3
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const koa_1 = require("koa");
|
|
7
|
-
const datasource_toolkit_1 = require("@forestadmin/datasource-toolkit");
|
|
8
|
-
const types_1 = require("../../types");
|
|
9
|
-
const base_route_1 = __importDefault(require("../base-route"));
|
|
10
|
-
class ErrorHandling extends base_route_1.default {
|
|
11
|
-
constructor() {
|
|
12
|
-
super(...arguments);
|
|
13
|
-
this.type = types_1.RouteType.ErrorHandler;
|
|
14
|
-
}
|
|
15
|
-
setupRoutes(router) {
|
|
16
|
-
router.use(this.errorHandler.bind(this));
|
|
17
|
-
}
|
|
18
|
-
async errorHandler(context, next) {
|
|
19
|
-
try {
|
|
20
|
-
await next();
|
|
21
|
-
}
|
|
22
|
-
catch (e) {
|
|
23
|
-
let status = types_1.HttpCode.InternalServerError;
|
|
24
|
-
let message = 'Unexpected error';
|
|
25
|
-
if (e instanceof koa_1.HttpError || e instanceof datasource_toolkit_1.ValidationError) {
|
|
26
|
-
status = e instanceof koa_1.HttpError ? e.status : types_1.HttpCode.BadRequest;
|
|
27
|
-
message = e.message;
|
|
28
|
-
}
|
|
29
|
-
context.response.status = status;
|
|
30
|
-
context.response.body = { errors: [{ detail: message }] };
|
|
31
|
-
if (!this.options.isProduction) {
|
|
32
|
-
process.nextTick(() => this.debugLogError(context, e));
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
debugLogError(context, error) {
|
|
37
|
-
const { request } = context;
|
|
38
|
-
const query = JSON.stringify(request.query, null, ' ')?.replace(/"/g, '');
|
|
39
|
-
console.error('');
|
|
40
|
-
console.error(`\x1b[33m===== An exception was raised =====\x1b[0m`);
|
|
41
|
-
console.error(`${request.method} \x1b[34m${request.path}\x1b[36m?${query}\x1b[0m`);
|
|
42
|
-
if (request.method === 'POST' || request.method === 'PUT' || request.method === 'PATCH') {
|
|
43
|
-
const body = JSON.stringify(request.body, null, ' ')?.replace(/"/g, '');
|
|
44
|
-
console.error('');
|
|
45
|
-
console.error(`Body \x1b[36m${body}\x1b[0m`);
|
|
46
|
-
}
|
|
47
|
-
console.error('');
|
|
48
|
-
console.error('\x1b[31m', error.message, '\x1b[0m');
|
|
49
|
-
console.error('');
|
|
50
|
-
console.error(error.stack);
|
|
51
|
-
console.error(`\x1b[33m===================================\x1b[0m`);
|
|
52
|
-
console.error('');
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
exports.default = ErrorHandling;
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3ItaGFuZGxpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYWdlbnQvcm91dGVzL3N5c3RlbS9lcnJvci1oYW5kbGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZCQUErQztBQUMvQyx3RUFBa0U7QUFHbEUsdUNBQWtEO0FBQ2xELCtEQUFzQztBQUV0QyxNQUFxQixhQUFjLFNBQVEsb0JBQVM7SUFBcEQ7O1FBQ0UsU0FBSSxHQUFHLGlCQUFTLENBQUMsWUFBWSxDQUFDO0lBZ0RoQyxDQUFDO0lBOUNDLFdBQVcsQ0FBQyxNQUFjO1FBQ3hCLE1BQU0sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRU8sS0FBSyxDQUFDLFlBQVksQ0FBQyxPQUFnQixFQUFFLElBQVU7UUFDckQsSUFBSTtZQUNGLE1BQU0sSUFBSSxFQUFFLENBQUM7U0FDZDtRQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQ1YsSUFBSSxNQUFNLEdBQUcsZ0JBQVEsQ0FBQyxtQkFBbUIsQ0FBQztZQUMxQyxJQUFJLE9BQU8sR0FBRyxrQkFBa0IsQ0FBQztZQUVqQyxJQUFJLENBQUMsWUFBWSxlQUFTLElBQUksQ0FBQyxZQUFZLG9DQUFlLEVBQUU7Z0JBQzFELE1BQU0sR0FBRyxDQUFDLFlBQVksZUFBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxnQkFBUSxDQUFDLFVBQVUsQ0FBQztnQkFDakUsT0FBTyxHQUFHLENBQUMsQ0FBQyxPQUFPLENBQUM7YUFDckI7WUFFRCxPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7WUFDakMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUM7WUFFMUQsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFO2dCQUM5QixPQUFPLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDeEQ7U0FDRjtJQUNILENBQUM7SUFFTyxhQUFhLENBQUMsT0FBZ0IsRUFBRSxLQUFZO1FBQ2xELE1BQU0sRUFBRSxPQUFPLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFFNUIsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxHQUFHLENBQUMsRUFBRSxPQUFPLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQzFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDbEIsT0FBTyxDQUFDLEtBQUssQ0FBQyxvREFBb0QsQ0FBQyxDQUFDO1FBQ3BFLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxPQUFPLENBQUMsTUFBTSxZQUFZLE9BQU8sQ0FBQyxJQUFJLFlBQVksS0FBSyxTQUFTLENBQUMsQ0FBQztRQUVuRixJQUFJLE9BQU8sQ0FBQyxNQUFNLEtBQUssTUFBTSxJQUFJLE9BQU8sQ0FBQyxNQUFNLEtBQUssS0FBSyxJQUFJLE9BQU8sQ0FBQyxNQUFNLEtBQUssT0FBTyxFQUFFO1lBQ3ZGLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxDQUFDLEVBQUUsT0FBTyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztZQUN4RSxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQ2xCLE9BQU8sQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLElBQUksU0FBUyxDQUFDLENBQUM7U0FDOUM7UUFFRCxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ2xCLE9BQU8sQ0FBQyxLQUFLLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDcEQsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNsQixPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMzQixPQUFPLENBQUMsS0FBSyxDQUFDLG9EQUFvRCxDQUFDLENBQUM7UUFDcEUsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNwQixDQUFDO0NBQ0Y7QUFqREQsZ0NBaURDIn0=
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const lru_cache_1 = __importDefault(require("lru-cache"));
|
|
7
|
-
const object_hash_1 = __importDefault(require("object-hash"));
|
|
8
|
-
const types_1 = require("../types");
|
|
9
|
-
const forest_http_api_1 = __importDefault(require("../utils/forest-http-api"));
|
|
10
|
-
class PermissionService {
|
|
11
|
-
constructor(options) {
|
|
12
|
-
this.options = options;
|
|
13
|
-
this.cache = new lru_cache_1.default({
|
|
14
|
-
max: 256,
|
|
15
|
-
ttl: this.options.permissionsCacheDurationInSeconds * 1000,
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
invalidateCache(renderingId) {
|
|
19
|
-
this.cache.delete(renderingId);
|
|
20
|
-
}
|
|
21
|
-
/** Checks that a charting query is in the list of allowed queries */
|
|
22
|
-
async canChart(context) {
|
|
23
|
-
const chart = { ...context.request.body };
|
|
24
|
-
// When the server sends the data of the allowed charts, the target column is not specified
|
|
25
|
-
// for relations => allow them all.
|
|
26
|
-
if (chart?.group_by_field?.includes(':'))
|
|
27
|
-
chart.group_by_field = chart.group_by_field.substring(0, chart.group_by_field.indexOf(':'));
|
|
28
|
-
const chartHash = (0, object_hash_1.default)(chart, {
|
|
29
|
-
respectType: false,
|
|
30
|
-
excludeKeys: key => chart[key] === null,
|
|
31
|
-
});
|
|
32
|
-
await this.can(context, `chart:${chartHash}`);
|
|
33
|
-
}
|
|
34
|
-
/** Check if a user is allowed to perform a specific action */
|
|
35
|
-
async can(context, action, allowRefetch = true) {
|
|
36
|
-
const { id: userId, renderingId } = context.state.user;
|
|
37
|
-
const perms = await this.getRenderingPermissions(renderingId);
|
|
38
|
-
const isAllowed = perms.actions.has(action) || perms.actionsByUser[action]?.has(userId);
|
|
39
|
-
if (!isAllowed && allowRefetch) {
|
|
40
|
-
this.invalidateCache(renderingId);
|
|
41
|
-
return this.can(context, action, false);
|
|
42
|
-
}
|
|
43
|
-
if (!isAllowed) {
|
|
44
|
-
context.throw(types_1.HttpCode.Forbidden, 'Forbidden');
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
async getScope(collection, context) {
|
|
48
|
-
const { user } = context.state;
|
|
49
|
-
const perms = await this.getRenderingPermissions(user.renderingId);
|
|
50
|
-
const scopes = perms.scopes[collection.name];
|
|
51
|
-
if (!scopes)
|
|
52
|
-
return null;
|
|
53
|
-
return scopes.conditionTree.replaceLeafs(leaf => {
|
|
54
|
-
const dynamicValues = scopes.dynamicScopeValues?.[user.id];
|
|
55
|
-
if (typeof leaf.value === 'string' && leaf.value.startsWith('$currentUser')) {
|
|
56
|
-
// Search replacement hash from forestadmin server
|
|
57
|
-
if (dynamicValues) {
|
|
58
|
-
return leaf.override({ value: dynamicValues[leaf.value] });
|
|
59
|
-
}
|
|
60
|
-
// Search JWT token (new user)
|
|
61
|
-
return leaf.override({
|
|
62
|
-
value: leaf.value.startsWith('$currentUser.tags.')
|
|
63
|
-
? user.tags[leaf.value.substring(18)]
|
|
64
|
-
: user[leaf.value.substring(13)],
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
return leaf;
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
/** Get cached version of "rendering permissions" */
|
|
71
|
-
getRenderingPermissions(renderingId) {
|
|
72
|
-
if (!this.cache.has(renderingId))
|
|
73
|
-
this.cache.set(renderingId, forest_http_api_1.default.getPermissions(this.options, renderingId));
|
|
74
|
-
// We already checked the entry is up-to-date with the .has() call => allowStale
|
|
75
|
-
return this.cache.get(renderingId, { allowStale: true });
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
exports.default = PermissionService;
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVybWlzc2lvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYWdlbnQvc2VydmljZXMvcGVybWlzc2lvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFFQSwwREFBaUM7QUFDakMsOERBQXFDO0FBRXJDLG9DQUE4RDtBQUM5RCwrRUFBK0U7QUFPL0UsTUFBcUIsaUJBQWlCO0lBSXBDLFlBQVksT0FBcUI7UUFDL0IsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFDdkIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLG1CQUFRLENBQUM7WUFDeEIsR0FBRyxFQUFFLEdBQUc7WUFDUixHQUFHLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxpQ0FBaUMsR0FBRyxJQUFJO1NBQzNELENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxlQUFlLENBQUMsV0FBbUI7UUFDakMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVELHFFQUFxRTtJQUNyRSxLQUFLLENBQUMsUUFBUSxDQUFDLE9BQWdCO1FBQzdCLE1BQU0sS0FBSyxHQUFHLEVBQUUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1FBRTFDLDJGQUEyRjtRQUMzRixtQ0FBbUM7UUFDbkMsSUFBSSxLQUFLLEVBQUUsY0FBYyxFQUFFLFFBQVEsQ0FBQyxHQUFHLENBQUM7WUFDdEMsS0FBSyxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUU5RixNQUFNLFNBQVMsR0FBRyxJQUFBLHFCQUFVLEVBQUMsS0FBSyxFQUFFO1lBQ2xDLFdBQVcsRUFBRSxLQUFLO1lBQ2xCLFdBQVcsRUFBRSxHQUFHLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FB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
|
|
@@ -1,120 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const datasource_toolkit_1 = require("@forestadmin/datasource-toolkit");
|
|
7
|
-
const json_api_serializer_1 = __importDefault(require("json-api-serializer"));
|
|
8
|
-
const id_1 = __importDefault(require("../utils/id"));
|
|
9
|
-
class Serializer {
|
|
10
|
-
constructor(options) {
|
|
11
|
-
// No need to keep references to serializers for outdated schemas => weakmap.
|
|
12
|
-
this.serializers = new WeakMap();
|
|
13
|
-
this.prefix = options.prefix;
|
|
14
|
-
}
|
|
15
|
-
serialize(collection, data) {
|
|
16
|
-
const result = this.getSerializer(collection).serialize(collection.name, data);
|
|
17
|
-
this.stripUndefinedsInPlace(result);
|
|
18
|
-
return result;
|
|
19
|
-
}
|
|
20
|
-
deserialize(collection, body) {
|
|
21
|
-
return this.getSerializer(collection).deserialize(collection.name, body);
|
|
22
|
-
}
|
|
23
|
-
serializeWithSearchMetadata(collection, data, searchValue) {
|
|
24
|
-
const results = this.serialize(collection, data);
|
|
25
|
-
if (searchValue && searchValue.trim().length > 0) {
|
|
26
|
-
const resultsData = results.data;
|
|
27
|
-
const decorators = resultsData.reduce((decorator, record) => {
|
|
28
|
-
const search = Object.keys(record.attributes).filter(attribute => {
|
|
29
|
-
const value = record.attributes[attribute];
|
|
30
|
-
return value && value.toString().toLowerCase().includes(searchValue.toLowerCase());
|
|
31
|
-
});
|
|
32
|
-
if (search.length === 0) {
|
|
33
|
-
return decorator;
|
|
34
|
-
}
|
|
35
|
-
return { ...decorator, [Object.keys(decorator).length]: { id: record.id, search } };
|
|
36
|
-
}, {});
|
|
37
|
-
if (Object.values(decorators).length === 0) {
|
|
38
|
-
return results;
|
|
39
|
-
}
|
|
40
|
-
results.meta = { decorators };
|
|
41
|
-
}
|
|
42
|
-
return results;
|
|
43
|
-
}
|
|
44
|
-
getSerializer(collection) {
|
|
45
|
-
if (this.serializers.has(collection.schema)) {
|
|
46
|
-
return this.serializers.get(collection.schema);
|
|
47
|
-
}
|
|
48
|
-
const serializer = new json_api_serializer_1.default();
|
|
49
|
-
for (const sibling of collection.dataSource.collections) {
|
|
50
|
-
this.registerCollection(sibling, serializer);
|
|
51
|
-
this.serializers.set(sibling.schema, serializer);
|
|
52
|
-
}
|
|
53
|
-
return serializer;
|
|
54
|
-
}
|
|
55
|
-
registerCollection(collection, serializer) {
|
|
56
|
-
serializer.register(collection.name, {
|
|
57
|
-
id: 'forestId',
|
|
58
|
-
relationships: this.buildRelationshipsConfiguration(collection),
|
|
59
|
-
beforeSerialize: (data) => {
|
|
60
|
-
const copy = { ...data };
|
|
61
|
-
copy.forestId = id_1.default.packId(collection.schema, data);
|
|
62
|
-
return copy;
|
|
63
|
-
},
|
|
64
|
-
afterDeserialize: (data) => {
|
|
65
|
-
const copy = { ...data };
|
|
66
|
-
if (data.forestId) {
|
|
67
|
-
const parts = id_1.default.unpackId(collection.schema, data.forestId);
|
|
68
|
-
const primaryKeys = datasource_toolkit_1.SchemaUtils.getPrimaryKeys(collection.schema);
|
|
69
|
-
primaryKeys.forEach((field, index) => {
|
|
70
|
-
copy[field] = parts[index];
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
delete copy.forestId;
|
|
74
|
-
return copy;
|
|
75
|
-
},
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
buildRelationshipsConfiguration(collection) {
|
|
79
|
-
const relationships = {};
|
|
80
|
-
const urlPrefix = `${this.prefix}/${collection.name}`;
|
|
81
|
-
for (const [name, field] of Object.entries(collection.schema.fields)) {
|
|
82
|
-
if (field.type === 'ManyToOne' || field.type === 'OneToOne') {
|
|
83
|
-
relationships[name] = {
|
|
84
|
-
type: field.foreignCollection,
|
|
85
|
-
deserialize: (data) => {
|
|
86
|
-
const foreignCollection = collection.dataSource.getCollection(field.foreignCollection);
|
|
87
|
-
return id_1.default.unpackId(foreignCollection.schema, data.id);
|
|
88
|
-
},
|
|
89
|
-
};
|
|
90
|
-
}
|
|
91
|
-
if (field.type === 'ManyToMany' || field.type === 'OneToMany') {
|
|
92
|
-
relationships[name] = {
|
|
93
|
-
type: field.foreignCollection,
|
|
94
|
-
links: (data) => ({
|
|
95
|
-
related: {
|
|
96
|
-
href: `${urlPrefix}/${data.forestId}/relationships/${name}`,
|
|
97
|
-
},
|
|
98
|
-
}),
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
return relationships;
|
|
103
|
-
}
|
|
104
|
-
stripUndefinedsInPlace(record) {
|
|
105
|
-
if (record === null || typeof record !== 'object') {
|
|
106
|
-
return;
|
|
107
|
-
}
|
|
108
|
-
const indexable = record;
|
|
109
|
-
for (const key of Object.keys(indexable)) {
|
|
110
|
-
if (indexable[key] === undefined) {
|
|
111
|
-
delete indexable[key];
|
|
112
|
-
}
|
|
113
|
-
else {
|
|
114
|
-
this.stripUndefinedsInPlace(indexable[key]);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
exports.default = Serializer;
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VyaWFsaXplci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hZ2VudC9zZXJ2aWNlcy9zZXJpYWxpemVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsd0VBS3lDO0FBQ3pDLDhFQUFvRDtBQUdwRCxxREFBa0M7QUFLbEMsTUFBcUIsVUFBVTtJQUs3QixZQUFZLE9BQTBCO1FBSnRDLDZFQUE2RTtRQUM1RCxnQkFBVyxHQUFpRCxJQUFJLE9BQU8sRUFBRSxDQUFDO1FBSXpGLElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUMvQixDQUFDO0lBRUQsU0FBUyxDQUFDLFVBQXNCLEVBQUUsSUFBK0I7UUFDL0QsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztRQUMvRSxJQUFJLENBQUMsc0JBQXNCLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFcEMsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUVELFdBQVcsQ0FBQyxVQUFzQixFQUFFLElBQWE7UUFDL0MsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzNFLENBQUM7SUFFRCwyQkFBMkIsQ0FDekIsVUFBc0IsRUFDdEIsSUFBa0IsRUFDbEIsV0FBbUI7UUFFbkIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFlLENBQUM7UUFFL0QsSUFBSSxXQUFXLElBQUksV0FBVyxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDaEQsTUFBTSxXQUFXLEdBQUcsT0FBTyxDQUFDLElBQW9CLENBQUM7WUFDakQsTUFBTSxVQUFVLEdBQUcs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
|
package/dist/agent/types.d.ts
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { CompositeId } from '@forestadmin/datasource-toolkit';
|
|
2
|
-
import { AgentOptions } from '../types';
|
|
3
|
-
export declare enum HttpCode {
|
|
4
|
-
BadRequest = 400,
|
|
5
|
-
Forbidden = 403,
|
|
6
|
-
InternalServerError = 500,
|
|
7
|
-
NoContent = 204,
|
|
8
|
-
NotFound = 404,
|
|
9
|
-
Ok = 200
|
|
10
|
-
}
|
|
11
|
-
export declare enum RouteType {
|
|
12
|
-
Logger = 0,
|
|
13
|
-
ErrorHandler = 1,
|
|
14
|
-
PublicRoute = 2,
|
|
15
|
-
Authentication = 3,
|
|
16
|
-
PrivateRoute = 4
|
|
17
|
-
}
|
|
18
|
-
export declare type SelectionIds = {
|
|
19
|
-
areExcluded: boolean;
|
|
20
|
-
ids: CompositeId[];
|
|
21
|
-
};
|
|
22
|
-
export declare type AgentOptionsWithDefaults = Readonly<Required<AgentOptions>>;
|
|
23
|
-
//# sourceMappingURL=types.d.ts.map
|
package/dist/agent/types.js
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.RouteType = exports.HttpCode = void 0;
|
|
4
|
-
var HttpCode;
|
|
5
|
-
(function (HttpCode) {
|
|
6
|
-
HttpCode[HttpCode["BadRequest"] = 400] = "BadRequest";
|
|
7
|
-
HttpCode[HttpCode["Forbidden"] = 403] = "Forbidden";
|
|
8
|
-
HttpCode[HttpCode["InternalServerError"] = 500] = "InternalServerError";
|
|
9
|
-
HttpCode[HttpCode["NoContent"] = 204] = "NoContent";
|
|
10
|
-
HttpCode[HttpCode["NotFound"] = 404] = "NotFound";
|
|
11
|
-
HttpCode[HttpCode["Ok"] = 200] = "Ok";
|
|
12
|
-
})(HttpCode = exports.HttpCode || (exports.HttpCode = {}));
|
|
13
|
-
var RouteType;
|
|
14
|
-
(function (RouteType) {
|
|
15
|
-
// Changing the values of this enum changes the order in which routes are loaded into koa-router.
|
|
16
|
-
RouteType[RouteType["Logger"] = 0] = "Logger";
|
|
17
|
-
RouteType[RouteType["ErrorHandler"] = 1] = "ErrorHandler";
|
|
18
|
-
RouteType[RouteType["PublicRoute"] = 2] = "PublicRoute";
|
|
19
|
-
RouteType[RouteType["Authentication"] = 3] = "Authentication";
|
|
20
|
-
RouteType[RouteType["PrivateRoute"] = 4] = "PrivateRoute";
|
|
21
|
-
})(RouteType = exports.RouteType || (exports.RouteType = {}));
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWdlbnQvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBSUEsSUFBWSxRQU9YO0FBUEQsV0FBWSxRQUFRO0lBQ2xCLHFEQUFnQixDQUFBO0lBQ2hCLG1EQUFlLENBQUE7SUFDZix1RUFBeUIsQ0FBQTtJQUN6QixtREFBZSxDQUFBO0lBQ2YsaURBQWMsQ0FBQTtJQUNkLHFDQUFRLENBQUE7QUFDVixDQUFDLEVBUFcsUUFBUSxHQUFSLGdCQUFRLEtBQVIsZ0JBQVEsUUFPbkI7QUFFRCxJQUFZLFNBT1g7QUFQRCxXQUFZLFNBQVM7SUFDbkIsaUdBQWlHO0lBQ2pHLDZDQUFVLENBQUE7SUFDVix5REFBZ0IsQ0FBQTtJQUNoQix1REFBZSxDQUFBO0lBQ2YsNkRBQWtCLENBQUE7SUFDbEIseURBQWdCLENBQUE7QUFDbEIsQ0FBQyxFQVBXLFNBQVMsR0FBVCxpQkFBUyxLQUFULGlCQUFTLFFBT3BCIn0=
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CHUNK_SIZE = void 0;
|
|
4
|
-
const datasource_toolkit_1 = require("@forestadmin/datasource-toolkit");
|
|
5
|
-
const format_1 = require("@fast-csv/format");
|
|
6
|
-
exports.CHUNK_SIZE = 1000;
|
|
7
|
-
class CsvGenerator {
|
|
8
|
-
/**
|
|
9
|
-
* Use an async generator to ensure that
|
|
10
|
-
* - backpressure is properly applied without needing to extend Readable (for slow clients)
|
|
11
|
-
* - we stop making queries to the database if the client closes the connection.
|
|
12
|
-
*/
|
|
13
|
-
static async *generate(projection, header, filter, collection, list) {
|
|
14
|
-
yield (0, format_1.writeToString)([header.split(',')], { headers: true, includeEndRowDelimiter: true });
|
|
15
|
-
const limit = filter.page?.limit;
|
|
16
|
-
let skip = filter.page?.skip || 0;
|
|
17
|
-
let areAllRecordsFetched = false;
|
|
18
|
-
const copiedFilter = { ...filter };
|
|
19
|
-
while (!areAllRecordsFetched) {
|
|
20
|
-
let currentPageSize = exports.CHUNK_SIZE;
|
|
21
|
-
if (limit < skip)
|
|
22
|
-
currentPageSize = skip - limit;
|
|
23
|
-
copiedFilter.page = new datasource_toolkit_1.Page(skip, currentPageSize);
|
|
24
|
-
if (!copiedFilter.sort || copiedFilter.sort.length === 0) {
|
|
25
|
-
copiedFilter.sort = datasource_toolkit_1.SortFactory.byPrimaryKeys(collection);
|
|
26
|
-
}
|
|
27
|
-
// eslint-disable-next-line no-await-in-loop
|
|
28
|
-
const records = await list(new datasource_toolkit_1.PaginatedFilter(copiedFilter), projection);
|
|
29
|
-
yield CsvGenerator.convert(records, projection);
|
|
30
|
-
areAllRecordsFetched = records.length < exports.CHUNK_SIZE;
|
|
31
|
-
skip += currentPageSize;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
static convert(records, projection) {
|
|
35
|
-
return (0, format_1.writeToString)(records.map(record => projection.map(field => datasource_toolkit_1.RecordUtils.getFieldValue(record, field))));
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
exports.default = CsvGenerator;
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3N2LWdlbmVyYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hZ2VudC91dGlscy9jc3YtZ2VuZXJhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHdFQVF5QztBQUN6Qyw2Q0FBaUQ7QUFFcEMsUUFBQSxVQUFVLEdBQUcsSUFBSSxDQUFDO0FBRS9CLE1BQXFCLFlBQVk7SUFDL0I7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxRQUFRLENBQ3BCLFVBQXNCLEVBQ3RCLE1BQWMsRUFDZCxNQUF1QixFQUN2QixVQUFzQixFQUN0QixJQUF3QjtRQUV4QixNQUFNLElBQUEsc0JBQWEsRUFBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsc0JBQXNCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUUxRixNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQztRQUNqQyxJQUFJLElBQUksR0FBRyxNQUFNLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLENBQUM7UUFFbEMsSUFBSSxvQkFBb0IsR0FBRyxLQUFLLENBQUM7UUFDakMsTUFBTSxZQUFZLEdBQUcsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUFDO1FBRW5DLE9BQU8sQ0FBQyxvQkFBb0IsRUFBRTtZQUM1QixJQUFJLGVBQWUsR0FBRyxrQkFBVSxDQUFDO1lBQ2pDLElBQUksS0FBSyxHQUFHLElBQUk7Z0JBQUUsZUFBZSxHQUFHLElBQUksR0FBRyxLQUFLLENBQUM7WUFFakQsWUFBWSxDQUFDLElBQUksR0FBRyxJQUFJLHlCQUFJLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBRXBELElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtnQkFDeEQsWUFBWSxDQUFDLElBQUksR0FBRyxnQ0FBVyxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsQ0FBQzthQUMzRDtZQUVELDRDQUE0QztZQUM1QyxNQUFNLE9BQU8sR0FBRyxNQUFNLElBQUksQ0FBQyxJQUFJLG9DQUFlLENBQUMsWUFBWSxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFFMUUsTUFBTSxZQUFZLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FBQztZQUVoRCxvQkFBb0IsR0FBRyxPQUFPLENBQUMsTUFBTSxHQUFHLGtCQUFVLENBQUM7WUFDbkQsSUFBSSxJQUFJLGVBQWUsQ0FBQztTQUN6QjtJQUNILENBQUM7SUFFTyxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQXFCLEVBQUUsVUFBc0I7UUFDbEUsT0FBTyxJQUFBLHNCQUFhLEVBQ2xCLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsZ0NBQVcsQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FDekYsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQTlDRCwrQkE4Q0MifQ==
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
class CsvRouteContext {
|
|
4
|
-
static buildResponse(context) {
|
|
5
|
-
const { filename } = context.request.query;
|
|
6
|
-
context.response.type = 'text/csv; charset=utf-8';
|
|
7
|
-
context.response.attachment(`attachment; filename=${filename}`);
|
|
8
|
-
context.response.lastModified = new Date();
|
|
9
|
-
context.response.set({ 'X-Accel-Buffering': 'no' });
|
|
10
|
-
context.response.set({ 'Cache-Control': 'no-cache' });
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
exports.default = CsvRouteContext;
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3N2LXJvdXRlLWNvbnRleHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYWdlbnQvdXRpbHMvY3N2LXJvdXRlLWNvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSxNQUFxQixlQUFlO0lBQ2xDLE1BQU0sQ0FBQyxhQUFhLENBQUMsT0FBZ0I7UUFDbkMsTUFBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDO1FBRTNDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLHlCQUF5QixDQUFDO1FBQ2xELE9BQU8sQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLHdCQUF3QixRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQ2hFLE9BQU8sQ0FBQyxRQUFRLENBQUMsWUFBWSxHQUFHLElBQUksSUFBSSxFQUFFLENBQUM7UUFDM0MsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRSxtQkFBbUIsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ3BELE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUUsZUFBZSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFDeEQsQ0FBQztDQUNGO0FBVkQsa0NBVUMifQ==
|
|
@@ -1,173 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
7
|
-
const datasource_toolkit_1 = require("@forestadmin/datasource-toolkit");
|
|
8
|
-
const object_hash_1 = __importDefault(require("object-hash"));
|
|
9
|
-
const superagent_1 = __importDefault(require("superagent"));
|
|
10
|
-
class ForestHttpApi {
|
|
11
|
-
static async getIpWhitelistConfiguration(options) {
|
|
12
|
-
try {
|
|
13
|
-
const response = await superagent_1.default
|
|
14
|
-
.get(new URL('/liana/v1/ip-whitelist-rules', options.forestServerUrl).toString())
|
|
15
|
-
.set('forest-secret-key', options.envSecret);
|
|
16
|
-
const { attributes } = response.body.data;
|
|
17
|
-
return { isFeatureEnabled: attributes.use_ip_whitelist, ipRules: attributes.rules };
|
|
18
|
-
}
|
|
19
|
-
catch {
|
|
20
|
-
throw new Error('An error occurred while retrieving your IP whitelist.');
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
static async getOpenIdIssuerMetadata(options) {
|
|
24
|
-
try {
|
|
25
|
-
const response = await superagent_1.default
|
|
26
|
-
.get(new URL('/oidc/.well-known/openid-configuration', options.forestServerUrl).toString())
|
|
27
|
-
.set('forest-secret-key', options.envSecret);
|
|
28
|
-
return response.body;
|
|
29
|
-
}
|
|
30
|
-
catch {
|
|
31
|
-
throw new Error('Failed to fetch open-id issuer metadata.');
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
static async getUserInformation(options, renderingId, accessToken) {
|
|
35
|
-
try {
|
|
36
|
-
const url = new URL(`/liana/v2/renderings/${renderingId}/authorization`, options.forestServerUrl);
|
|
37
|
-
const response = await superagent_1.default
|
|
38
|
-
.get(url.toString())
|
|
39
|
-
.set('forest-token', accessToken)
|
|
40
|
-
.set('forest-secret-key', options.envSecret);
|
|
41
|
-
const { attributes, id } = response.body.data;
|
|
42
|
-
return {
|
|
43
|
-
id: Number(id),
|
|
44
|
-
email: attributes.email,
|
|
45
|
-
firstName: attributes.first_name,
|
|
46
|
-
lastName: attributes.last_name,
|
|
47
|
-
team: attributes.teams[0],
|
|
48
|
-
role: attributes.role,
|
|
49
|
-
tags: attributes.tags?.reduce((memo, { key, value }) => ({ ...memo, [key]: value }), {}),
|
|
50
|
-
renderingId,
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
catch {
|
|
54
|
-
throw new Error('Failed to retrieve authorization informations.');
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
static async hasSchema(options, hash) {
|
|
58
|
-
const response = await superagent_1.default
|
|
59
|
-
.post(new URL('/forest/apimaps/hashcheck', options.forestServerUrl).toString())
|
|
60
|
-
.send({ schemaFileHash: hash })
|
|
61
|
-
.set('forest-secret-key', options.envSecret);
|
|
62
|
-
return !response?.body?.sendSchema;
|
|
63
|
-
}
|
|
64
|
-
static async uploadSchema(options, apimap) {
|
|
65
|
-
try {
|
|
66
|
-
await superagent_1.default
|
|
67
|
-
.post(new URL('/forest/apimaps', options.forestServerUrl).toString())
|
|
68
|
-
.send(apimap)
|
|
69
|
-
.set('forest-secret-key', options.envSecret);
|
|
70
|
-
}
|
|
71
|
-
catch (e) {
|
|
72
|
-
// Sending the schema to forestadmin-server is mandatory: crash the server gracefully
|
|
73
|
-
let message;
|
|
74
|
-
switch (e.response?.status) {
|
|
75
|
-
case 0:
|
|
76
|
-
message = 'Cannot send the apimap to Forest. Are you online?';
|
|
77
|
-
break;
|
|
78
|
-
case 404:
|
|
79
|
-
message =
|
|
80
|
-
'Cannot find the project related to the envSecret you configured. ' +
|
|
81
|
-
'Can you check on Forest that you copied it properly in the Forest initialization?';
|
|
82
|
-
break;
|
|
83
|
-
case 503:
|
|
84
|
-
message =
|
|
85
|
-
'Forest is in maintenance for a few minutes. ' +
|
|
86
|
-
'We are upgrading your experience in the forest. ' +
|
|
87
|
-
'We just need a few more minutes to get it right.';
|
|
88
|
-
break;
|
|
89
|
-
default:
|
|
90
|
-
message =
|
|
91
|
-
'An error occured with the apimap sent to Forest. ' +
|
|
92
|
-
'Please contact support@forestadmin.com for further investigations.';
|
|
93
|
-
}
|
|
94
|
-
throw new Error(message);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
static async getPermissions(options, renderingId) {
|
|
98
|
-
const { body } = await superagent_1.default
|
|
99
|
-
.get(`${options.forestServerUrl}/liana/v3/permissions`)
|
|
100
|
-
.set('forest-secret-key', options.envSecret)
|
|
101
|
-
.query(`renderingId=${renderingId}`);
|
|
102
|
-
if (!body.meta?.rolesACLActivated) {
|
|
103
|
-
throw new Error('Roles V2 are unsupported');
|
|
104
|
-
}
|
|
105
|
-
const actions = new Set();
|
|
106
|
-
const actionsByUser = {};
|
|
107
|
-
ForestHttpApi.decodeChartPermissions(body?.stats ?? {}, actions);
|
|
108
|
-
ForestHttpApi.decodeActionPermissions(body?.data?.collections ?? {}, actions, actionsByUser);
|
|
109
|
-
return {
|
|
110
|
-
actions,
|
|
111
|
-
actionsByUser,
|
|
112
|
-
scopes: ForestHttpApi.decodeScopePermissions(body?.data?.renderings?.[renderingId] ?? {}),
|
|
113
|
-
};
|
|
114
|
-
}
|
|
115
|
-
/** Helper to format permissions into something easy to validate against */
|
|
116
|
-
static decodeChartPermissions(chartsByType, actions) {
|
|
117
|
-
const serverCharts = Object.values(chartsByType).flat();
|
|
118
|
-
const frontendCharts = serverCharts.map(chart => ({
|
|
119
|
-
type: chart.type,
|
|
120
|
-
filters: chart.filter,
|
|
121
|
-
aggregate: chart.aggregator,
|
|
122
|
-
aggregate_field: chart.aggregateFieldName,
|
|
123
|
-
collection: chart.sourceCollectionId,
|
|
124
|
-
time_range: chart.timeRange,
|
|
125
|
-
group_by_date_field: (chart.type === 'Line' && chart.groupByFieldName) || null,
|
|
126
|
-
group_by_field: (chart.type !== 'Line' && chart.groupByFieldName) || null,
|
|
127
|
-
limit: chart.limit,
|
|
128
|
-
label_field: chart.labelFieldName,
|
|
129
|
-
relationship_field: chart.relationshipFieldName,
|
|
130
|
-
}));
|
|
131
|
-
const hashes = frontendCharts.map(chart => (0, object_hash_1.default)(chart, {
|
|
132
|
-
respectType: false,
|
|
133
|
-
excludeKeys: key => chart[key] === null || chart[key] === undefined,
|
|
134
|
-
}));
|
|
135
|
-
hashes.forEach(hash => actions.add(`chart:${hash}`));
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* Helper to format permissions into something easy to validate against
|
|
139
|
-
* Note that the format the server is sending varies depending on if we're using a remote or
|
|
140
|
-
* local environment.
|
|
141
|
-
*/
|
|
142
|
-
static decodeActionPermissions(collections, actions, actionsByUser) {
|
|
143
|
-
for (const [name, settings] of Object.entries(collections)) {
|
|
144
|
-
for (const [actionName, userIds] of Object.entries(settings.collection ?? {})) {
|
|
145
|
-
const shortName = actionName.substring(0, actionName.length - 'Enabled'.length);
|
|
146
|
-
if (typeof userIds === 'boolean')
|
|
147
|
-
actions.add(`${shortName}:${name}`);
|
|
148
|
-
else
|
|
149
|
-
actionsByUser[`${shortName}:${name}`] = new Set(userIds);
|
|
150
|
-
}
|
|
151
|
-
for (const [actionName, actionPerms] of Object.entries(settings.actions ?? {})) {
|
|
152
|
-
const userIds = actionPerms.triggerEnabled;
|
|
153
|
-
if (typeof userIds === 'boolean')
|
|
154
|
-
actions.add(`custom:${actionName}:${name}`);
|
|
155
|
-
else
|
|
156
|
-
actionsByUser[`custom:${actionName}:${name}`] = new Set(userIds);
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
/** Helper to format permissions into something easy to validate against */
|
|
161
|
-
static decodeScopePermissions(rendering) {
|
|
162
|
-
const scopes = {};
|
|
163
|
-
for (const [name, { scope }] of Object.entries(rendering)) {
|
|
164
|
-
scopes[name] = scope && {
|
|
165
|
-
conditionTree: datasource_toolkit_1.ConditionTreeFactory.fromPlainObject(scope.filter),
|
|
166
|
-
dynamicScopeValues: scope.dynamicScopesValues?.users ?? {},
|
|
167
|
-
};
|
|
168
|
-
}
|
|
169
|
-
return scopes;
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
exports.default = ForestHttpApi;
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9yZXN0LWh0dHAtYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FnZW50L3V0aWxzL2ZvcmVzdC1odHRwLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHVEQUF1RDtBQUN2RCx3RUFBc0Y7QUFHdEYsOERBQXFDO0FBQ3JDLDREQUFpRTtBQXVDakUsTUFBcUIsYUFBYTtJQUNoQyxNQUFNLENBQUMsS0FBSyxDQUFDLDJCQUEyQixDQUN0QyxPQUFvQjtRQUVwQixJQUFJO1lBQ0YsTUFBTSxRQUFRLEdBQWEsTUFBTSxvQkFBVTtpQkFDeEMsR0FBRyxDQUFDLElBQUksR0FBRyxDQUFDLDhCQUE4QixFQUFFLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztpQkFDaEYsR0FBRyxDQUFDLG1CQUFtQixFQUFFLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUUvQyxNQUFNLEVBQUUsVUFBVSxFQUFFLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7WUFFMUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFVBQVUsQ0FBQyxnQkFBZ0IsRUFBRSxPQUFPLEVBQUUsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQ3JGO1FBQUMsTUFBTTtZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsdURBQXVELENBQUMsQ0FBQztTQUMxRTtJQUNILENBQUM7SUFFRCxNQUFNLENBQUMsS0FBSyxDQUFDLHVCQUF1QixDQUFDLE9BQW9CO1FBQ3ZELElBQUk7WUFDRixNQUFNLFFBQVEsR0FBYSxNQUFNLG9CQUFVO2lCQUN4QyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsd0NBQXdDLEVBQUUsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO2lCQUMxRixHQUFHLENBQUMsbUJBQW1CLEVBQUUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBRS9DLE9BQU8sUUFBUSxDQUFD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
|