parse-server 2.8.4 → 8.6.2
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/LICENSE +167 -25
- package/NOTICE +10 -0
- package/README.md +929 -278
- package/lib/AccountLockout.js +47 -30
- package/lib/Adapters/AdapterLoader.js +21 -6
- package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
- package/lib/Adapters/Auth/AuthAdapter.js +116 -13
- package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
- package/lib/Adapters/Auth/OAuth1Client.js +27 -46
- package/lib/Adapters/Auth/apple.js +123 -0
- package/lib/Adapters/Auth/facebook.js +162 -35
- package/lib/Adapters/Auth/gcenter.js +217 -0
- package/lib/Adapters/Auth/github.js +118 -48
- package/lib/Adapters/Auth/google.js +160 -51
- package/lib/Adapters/Auth/gpgames.js +125 -0
- package/lib/Adapters/Auth/httpsRequest.js +6 -7
- package/lib/Adapters/Auth/index.js +170 -62
- package/lib/Adapters/Auth/instagram.js +114 -40
- package/lib/Adapters/Auth/janraincapture.js +52 -23
- package/lib/Adapters/Auth/janrainengage.js +19 -36
- package/lib/Adapters/Auth/keycloak.js +148 -0
- package/lib/Adapters/Auth/ldap.js +167 -0
- package/lib/Adapters/Auth/line.js +125 -0
- package/lib/Adapters/Auth/linkedin.js +111 -55
- package/lib/Adapters/Auth/meetup.js +24 -34
- package/lib/Adapters/Auth/mfa.js +324 -0
- package/lib/Adapters/Auth/microsoft.js +111 -0
- package/lib/Adapters/Auth/oauth2.js +97 -162
- package/lib/Adapters/Auth/phantauth.js +53 -0
- package/lib/Adapters/Auth/qq.js +108 -49
- package/lib/Adapters/Auth/spotify.js +107 -55
- package/lib/Adapters/Auth/twitter.js +188 -48
- package/lib/Adapters/Auth/utils.js +28 -0
- package/lib/Adapters/Auth/vkontakte.js +26 -39
- package/lib/Adapters/Auth/wechat.js +106 -44
- package/lib/Adapters/Auth/weibo.js +132 -58
- package/lib/Adapters/Cache/CacheAdapter.js +13 -8
- package/lib/Adapters/Cache/InMemoryCache.js +3 -13
- package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
- package/lib/Adapters/Cache/LRUCache.js +13 -27
- package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
- package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
- package/lib/Adapters/Cache/SchemaCache.js +25 -0
- package/lib/Adapters/Email/MailAdapter.js +10 -8
- package/lib/Adapters/Files/FilesAdapter.js +83 -25
- package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
- package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
- package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
- package/lib/Adapters/Logger/WinstonLogger.js +69 -88
- package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
- package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
- package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
- package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
- package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
- package/lib/Adapters/Push/PushAdapter.js +14 -7
- package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
- package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
- package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
- package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
- package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
- package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
- package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
- package/lib/Adapters/Storage/StorageAdapter.js +1 -1
- package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
- package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
- package/lib/Auth.js +488 -125
- package/lib/ClientSDK.js +2 -6
- package/lib/Config.js +525 -94
- package/lib/Controllers/AdaptableController.js +5 -25
- package/lib/Controllers/AnalyticsController.js +22 -23
- package/lib/Controllers/CacheController.js +10 -31
- package/lib/Controllers/DatabaseController.js +767 -313
- package/lib/Controllers/FilesController.js +49 -54
- package/lib/Controllers/HooksController.js +80 -84
- package/lib/Controllers/LiveQueryController.js +35 -22
- package/lib/Controllers/LoggerController.js +22 -58
- package/lib/Controllers/ParseGraphQLController.js +293 -0
- package/lib/Controllers/PushController.js +58 -49
- package/lib/Controllers/SchemaController.js +916 -422
- package/lib/Controllers/UserController.js +265 -180
- package/lib/Controllers/index.js +90 -125
- package/lib/Controllers/types.js +1 -1
- package/lib/Deprecator/Deprecations.js +30 -0
- package/lib/Deprecator/Deprecator.js +127 -0
- package/lib/Error.js +48 -0
- package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
- package/lib/GraphQL/ParseGraphQLServer.js +214 -0
- package/lib/GraphQL/helpers/objectsMutations.js +30 -0
- package/lib/GraphQL/helpers/objectsQueries.js +246 -0
- package/lib/GraphQL/loaders/configMutations.js +87 -0
- package/lib/GraphQL/loaders/configQueries.js +79 -0
- package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
- package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
- package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
- package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
- package/lib/GraphQL/loaders/filesMutations.js +107 -0
- package/lib/GraphQL/loaders/functionsMutations.js +78 -0
- package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
- package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
- package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
- package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
- package/lib/GraphQL/loaders/schemaMutations.js +162 -0
- package/lib/GraphQL/loaders/schemaQueries.js +81 -0
- package/lib/GraphQL/loaders/schemaTypes.js +341 -0
- package/lib/GraphQL/loaders/usersMutations.js +433 -0
- package/lib/GraphQL/loaders/usersQueries.js +90 -0
- package/lib/GraphQL/parseGraphQLUtils.js +63 -0
- package/lib/GraphQL/transformers/className.js +14 -0
- package/lib/GraphQL/transformers/constraintType.js +53 -0
- package/lib/GraphQL/transformers/inputType.js +51 -0
- package/lib/GraphQL/transformers/mutation.js +274 -0
- package/lib/GraphQL/transformers/outputType.js +51 -0
- package/lib/GraphQL/transformers/query.js +237 -0
- package/lib/GraphQL/transformers/schemaFields.js +99 -0
- package/lib/KeyPromiseQueue.js +48 -0
- package/lib/LiveQuery/Client.js +25 -33
- package/lib/LiveQuery/Id.js +2 -5
- package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
- package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
- package/lib/LiveQuery/ParsePubSub.js +7 -16
- package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
- package/lib/LiveQuery/QueryTools.js +76 -15
- package/lib/LiveQuery/RequestSchema.js +111 -97
- package/lib/LiveQuery/SessionTokenCache.js +23 -36
- package/lib/LiveQuery/Subscription.js +8 -17
- package/lib/LiveQuery/equalObjects.js +2 -3
- package/lib/Options/Definitions.js +1355 -382
- package/lib/Options/docs.js +301 -62
- package/lib/Options/index.js +11 -1
- package/lib/Options/parsers.js +14 -10
- package/lib/Page.js +44 -0
- package/lib/ParseMessageQueue.js +6 -13
- package/lib/ParseServer.js +474 -235
- package/lib/ParseServerRESTController.js +102 -40
- package/lib/PromiseRouter.js +39 -50
- package/lib/Push/PushQueue.js +24 -30
- package/lib/Push/PushWorker.js +32 -56
- package/lib/Push/utils.js +22 -35
- package/lib/RestQuery.js +361 -139
- package/lib/RestWrite.js +713 -344
- package/lib/Routers/AggregateRouter.js +97 -71
- package/lib/Routers/AnalyticsRouter.js +8 -14
- package/lib/Routers/AudiencesRouter.js +16 -35
- package/lib/Routers/ClassesRouter.js +86 -72
- package/lib/Routers/CloudCodeRouter.js +28 -37
- package/lib/Routers/FeaturesRouter.js +22 -25
- package/lib/Routers/FilesRouter.js +266 -171
- package/lib/Routers/FunctionsRouter.js +87 -103
- package/lib/Routers/GlobalConfigRouter.js +94 -33
- package/lib/Routers/GraphQLRouter.js +41 -0
- package/lib/Routers/HooksRouter.js +43 -47
- package/lib/Routers/IAPValidationRouter.js +57 -70
- package/lib/Routers/InstallationsRouter.js +17 -25
- package/lib/Routers/LogsRouter.js +10 -25
- package/lib/Routers/PagesRouter.js +647 -0
- package/lib/Routers/PublicAPIRouter.js +104 -112
- package/lib/Routers/PurgeRouter.js +19 -29
- package/lib/Routers/PushRouter.js +14 -28
- package/lib/Routers/RolesRouter.js +7 -14
- package/lib/Routers/SchemasRouter.js +63 -42
- package/lib/Routers/SecurityRouter.js +34 -0
- package/lib/Routers/SessionsRouter.js +25 -38
- package/lib/Routers/UsersRouter.js +463 -190
- package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
- package/lib/SchemaMigrations/Migrations.js +30 -0
- package/lib/Security/Check.js +109 -0
- package/lib/Security/CheckGroup.js +44 -0
- package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
- package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
- package/lib/Security/CheckGroups/CheckGroups.js +21 -0
- package/lib/Security/CheckRunner.js +213 -0
- package/lib/SharedRest.js +29 -0
- package/lib/StatusHandler.js +96 -93
- package/lib/TestUtils.js +70 -14
- package/lib/Utils.js +468 -0
- package/lib/batch.js +74 -40
- package/lib/cache.js +8 -8
- package/lib/cli/definitions/parse-live-query-server.js +4 -3
- package/lib/cli/definitions/parse-server.js +4 -3
- package/lib/cli/parse-live-query-server.js +9 -17
- package/lib/cli/parse-server.js +49 -47
- package/lib/cli/utils/commander.js +20 -29
- package/lib/cli/utils/runner.js +31 -32
- package/lib/cloud-code/Parse.Cloud.js +711 -36
- package/lib/cloud-code/Parse.Server.js +21 -0
- package/lib/cryptoUtils.js +6 -11
- package/lib/defaults.js +21 -15
- package/lib/deprecated.js +1 -1
- package/lib/index.js +78 -67
- package/lib/logger.js +12 -20
- package/lib/middlewares.js +484 -160
- package/lib/password.js +10 -6
- package/lib/request.js +175 -0
- package/lib/requiredParameter.js +4 -3
- package/lib/rest.js +157 -82
- package/lib/triggers.js +627 -185
- package/lib/vendor/README.md +3 -3
- package/lib/vendor/mongodbUrl.js +224 -137
- package/package.json +135 -57
- package/postinstall.js +38 -50
- package/public_html/invalid_verification_link.html +3 -3
- package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
- package/types/@types/deepcopy/index.d.ts +5 -0
- package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
- package/types/Options/index.d.ts +301 -0
- package/types/ParseServer.d.ts +65 -0
- package/types/eslint.config.mjs +30 -0
- package/types/index.d.ts +21 -0
- package/types/logger.d.ts +2 -0
- package/types/tests.ts +44 -0
- package/types/tsconfig.json +24 -0
- package/CHANGELOG.md +0 -1246
- package/PATENTS +0 -37
- package/bin/dev +0 -37
- package/lib/.DS_Store +0 -0
- package/lib/Adapters/Auth/common.js +0 -2
- package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
- package/lib/Controllers/SchemaCache.js +0 -97
- package/lib/LiveQuery/.DS_Store +0 -0
- package/lib/cli/utils/parsers.js +0 -77
- package/lib/cloud-code/.DS_Store +0 -0
- package/lib/cloud-code/HTTPResponse.js +0 -57
- package/lib/cloud-code/Untitled-1 +0 -123
- package/lib/cloud-code/httpRequest.js +0 -102
- package/lib/cloud-code/team.html +0 -123
- package/lib/graphql/ParseClass.js +0 -234
- package/lib/graphql/Schema.js +0 -197
- package/lib/graphql/index.js +0 -1
- package/lib/graphql/types/ACL.js +0 -35
- package/lib/graphql/types/Date.js +0 -25
- package/lib/graphql/types/File.js +0 -24
- package/lib/graphql/types/GeoPoint.js +0 -35
- package/lib/graphql/types/JSONObject.js +0 -30
- package/lib/graphql/types/NumberInput.js +0 -43
- package/lib/graphql/types/NumberQuery.js +0 -42
- package/lib/graphql/types/Pointer.js +0 -35
- package/lib/graphql/types/QueryConstraint.js +0 -61
- package/lib/graphql/types/StringQuery.js +0 -39
- package/lib/graphql/types/index.js +0 -110
|
@@ -1,59 +1,72 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.LiveQueryController =
|
|
7
|
-
|
|
8
|
-
var
|
|
9
|
-
|
|
10
|
-
var _Options = require('../Options');
|
|
11
|
-
|
|
6
|
+
exports.default = exports.LiveQueryController = void 0;
|
|
7
|
+
var _ParseCloudCodePublisher = require("../LiveQuery/ParseCloudCodePublisher");
|
|
8
|
+
var _Options = require("../Options");
|
|
9
|
+
var _triggers = require("./../triggers");
|
|
12
10
|
class LiveQueryController {
|
|
13
|
-
|
|
14
11
|
constructor(config) {
|
|
15
12
|
// If config is empty, we just assume no classs needs to be registered as LiveQuery
|
|
16
13
|
if (!config || !config.classNames) {
|
|
17
14
|
this.classNames = new Set();
|
|
18
15
|
} else if (config.classNames instanceof Array) {
|
|
19
|
-
|
|
16
|
+
const classNames = config.classNames.map(name => {
|
|
17
|
+
const _name = (0, _triggers.getClassName)(name);
|
|
18
|
+
return new RegExp(`^${_name}$`);
|
|
19
|
+
});
|
|
20
|
+
this.classNames = new Set(classNames);
|
|
20
21
|
} else {
|
|
21
22
|
throw 'liveQuery.classes should be an array of string';
|
|
22
23
|
}
|
|
23
24
|
this.liveQueryPublisher = new _ParseCloudCodePublisher.ParseCloudCodePublisher(config);
|
|
24
25
|
}
|
|
25
|
-
|
|
26
|
-
|
|
26
|
+
connect() {
|
|
27
|
+
return this.liveQueryPublisher.connect();
|
|
28
|
+
}
|
|
29
|
+
onAfterSave(className, currentObject, originalObject, classLevelPermissions) {
|
|
27
30
|
if (!this.hasLiveQuery(className)) {
|
|
28
31
|
return;
|
|
29
32
|
}
|
|
30
|
-
const req = this._makePublisherRequest(currentObject, originalObject);
|
|
33
|
+
const req = this._makePublisherRequest(currentObject, originalObject, classLevelPermissions);
|
|
31
34
|
this.liveQueryPublisher.onCloudCodeAfterSave(req);
|
|
32
35
|
}
|
|
33
|
-
|
|
34
|
-
onAfterDelete(className, currentObject, originalObject) {
|
|
36
|
+
onAfterDelete(className, currentObject, originalObject, classLevelPermissions) {
|
|
35
37
|
if (!this.hasLiveQuery(className)) {
|
|
36
38
|
return;
|
|
37
39
|
}
|
|
38
|
-
const req = this._makePublisherRequest(currentObject, originalObject);
|
|
40
|
+
const req = this._makePublisherRequest(currentObject, originalObject, classLevelPermissions);
|
|
39
41
|
this.liveQueryPublisher.onCloudCodeAfterDelete(req);
|
|
40
42
|
}
|
|
41
|
-
|
|
42
43
|
hasLiveQuery(className) {
|
|
43
|
-
|
|
44
|
+
for (const name of this.classNames) {
|
|
45
|
+
if (name.test(className)) {
|
|
46
|
+
return true;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return false;
|
|
44
50
|
}
|
|
45
|
-
|
|
46
|
-
|
|
51
|
+
clearCachedRoles(user) {
|
|
52
|
+
if (!user) {
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
return this.liveQueryPublisher.onClearCachedRoles(user);
|
|
56
|
+
}
|
|
57
|
+
_makePublisherRequest(currentObject, originalObject, classLevelPermissions) {
|
|
47
58
|
const req = {
|
|
48
59
|
object: currentObject
|
|
49
60
|
};
|
|
50
61
|
if (currentObject) {
|
|
51
62
|
req.original = originalObject;
|
|
52
63
|
}
|
|
64
|
+
if (classLevelPermissions) {
|
|
65
|
+
req.classLevelPermissions = classLevelPermissions;
|
|
66
|
+
}
|
|
53
67
|
return req;
|
|
54
68
|
}
|
|
55
69
|
}
|
|
56
|
-
|
|
57
70
|
exports.LiveQueryController = LiveQueryController;
|
|
58
|
-
exports.default = LiveQueryController;
|
|
59
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
71
|
+
var _default = exports.default = LiveQueryController;
|
|
72
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfUGFyc2VDbG91ZENvZGVQdWJsaXNoZXIiLCJyZXF1aXJlIiwiX09wdGlvbnMiLCJfdHJpZ2dlcnMiLCJMaXZlUXVlcnlDb250cm9sbGVyIiwiY29uc3RydWN0b3IiLCJjb25maWciLCJjbGFzc05hbWVzIiwiU2V0IiwiQXJyYXkiLCJtYXAiLCJuYW1lIiwiX25hbWUiLCJnZXRDbGFzc05hbWUiLCJSZWdFeHAiLCJsaXZlUXVlcnlQdWJsaXNoZXIiLCJQYXJzZUNsb3VkQ29kZVB1Ymxpc2hlciIsImNvbm5lY3QiLCJvbkFmdGVyU2F2ZSIsImNsYXNzTmFtZSIsImN1cnJlbnRPYmplY3QiLCJvcmlnaW5hbE9iamVjdCIsImNsYXNzTGV2ZWxQZXJtaXNzaW9ucyIsImhhc0xpdmVRdWVyeSIsInJlcSIsIl9tYWtlUHVibGlzaGVyUmVxdWVzdCIsIm9uQ2xvdWRDb2RlQWZ0ZXJTYXZlIiwib25BZnRlckRlbGV0ZSIsIm9uQ2xvdWRDb2RlQWZ0ZXJEZWxldGUiLCJ0ZXN0IiwiY2xlYXJDYWNoZWRSb2xlcyIsInVzZXIiLCJvbkNsZWFyQ2FjaGVkUm9sZXMiLCJvYmplY3QiLCJvcmlnaW5hbCIsImV4cG9ydHMiLCJfZGVmYXVsdCIsImRlZmF1bHQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvQ29udHJvbGxlcnMvTGl2ZVF1ZXJ5Q29udHJvbGxlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQYXJzZUNsb3VkQ29kZVB1Ymxpc2hlciB9IGZyb20gJy4uL0xpdmVRdWVyeS9QYXJzZUNsb3VkQ29kZVB1Ymxpc2hlcic7XG5pbXBvcnQgeyBMaXZlUXVlcnlPcHRpb25zIH0gZnJvbSAnLi4vT3B0aW9ucyc7XG5pbXBvcnQgeyBnZXRDbGFzc05hbWUgfSBmcm9tICcuLy4uL3RyaWdnZXJzJztcbmV4cG9ydCBjbGFzcyBMaXZlUXVlcnlDb250cm9sbGVyIHtcbiAgY2xhc3NOYW1lczogYW55O1xuICBsaXZlUXVlcnlQdWJsaXNoZXI6IGFueTtcblxuICBjb25zdHJ1Y3Rvcihjb25maWc6ID9MaXZlUXVlcnlPcHRpb25zKSB7XG4gICAgLy8gSWYgY29uZmlnIGlzIGVtcHR5LCB3ZSBqdXN0IGFzc3VtZSBubyBjbGFzc3MgbmVlZHMgdG8gYmUgcmVnaXN0ZXJlZCBhcyBMaXZlUXVlcnlcbiAgICBpZiAoIWNvbmZpZyB8fCAhY29uZmlnLmNsYXNzTmFtZXMpIHtcbiAgICAgIHRoaXMuY2xhc3NOYW1lcyA9IG5ldyBTZXQoKTtcbiAgICB9IGVsc2UgaWYgKGNvbmZpZy5jbGFzc05hbWVzIGluc3RhbmNlb2YgQXJyYXkpIHtcbiAgICAgIGNvbnN0IGNsYXNzTmFtZXMgPSBjb25maWcuY2xhc3NOYW1lcy5tYXAobmFtZSA9PiB7XG4gICAgICAgIGNvbnN0IF9uYW1lID0gZ2V0Q2xhc3NOYW1lKG5hbWUpO1xuICAgICAgICByZXR1cm4gbmV3IFJlZ0V4cChgXiR7X25hbWV9JGApO1xuICAgICAgfSk7XG4gICAgICB0aGlzLmNsYXNzTmFtZXMgPSBuZXcgU2V0KGNsYXNzTmFtZXMpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyAnbGl2ZVF1ZXJ5LmNsYXNzZXMgc2hvdWxkIGJlIGFuIGFycmF5IG9mIHN0cmluZyc7XG4gICAgfVxuICAgIHRoaXMubGl2ZVF1ZXJ5UHVibGlzaGVyID0gbmV3IFBhcnNlQ2xvdWRDb2RlUHVibGlzaGVyKGNvbmZpZyk7XG4gIH1cblxuICBjb25uZWN0KCkge1xuICAgIHJldHVybiB0aGlzLmxpdmVRdWVyeVB1Ymxpc2hlci5jb25uZWN0KCk7XG4gIH1cblxuICBvbkFmdGVyU2F2ZShcbiAgICBjbGFzc05hbWU6IHN0cmluZyxcbiAgICBjdXJyZW50T2JqZWN0OiBhbnksXG4gICAgb3JpZ2luYWxPYmplY3Q6IGFueSxcbiAgICBjbGFzc0xldmVsUGVybWlzc2lvbnM6ID9hbnlcbiAgKSB7XG4gICAgaWYgKCF0aGlzLmhhc0xpdmVRdWVyeShjbGFzc05hbWUpKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGNvbnN0IHJlcSA9IHRoaXMuX21ha2VQdWJsaXNoZXJSZXF1ZXN0KGN1cnJlbnRPYmplY3QsIG9yaWdpbmFsT2JqZWN0LCBjbGFzc0xldmVsUGVybWlzc2lvbnMpO1xuICAgIHRoaXMubGl2ZVF1ZXJ5UHVibGlzaGVyLm9uQ2xvdWRDb2RlQWZ0ZXJTYXZlKHJlcSk7XG4gIH1cblxuICBvbkFmdGVyRGVsZXRlKFxuICAgIGNsYXNzTmFtZTogc3RyaW5nLFxuICAgIGN1cnJlbnRPYmplY3Q6IGFueSxcbiAgICBvcmlnaW5hbE9iamVjdDogYW55LFxuICAgIGNsYXNzTGV2ZWxQZXJtaXNzaW9uczogYW55XG4gICkge1xuICAgIGlmICghdGhpcy5oYXNMaXZlUXVlcnkoY2xhc3NOYW1lKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBjb25zdCByZXEgPSB0aGlzLl9tYWtlUHVibGlzaGVyUmVxdWVzdChjdXJyZW50T2JqZWN0LCBvcmlnaW5hbE9iamVjdCwgY2xhc3NMZXZlbFBlcm1pc3Npb25zKTtcbiAgICB0aGlzLmxpdmVRdWVyeVB1Ymxpc2hlci5vbkNsb3VkQ29kZUFmdGVyRGVsZXRlKHJlcSk7XG4gIH1cblxuICBoYXNMaXZlUXVlcnkoY2xhc3NOYW1lOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICBmb3IgKGNvbnN0IG5hbWUgb2YgdGhpcy5jbGFzc05hbWVzKSB7XG4gICAgICBpZiAobmFtZS50ZXN0KGNsYXNzTmFtZSkpIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGNsZWFyQ2FjaGVkUm9sZXModXNlcjogYW55KSB7XG4gICAgaWYgKCF1c2VyKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHJldHVybiB0aGlzLmxpdmVRdWVyeVB1Ymxpc2hlci5vbkNsZWFyQ2FjaGVkUm9sZXModXNlcik7XG4gIH1cblxuICBfbWFrZVB1Ymxpc2hlclJlcXVlc3QoY3VycmVudE9iamVjdDogYW55LCBvcmlnaW5hbE9iamVjdDogYW55LCBjbGFzc0xldmVsUGVybWlzc2lvbnM6ID9hbnkpOiBhbnkge1xuICAgIGNvbnN0IHJlcSA9IHtcbiAgICAgIG9iamVjdDogY3VycmVudE9iamVjdCxcbiAgICB9O1xuICAgIGlmIChjdXJyZW50T2JqZWN0KSB7XG4gICAgICByZXEub3JpZ2luYWwgPSBvcmlnaW5hbE9iamVjdDtcbiAgICB9XG4gICAgaWYgKGNsYXNzTGV2ZWxQZXJtaXNzaW9ucykge1xuICAgICAgcmVxLmNsYXNzTGV2ZWxQZXJtaXNzaW9ucyA9IGNsYXNzTGV2ZWxQZXJtaXNzaW9ucztcbiAgICB9XG4gICAgcmV0dXJuIHJlcTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBMaXZlUXVlcnlDb250cm9sbGVyO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSx3QkFBQSxHQUFBQyxPQUFBO0FBQ0EsSUFBQUMsUUFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsU0FBQSxHQUFBRixPQUFBO0FBQ08sTUFBTUcsbUJBQW1CLENBQUM7RUFJL0JDLFdBQVdBLENBQUNDLE1BQXlCLEVBQUU7SUFDckM7SUFDQSxJQUFJLENBQUNBLE1BQU0sSUFBSSxDQUFDQSxNQUFNLENBQUNDLFVBQVUsRUFBRTtNQUNqQyxJQUFJLENBQUNBLFVBQVUsR0FBRyxJQUFJQyxHQUFHLENBQUMsQ0FBQztJQUM3QixDQUFDLE1BQU0sSUFBSUYsTUFBTSxDQUFDQyxVQUFVLFlBQVlFLEtBQUssRUFBRTtNQUM3QyxNQUFNRixVQUFVLEdBQUdELE1BQU0sQ0FBQ0MsVUFBVSxDQUFDRyxHQUFHLENBQUNDLElBQUksSUFBSTtRQUMvQyxNQUFNQyxLQUFLLEdBQUcsSUFBQUMsc0JBQVksRUFBQ0YsSUFBSSxDQUFDO1FBQ2hDLE9BQU8sSUFBSUcsTUFBTSxDQUFDLElBQUlGLEtBQUssR0FBRyxDQUFDO01BQ2pDLENBQUMsQ0FBQztNQUNGLElBQUksQ0FBQ0wsVUFBVSxHQUFHLElBQUlDLEdBQUcsQ0FBQ0QsVUFBVSxDQUFDO0lBQ3ZDLENBQUMsTUFBTTtNQUNMLE1BQU0sZ0RBQWdEO0lBQ3hEO0lBQ0EsSUFBSSxDQUFDUSxrQkFBa0IsR0FBRyxJQUFJQyxnREFBdUIsQ0FBQ1YsTUFBTSxDQUFDO0VBQy9EO0VBRUFXLE9BQU9BLENBQUEsRUFBRztJQUNSLE9BQU8sSUFBSSxDQUFDRixrQkFBa0IsQ0FBQ0UsT0FBTyxDQUFDLENBQUM7RUFDMUM7RUFFQUMsV0FBV0EsQ0FDVEMsU0FBaUIsRUFDakJDLGFBQWtCLEVBQ2xCQyxjQUFtQixFQUNuQkMscUJBQTJCLEVBQzNCO0lBQ0EsSUFBSSxDQUFDLElBQUksQ0FBQ0MsWUFBWSxDQUFDSixTQUFTLENBQUMsRUFBRTtNQUNqQztJQUNGO0lBQ0EsTUFBTUssR0FBRyxHQUFHLElBQUksQ0FBQ0MscUJBQXFCLENBQUNMLGFBQWEsRUFBRUMsY0FBYyxFQUFFQyxxQkFBcUIsQ0FBQztJQUM1RixJQUFJLENBQUNQLGtCQUFrQixDQUFDVyxvQkFBb0IsQ0FBQ0YsR0FBRyxDQUFDO0VBQ25EO0VBRUFHLGFBQWFBLENBQ1hSLFNBQWlCLEVBQ2pCQyxhQUFrQixFQUNsQkMsY0FBbUIsRUFDbkJDLHFCQUEwQixFQUMxQjtJQUNBLElBQUksQ0FBQyxJQUFJLENBQUNDLFlBQVksQ0FBQ0osU0FBUyxDQUFDLEVBQUU7TUFDakM7SUFDRjtJQUNBLE1BQU1LLEdBQUcsR0FBRyxJQUFJLENBQUNDLHFCQUFxQixDQUFDTCxhQUFhLEVBQUVDLGNBQWMsRUFBRUMscUJBQXFCLENBQUM7SUFDNUYsSUFBSSxDQUFDUCxrQkFBa0IsQ0FBQ2Esc0JBQXNCLENBQUNKLEdBQUcsQ0FBQztFQUNyRDtFQUVBRCxZQUFZQSxDQUFDSixTQUFpQixFQUFXO0lBQ3ZDLEtBQUssTUFBTVIsSUFBSSxJQUFJLElBQUksQ0FBQ0osVUFBVSxFQUFFO01BQ2xDLElBQUlJLElBQUksQ0FBQ2tCLElBQUksQ0FBQ1YsU0FBUyxDQUFDLEVBQUU7UUFDeEIsT0FBTyxJQUFJO01BQ2I7SUFDRjtJQUNBLE9BQU8sS0FBSztFQUNkO0VBRUFXLGdCQUFnQkEsQ0FBQ0MsSUFBUyxFQUFFO0lBQzFCLElBQUksQ0FBQ0EsSUFBSSxFQUFFO01BQ1Q7SUFDRjtJQUNBLE9BQU8sSUFBSSxDQUFDaEIsa0JBQWtCLENBQUNpQixrQkFBa0IsQ0FBQ0QsSUFBSSxDQUFDO0VBQ3pEO0VBRUFOLHFCQUFxQkEsQ0FBQ0wsYUFBa0IsRUFBRUMsY0FBbUIsRUFBRUMscUJBQTJCLEVBQU87SUFDL0YsTUFBTUUsR0FBRyxHQUFHO01BQ1ZTLE1BQU0sRUFBRWI7SUFDVixDQUFDO0lBQ0QsSUFBSUEsYUFBYSxFQUFFO01BQ2pCSSxHQUFHLENBQUNVLFFBQVEsR0FBR2IsY0FBYztJQUMvQjtJQUNBLElBQUlDLHFCQUFxQixFQUFFO01BQ3pCRSxHQUFHLENBQUNGLHFCQUFxQixHQUFHQSxxQkFBcUI7SUFDbkQ7SUFDQSxPQUFPRSxHQUFHO0VBQ1o7QUFDRjtBQUFDVyxPQUFBLENBQUEvQixtQkFBQSxHQUFBQSxtQkFBQTtBQUFBLElBQUFnQyxRQUFBLEdBQUFELE9BQUEsQ0FBQUUsT0FBQSxHQUVjakMsbUJBQW1CIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -1,43 +1,29 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.LoggerController = exports.LogOrder = exports.LogLevel =
|
|
7
|
-
|
|
8
|
-
var
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
var _AdaptableController2 = _interopRequireDefault(_AdaptableController);
|
|
13
|
-
|
|
14
|
-
var _LoggerAdapter = require('../Adapters/Logger/LoggerAdapter');
|
|
15
|
-
|
|
16
|
-
var _url = require('url');
|
|
17
|
-
|
|
18
|
-
var _url2 = _interopRequireDefault(_url);
|
|
19
|
-
|
|
20
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
21
|
-
|
|
6
|
+
exports.logLevels = exports.default = exports.LoggerController = exports.LogOrder = exports.LogLevel = void 0;
|
|
7
|
+
var _node = require("parse/node");
|
|
8
|
+
var _AdaptableController = _interopRequireDefault(require("./AdaptableController"));
|
|
9
|
+
var _LoggerAdapter = require("../Adapters/Logger/LoggerAdapter");
|
|
10
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
22
11
|
const MILLISECONDS_IN_A_DAY = 24 * 60 * 60 * 1000;
|
|
23
12
|
const LOG_STRING_TRUNCATE_LENGTH = 1000;
|
|
24
13
|
const truncationMarker = '... (truncated)';
|
|
25
|
-
|
|
26
14
|
const LogLevel = exports.LogLevel = {
|
|
27
15
|
INFO: 'info',
|
|
28
16
|
ERROR: 'error'
|
|
29
17
|
};
|
|
30
|
-
|
|
31
18
|
const LogOrder = exports.LogOrder = {
|
|
32
19
|
DESCENDING: 'desc',
|
|
33
20
|
ASCENDING: 'asc'
|
|
34
21
|
};
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
constructor(adapter, appId, options = { logLevel: 'info' }) {
|
|
22
|
+
const logLevels = exports.logLevels = ['error', 'warn', 'info', 'debug', 'verbose', 'silly', 'silent'];
|
|
23
|
+
class LoggerController extends _AdaptableController.default {
|
|
24
|
+
constructor(adapter, appId, options = {
|
|
25
|
+
logLevel: 'info'
|
|
26
|
+
}) {
|
|
41
27
|
super(adapter, appId, options);
|
|
42
28
|
let level = 'info';
|
|
43
29
|
if (options.verbose) {
|
|
@@ -54,16 +40,15 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
54
40
|
}
|
|
55
41
|
});
|
|
56
42
|
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
const urlObj =
|
|
60
|
-
const query = urlObj.
|
|
43
|
+
maskSensitiveUrl(path) {
|
|
44
|
+
const urlString = 'http://localhost' + path; // prepend dummy string to make a real URL
|
|
45
|
+
const urlObj = new URL(urlString);
|
|
46
|
+
const query = urlObj.searchParams;
|
|
61
47
|
let sanitizedQuery = '?';
|
|
62
|
-
|
|
63
|
-
for (const key in query) {
|
|
48
|
+
for (const [key, value] of query) {
|
|
64
49
|
if (key !== 'password') {
|
|
65
50
|
// normal value
|
|
66
|
-
sanitizedQuery += key + '=' +
|
|
51
|
+
sanitizedQuery += key + '=' + value + '&';
|
|
67
52
|
} else {
|
|
68
53
|
// password value, redact it
|
|
69
54
|
sanitizedQuery += key + '=' + '********' + '&';
|
|
@@ -76,13 +61,11 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
76
61
|
// return original path name with sanitized params attached
|
|
77
62
|
return urlObj.pathname + sanitizedQuery;
|
|
78
63
|
}
|
|
79
|
-
|
|
80
64
|
maskSensitive(argArray) {
|
|
81
65
|
return argArray.map(e => {
|
|
82
66
|
if (!e) {
|
|
83
67
|
return e;
|
|
84
68
|
}
|
|
85
|
-
|
|
86
69
|
if (typeof e === 'string') {
|
|
87
70
|
return e.replace(/(password".?:.?")[^"]*"/g, '$1********"');
|
|
88
71
|
}
|
|
@@ -99,12 +82,10 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
99
82
|
if (typeof item === 'string') {
|
|
100
83
|
return this.maskSensitiveUrl(item);
|
|
101
84
|
}
|
|
102
|
-
|
|
103
85
|
return item;
|
|
104
86
|
});
|
|
105
87
|
}
|
|
106
88
|
}
|
|
107
|
-
|
|
108
89
|
if (e.body) {
|
|
109
90
|
for (const key of Object.keys(e.body)) {
|
|
110
91
|
if (key === 'password') {
|
|
@@ -113,7 +94,6 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
113
94
|
}
|
|
114
95
|
}
|
|
115
96
|
}
|
|
116
|
-
|
|
117
97
|
if (e.params) {
|
|
118
98
|
for (const key of Object.keys(e.params)) {
|
|
119
99
|
if (key === 'password') {
|
|
@@ -122,11 +102,9 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
122
102
|
}
|
|
123
103
|
}
|
|
124
104
|
}
|
|
125
|
-
|
|
126
105
|
return e;
|
|
127
106
|
});
|
|
128
107
|
}
|
|
129
|
-
|
|
130
108
|
log(level, args) {
|
|
131
109
|
// make the passed in arguments object an array with the spread operator
|
|
132
110
|
args = this.maskSensitive([...args]);
|
|
@@ -138,31 +116,24 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
138
116
|
}));
|
|
139
117
|
this.adapter.log.apply(this.adapter, args);
|
|
140
118
|
}
|
|
141
|
-
|
|
142
119
|
info() {
|
|
143
120
|
return this.log('info', arguments);
|
|
144
121
|
}
|
|
145
|
-
|
|
146
122
|
error() {
|
|
147
123
|
return this.log('error', arguments);
|
|
148
124
|
}
|
|
149
|
-
|
|
150
125
|
warn() {
|
|
151
126
|
return this.log('warn', arguments);
|
|
152
127
|
}
|
|
153
|
-
|
|
154
128
|
verbose() {
|
|
155
129
|
return this.log('verbose', arguments);
|
|
156
130
|
}
|
|
157
|
-
|
|
158
131
|
debug() {
|
|
159
132
|
return this.log('debug', arguments);
|
|
160
133
|
}
|
|
161
|
-
|
|
162
134
|
silly() {
|
|
163
135
|
return this.log('silly', arguments);
|
|
164
136
|
}
|
|
165
|
-
|
|
166
137
|
logRequest({
|
|
167
138
|
method,
|
|
168
139
|
url,
|
|
@@ -179,7 +150,6 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
179
150
|
body
|
|
180
151
|
});
|
|
181
152
|
}
|
|
182
|
-
|
|
183
153
|
logResponse({
|
|
184
154
|
method,
|
|
185
155
|
url,
|
|
@@ -188,7 +158,9 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
188
158
|
this.verbose(() => {
|
|
189
159
|
const stringifiedResponse = JSON.stringify(result, null, 2);
|
|
190
160
|
return `RESPONSE from [${method}] ${url}: ${stringifiedResponse}`;
|
|
191
|
-
}, {
|
|
161
|
+
}, {
|
|
162
|
+
result: result
|
|
163
|
+
});
|
|
192
164
|
}
|
|
193
165
|
// check that date input is valid
|
|
194
166
|
static validDateTime(date) {
|
|
@@ -196,30 +168,24 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
196
168
|
return null;
|
|
197
169
|
}
|
|
198
170
|
date = new Date(date);
|
|
199
|
-
|
|
200
171
|
if (!isNaN(date.getTime())) {
|
|
201
172
|
return date;
|
|
202
173
|
}
|
|
203
|
-
|
|
204
174
|
return null;
|
|
205
175
|
}
|
|
206
|
-
|
|
207
176
|
truncateLogMessage(string) {
|
|
208
177
|
if (string && string.length > LOG_STRING_TRUNCATE_LENGTH) {
|
|
209
178
|
const truncated = string.substring(0, LOG_STRING_TRUNCATE_LENGTH) + truncationMarker;
|
|
210
179
|
return truncated;
|
|
211
180
|
}
|
|
212
|
-
|
|
213
181
|
return string;
|
|
214
182
|
}
|
|
215
|
-
|
|
216
183
|
static parseOptions(options = {}) {
|
|
217
184
|
const from = LoggerController.validDateTime(options.from) || new Date(Date.now() - 7 * MILLISECONDS_IN_A_DAY);
|
|
218
185
|
const until = LoggerController.validDateTime(options.until) || new Date();
|
|
219
186
|
const size = Number(options.size) || 10;
|
|
220
187
|
const order = options.order || LogOrder.DESCENDING;
|
|
221
188
|
const level = options.level || LogLevel.INFO;
|
|
222
|
-
|
|
223
189
|
return {
|
|
224
190
|
from,
|
|
225
191
|
until,
|
|
@@ -246,12 +212,10 @@ class LoggerController extends _AdaptableController2.default {
|
|
|
246
212
|
options = LoggerController.parseOptions(options);
|
|
247
213
|
return this.adapter.query(options);
|
|
248
214
|
}
|
|
249
|
-
|
|
250
215
|
expectedAdapterType() {
|
|
251
216
|
return _LoggerAdapter.LoggerAdapter;
|
|
252
217
|
}
|
|
253
218
|
}
|
|
254
|
-
|
|
255
219
|
exports.LoggerController = LoggerController;
|
|
256
|
-
exports.default = LoggerController;
|
|
257
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/LoggerController.js"],"names":["MILLISECONDS_IN_A_DAY","LOG_STRING_TRUNCATE_LENGTH","truncationMarker","LogLevel","INFO","ERROR","LogOrder","DESCENDING","ASCENDING","logLevels","LoggerController","AdaptableController","constructor","adapter","appId","options","logLevel","level","verbose","index","indexOf","forEach","levelIndex","maskSensitiveUrl","urlString","urlObj","url","parse","query","sanitizedQuery","key","slice","pathname","maskSensitive","argArray","map","e","replace","Array","isArray","item","body","Object","keys","params","log","args","concat","arg","apply","info","arguments","error","warn","debug","silly","logRequest","method","headers","stringifiedBody","JSON","stringify","logResponse","result","stringifiedResponse","validDateTime","date","Date","isNaN","getTime","truncateLogMessage","string","length","truncated","substring","parseOptions","from","now","until","size","Number","order","getLogs","Parse","Error","PUSH_MISCONFIGURED","expectedAdapterType","LoggerAdapter"],"mappings":"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","file":"LoggerController.js","sourcesContent":["import { Parse } from 'parse/node';\nimport AdaptableController from './AdaptableController';\nimport { LoggerAdapter } from '../Adapters/Logger/LoggerAdapter';\nimport url from 'url';\n\nconst MILLISECONDS_IN_A_DAY = 24 * 60 * 60 * 1000;\nconst LOG_STRING_TRUNCATE_LENGTH = 1000;\nconst truncationMarker = '... (truncated)';\n\nexport const LogLevel = {\n  INFO: 'info',\n  ERROR: 'error'\n}\n\nexport const LogOrder = {\n  DESCENDING: 'desc',\n  ASCENDING: 'asc'\n}\n\nconst logLevels = [\n  'error',\n  'warn',\n  'info',\n  'debug',\n  'verbose',\n  'silly',\n]\n\nexport class LoggerController extends AdaptableController {\n\n  constructor(adapter, appId, options = {logLevel: 'info'}) {\n    super(adapter, appId, options);\n    let level = 'info';\n    if (options.verbose) {\n      level = 'verbose';\n    }\n    if (options.logLevel) {\n      level = options.logLevel;\n    }\n    const index = logLevels.indexOf(level); // info by default\n    logLevels.forEach((level, levelIndex) => {\n      if (levelIndex > index) { // silence the levels that are > maxIndex\n        this[level] = () => {};\n      }\n    });\n  }\n\n  maskSensitiveUrl(urlString) {\n    const urlObj = url.parse(urlString, true);\n    const query = urlObj.query;\n    let sanitizedQuery = '?';\n\n    for(const key in query) {\n      if(key !== 'password') {\n        // normal value\n        sanitizedQuery += key + '=' + query[key] + '&';\n      } else {\n        // password value, redact it\n        sanitizedQuery += key + '=' + '********' + '&';\n      }\n    }\n\n    // trim last character, ? or &\n    sanitizedQuery = sanitizedQuery.slice(0, -1);\n\n    // return original path name with sanitized params attached\n    return urlObj.pathname + sanitizedQuery;\n  }\n\n  maskSensitive(argArray) {\n    return argArray.map(e => {\n      if (!e) {\n        return e;\n      }\n\n      if (typeof e === 'string') {\n        return e.replace(/(password\".?:.?\")[^\"]*\"/g, '$1********\"');\n      }\n      // else it is an object...\n\n      // check the url\n      if (e.url) {\n        // for strings\n        if (typeof e.url === 'string') {\n          e.url = this.maskSensitiveUrl(e.url);\n        } else if (Array.isArray(e.url)) { // for strings in array\n          e.url = e.url.map(item => {\n            if (typeof item === 'string') {\n              return this.maskSensitiveUrl(item);\n            }\n\n            return item;\n          });\n        }\n      }\n\n      if (e.body) {\n        for (const key of Object.keys(e.body)) {\n          if (key === 'password') {\n            e.body[key] = '********';\n            break;\n          }\n        }\n      }\n\n      if (e.params) {\n        for (const key of Object.keys(e.params)) {\n          if (key === 'password') {\n            e.params[key] = '********';\n            break;\n          }\n        }\n      }\n\n      return e;\n    });\n  }\n\n  log(level, args) {\n    // make the passed in arguments object an array with the spread operator\n    args = this.maskSensitive([...args]);\n    args = [].concat(level, args.map((arg) => {\n      if (typeof arg === 'function') { return arg(); }\n      return arg;\n    }));\n    this.adapter.log.apply(this.adapter, args);\n  }\n\n  info() {\n    return this.log('info', arguments);\n  }\n\n  error() {\n    return this.log('error', arguments);\n  }\n\n  warn() {\n    return this.log('warn', arguments);\n  }\n\n  verbose() {\n    return this.log('verbose', arguments);\n  }\n\n  debug() {\n    return this.log('debug', arguments);\n  }\n\n  silly() {\n    return this.log('silly', arguments);\n  }\n\n  logRequest({\n    method,\n    url,\n    headers,\n    body\n  }) {\n    this.verbose(() => {\n      const stringifiedBody = JSON.stringify(body, null, 2);\n      return `REQUEST for [${method}] ${url}: ${stringifiedBody}`;\n    }, {\n      method,\n      url,\n      headers,\n      body\n    });\n  }\n\n  logResponse({\n    method,\n    url,\n    result\n  }) {\n    this.verbose(\n      () => { const stringifiedResponse = JSON.stringify(result, null, 2);\n        return `RESPONSE from [${method}] ${url}: ${stringifiedResponse}`;\n      },\n      {result: result}\n    );\n  }\n  // check that date input is valid\n  static validDateTime(date) {\n    if (!date) {\n      return null;\n    }\n    date = new Date(date);\n\n    if (!isNaN(date.getTime())) {\n      return date;\n    }\n\n    return null;\n  }\n\n  truncateLogMessage(string) {\n    if (string && string.length > LOG_STRING_TRUNCATE_LENGTH) {\n      const truncated = string.substring(0, LOG_STRING_TRUNCATE_LENGTH) + truncationMarker;\n      return truncated;\n    }\n\n    return string;\n  }\n\n  static parseOptions(options = {}) {\n    const from = LoggerController.validDateTime(options.from) ||\n      new Date(Date.now() - 7 * MILLISECONDS_IN_A_DAY);\n    const until = LoggerController.validDateTime(options.until) || new Date();\n    const size = Number(options.size) || 10;\n    const order = options.order || LogOrder.DESCENDING;\n    const level = options.level || LogLevel.INFO;\n\n    return {\n      from,\n      until,\n      size,\n      order,\n      level,\n    };\n  }\n\n  // Returns a promise for a {response} object.\n  // query params:\n  // level (optional) Level of logging you want to query for (info || error)\n  // from (optional) Start time for the search. Defaults to 1 week ago.\n  // until (optional) End time for the search. Defaults to current time.\n  // order (optional) Direction of results returned, either “asc” or “desc”. Defaults to “desc”.\n  // size (optional) Number of rows returned by search. Defaults to 10\n  getLogs(options = {}) {\n    if (!this.adapter) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED,\n        'Logger adapter is not available');\n    }\n    if (typeof this.adapter.query !== 'function') {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED,\n        'Querying logs is not supported with this adapter');\n    }\n    options = LoggerController.parseOptions(options);\n    return this.adapter.query(options);\n  }\n\n  expectedAdapterType() {\n    return LoggerAdapter;\n  }\n}\n\nexport default LoggerController;\n"]}
|
|
220
|
+
var _default = exports.default = LoggerController;
|
|
221
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","require","_AdaptableController","_interopRequireDefault","_LoggerAdapter","e","__esModule","default","MILLISECONDS_IN_A_DAY","LOG_STRING_TRUNCATE_LENGTH","truncationMarker","LogLevel","exports","INFO","ERROR","LogOrder","DESCENDING","ASCENDING","logLevels","LoggerController","AdaptableController","constructor","adapter","appId","options","logLevel","level","verbose","index","indexOf","forEach","levelIndex","maskSensitiveUrl","path","urlString","urlObj","URL","query","searchParams","sanitizedQuery","key","value","slice","pathname","maskSensitive","argArray","map","replace","url","Array","isArray","item","body","Object","keys","params","log","args","concat","arg","apply","info","arguments","error","warn","debug","silly","logRequest","method","headers","stringifiedBody","JSON","stringify","logResponse","result","stringifiedResponse","validDateTime","date","Date","isNaN","getTime","truncateLogMessage","string","length","truncated","substring","parseOptions","from","now","until","size","Number","order","getLogs","Parse","Error","PUSH_MISCONFIGURED","expectedAdapterType","LoggerAdapter","_default"],"sources":["../../src/Controllers/LoggerController.js"],"sourcesContent":["import { Parse } from 'parse/node';\nimport AdaptableController from './AdaptableController';\nimport { LoggerAdapter } from '../Adapters/Logger/LoggerAdapter';\n\nconst MILLISECONDS_IN_A_DAY = 24 * 60 * 60 * 1000;\nconst LOG_STRING_TRUNCATE_LENGTH = 1000;\nconst truncationMarker = '... (truncated)';\n\nexport const LogLevel = {\n  INFO: 'info',\n  ERROR: 'error',\n};\n\nexport const LogOrder = {\n  DESCENDING: 'desc',\n  ASCENDING: 'asc',\n};\n\nexport const logLevels = ['error', 'warn', 'info', 'debug', 'verbose', 'silly', 'silent'];\n\nexport class LoggerController extends AdaptableController {\n  constructor(adapter, appId, options = { logLevel: 'info' }) {\n    super(adapter, appId, options);\n    let level = 'info';\n    if (options.verbose) {\n      level = 'verbose';\n    }\n    if (options.logLevel) {\n      level = options.logLevel;\n    }\n    const index = logLevels.indexOf(level); // info by default\n    logLevels.forEach((level, levelIndex) => {\n      if (levelIndex > index) {\n        // silence the levels that are > maxIndex\n        this[level] = () => {};\n      }\n    });\n  }\n\n  maskSensitiveUrl(path) {\n    const urlString = 'http://localhost' + path; // prepend dummy string to make a real URL\n    const urlObj = new URL(urlString);\n    const query = urlObj.searchParams;\n    let sanitizedQuery = '?';\n\n    for (const [key, value] of query) {\n      if (key !== 'password') {\n        // normal value\n        sanitizedQuery += key + '=' + value + '&';\n      } else {\n        // password value, redact it\n        sanitizedQuery += key + '=' + '********' + '&';\n      }\n    }\n\n    // trim last character, ? or &\n    sanitizedQuery = sanitizedQuery.slice(0, -1);\n\n    // return original path name with sanitized params attached\n    return urlObj.pathname + sanitizedQuery;\n  }\n\n  maskSensitive(argArray) {\n    return argArray.map(e => {\n      if (!e) {\n        return e;\n      }\n\n      if (typeof e === 'string') {\n        return e.replace(/(password\".?:.?\")[^\"]*\"/g, '$1********\"');\n      }\n      // else it is an object...\n\n      // check the url\n      if (e.url) {\n        // for strings\n        if (typeof e.url === 'string') {\n          e.url = this.maskSensitiveUrl(e.url);\n        } else if (Array.isArray(e.url)) {\n          // for strings in array\n          e.url = e.url.map(item => {\n            if (typeof item === 'string') {\n              return this.maskSensitiveUrl(item);\n            }\n\n            return item;\n          });\n        }\n      }\n\n      if (e.body) {\n        for (const key of Object.keys(e.body)) {\n          if (key === 'password') {\n            e.body[key] = '********';\n            break;\n          }\n        }\n      }\n\n      if (e.params) {\n        for (const key of Object.keys(e.params)) {\n          if (key === 'password') {\n            e.params[key] = '********';\n            break;\n          }\n        }\n      }\n\n      return e;\n    });\n  }\n\n  log(level, args) {\n    // make the passed in arguments object an array with the spread operator\n    args = this.maskSensitive([...args]);\n    args = [].concat(\n      level,\n      args.map(arg => {\n        if (typeof arg === 'function') {\n          return arg();\n        }\n        return arg;\n      })\n    );\n    this.adapter.log.apply(this.adapter, args);\n  }\n\n  info() {\n    return this.log('info', arguments);\n  }\n\n  error() {\n    return this.log('error', arguments);\n  }\n\n  warn() {\n    return this.log('warn', arguments);\n  }\n\n  verbose() {\n    return this.log('verbose', arguments);\n  }\n\n  debug() {\n    return this.log('debug', arguments);\n  }\n\n  silly() {\n    return this.log('silly', arguments);\n  }\n\n  logRequest({ method, url, headers, body }) {\n    this.verbose(\n      () => {\n        const stringifiedBody = JSON.stringify(body, null, 2);\n        return `REQUEST for [${method}] ${url}: ${stringifiedBody}`;\n      },\n      {\n        method,\n        url,\n        headers,\n        body,\n      }\n    );\n  }\n\n  logResponse({ method, url, result }) {\n    this.verbose(\n      () => {\n        const stringifiedResponse = JSON.stringify(result, null, 2);\n        return `RESPONSE from [${method}] ${url}: ${stringifiedResponse}`;\n      },\n      { result: result }\n    );\n  }\n  // check that date input is valid\n  static validDateTime(date) {\n    if (!date) {\n      return null;\n    }\n    date = new Date(date);\n\n    if (!isNaN(date.getTime())) {\n      return date;\n    }\n\n    return null;\n  }\n\n  truncateLogMessage(string) {\n    if (string && string.length > LOG_STRING_TRUNCATE_LENGTH) {\n      const truncated = string.substring(0, LOG_STRING_TRUNCATE_LENGTH) + truncationMarker;\n      return truncated;\n    }\n\n    return string;\n  }\n\n  static parseOptions(options = {}) {\n    const from =\n      LoggerController.validDateTime(options.from) ||\n      new Date(Date.now() - 7 * MILLISECONDS_IN_A_DAY);\n    const until = LoggerController.validDateTime(options.until) || new Date();\n    const size = Number(options.size) || 10;\n    const order = options.order || LogOrder.DESCENDING;\n    const level = options.level || LogLevel.INFO;\n\n    return {\n      from,\n      until,\n      size,\n      order,\n      level,\n    };\n  }\n\n  // Returns a promise for a {response} object.\n  // query params:\n  // level (optional) Level of logging you want to query for (info || error)\n  // from (optional) Start time for the search. Defaults to 1 week ago.\n  // until (optional) End time for the search. Defaults to current time.\n  // order (optional) Direction of results returned, either “asc” or “desc”. Defaults to “desc”.\n  // size (optional) Number of rows returned by search. Defaults to 10\n  getLogs(options = {}) {\n    if (!this.adapter) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Logger adapter is not available');\n    }\n    if (typeof this.adapter.query !== 'function') {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Querying logs is not supported with this adapter'\n      );\n    }\n    options = LoggerController.parseOptions(options);\n    return this.adapter.query(options);\n  }\n\n  expectedAdapterType() {\n    return LoggerAdapter;\n  }\n}\n\nexport default LoggerController;\n"],"mappings":"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","ignoreList":[]}
|