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.
Files changed (240) hide show
  1. package/LICENSE +167 -25
  2. package/NOTICE +10 -0
  3. package/README.md +929 -278
  4. package/lib/AccountLockout.js +47 -30
  5. package/lib/Adapters/AdapterLoader.js +21 -6
  6. package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
  7. package/lib/Adapters/Auth/AuthAdapter.js +116 -13
  8. package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
  9. package/lib/Adapters/Auth/OAuth1Client.js +27 -46
  10. package/lib/Adapters/Auth/apple.js +123 -0
  11. package/lib/Adapters/Auth/facebook.js +162 -35
  12. package/lib/Adapters/Auth/gcenter.js +217 -0
  13. package/lib/Adapters/Auth/github.js +118 -48
  14. package/lib/Adapters/Auth/google.js +160 -51
  15. package/lib/Adapters/Auth/gpgames.js +125 -0
  16. package/lib/Adapters/Auth/httpsRequest.js +6 -7
  17. package/lib/Adapters/Auth/index.js +170 -62
  18. package/lib/Adapters/Auth/instagram.js +114 -40
  19. package/lib/Adapters/Auth/janraincapture.js +52 -23
  20. package/lib/Adapters/Auth/janrainengage.js +19 -36
  21. package/lib/Adapters/Auth/keycloak.js +148 -0
  22. package/lib/Adapters/Auth/ldap.js +167 -0
  23. package/lib/Adapters/Auth/line.js +125 -0
  24. package/lib/Adapters/Auth/linkedin.js +111 -55
  25. package/lib/Adapters/Auth/meetup.js +24 -34
  26. package/lib/Adapters/Auth/mfa.js +324 -0
  27. package/lib/Adapters/Auth/microsoft.js +111 -0
  28. package/lib/Adapters/Auth/oauth2.js +97 -162
  29. package/lib/Adapters/Auth/phantauth.js +53 -0
  30. package/lib/Adapters/Auth/qq.js +108 -49
  31. package/lib/Adapters/Auth/spotify.js +107 -55
  32. package/lib/Adapters/Auth/twitter.js +188 -48
  33. package/lib/Adapters/Auth/utils.js +28 -0
  34. package/lib/Adapters/Auth/vkontakte.js +26 -39
  35. package/lib/Adapters/Auth/wechat.js +106 -44
  36. package/lib/Adapters/Auth/weibo.js +132 -58
  37. package/lib/Adapters/Cache/CacheAdapter.js +13 -8
  38. package/lib/Adapters/Cache/InMemoryCache.js +3 -13
  39. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
  40. package/lib/Adapters/Cache/LRUCache.js +13 -27
  41. package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
  42. package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
  43. package/lib/Adapters/Cache/SchemaCache.js +25 -0
  44. package/lib/Adapters/Email/MailAdapter.js +10 -8
  45. package/lib/Adapters/Files/FilesAdapter.js +83 -25
  46. package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
  47. package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
  48. package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
  49. package/lib/Adapters/Logger/WinstonLogger.js +69 -88
  50. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
  51. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
  52. package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
  53. package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
  54. package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
  55. package/lib/Adapters/Push/PushAdapter.js +14 -7
  56. package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
  57. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
  58. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
  59. package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
  60. package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
  61. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
  62. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
  63. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
  64. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  65. package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
  66. package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
  67. package/lib/Auth.js +488 -125
  68. package/lib/ClientSDK.js +2 -6
  69. package/lib/Config.js +525 -94
  70. package/lib/Controllers/AdaptableController.js +5 -25
  71. package/lib/Controllers/AnalyticsController.js +22 -23
  72. package/lib/Controllers/CacheController.js +10 -31
  73. package/lib/Controllers/DatabaseController.js +767 -313
  74. package/lib/Controllers/FilesController.js +49 -54
  75. package/lib/Controllers/HooksController.js +80 -84
  76. package/lib/Controllers/LiveQueryController.js +35 -22
  77. package/lib/Controllers/LoggerController.js +22 -58
  78. package/lib/Controllers/ParseGraphQLController.js +293 -0
  79. package/lib/Controllers/PushController.js +58 -49
  80. package/lib/Controllers/SchemaController.js +916 -422
  81. package/lib/Controllers/UserController.js +265 -180
  82. package/lib/Controllers/index.js +90 -125
  83. package/lib/Controllers/types.js +1 -1
  84. package/lib/Deprecator/Deprecations.js +30 -0
  85. package/lib/Deprecator/Deprecator.js +127 -0
  86. package/lib/Error.js +48 -0
  87. package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
  88. package/lib/GraphQL/ParseGraphQLServer.js +214 -0
  89. package/lib/GraphQL/helpers/objectsMutations.js +30 -0
  90. package/lib/GraphQL/helpers/objectsQueries.js +246 -0
  91. package/lib/GraphQL/loaders/configMutations.js +87 -0
  92. package/lib/GraphQL/loaders/configQueries.js +79 -0
  93. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
  94. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
  95. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
  96. package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
  97. package/lib/GraphQL/loaders/filesMutations.js +107 -0
  98. package/lib/GraphQL/loaders/functionsMutations.js +78 -0
  99. package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
  100. package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
  101. package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
  102. package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
  103. package/lib/GraphQL/loaders/schemaMutations.js +162 -0
  104. package/lib/GraphQL/loaders/schemaQueries.js +81 -0
  105. package/lib/GraphQL/loaders/schemaTypes.js +341 -0
  106. package/lib/GraphQL/loaders/usersMutations.js +433 -0
  107. package/lib/GraphQL/loaders/usersQueries.js +90 -0
  108. package/lib/GraphQL/parseGraphQLUtils.js +63 -0
  109. package/lib/GraphQL/transformers/className.js +14 -0
  110. package/lib/GraphQL/transformers/constraintType.js +53 -0
  111. package/lib/GraphQL/transformers/inputType.js +51 -0
  112. package/lib/GraphQL/transformers/mutation.js +274 -0
  113. package/lib/GraphQL/transformers/outputType.js +51 -0
  114. package/lib/GraphQL/transformers/query.js +237 -0
  115. package/lib/GraphQL/transformers/schemaFields.js +99 -0
  116. package/lib/KeyPromiseQueue.js +48 -0
  117. package/lib/LiveQuery/Client.js +25 -33
  118. package/lib/LiveQuery/Id.js +2 -5
  119. package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
  120. package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
  121. package/lib/LiveQuery/ParsePubSub.js +7 -16
  122. package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
  123. package/lib/LiveQuery/QueryTools.js +76 -15
  124. package/lib/LiveQuery/RequestSchema.js +111 -97
  125. package/lib/LiveQuery/SessionTokenCache.js +23 -36
  126. package/lib/LiveQuery/Subscription.js +8 -17
  127. package/lib/LiveQuery/equalObjects.js +2 -3
  128. package/lib/Options/Definitions.js +1355 -382
  129. package/lib/Options/docs.js +301 -62
  130. package/lib/Options/index.js +11 -1
  131. package/lib/Options/parsers.js +14 -10
  132. package/lib/Page.js +44 -0
  133. package/lib/ParseMessageQueue.js +6 -13
  134. package/lib/ParseServer.js +474 -235
  135. package/lib/ParseServerRESTController.js +102 -40
  136. package/lib/PromiseRouter.js +39 -50
  137. package/lib/Push/PushQueue.js +24 -30
  138. package/lib/Push/PushWorker.js +32 -56
  139. package/lib/Push/utils.js +22 -35
  140. package/lib/RestQuery.js +361 -139
  141. package/lib/RestWrite.js +713 -344
  142. package/lib/Routers/AggregateRouter.js +97 -71
  143. package/lib/Routers/AnalyticsRouter.js +8 -14
  144. package/lib/Routers/AudiencesRouter.js +16 -35
  145. package/lib/Routers/ClassesRouter.js +86 -72
  146. package/lib/Routers/CloudCodeRouter.js +28 -37
  147. package/lib/Routers/FeaturesRouter.js +22 -25
  148. package/lib/Routers/FilesRouter.js +266 -171
  149. package/lib/Routers/FunctionsRouter.js +87 -103
  150. package/lib/Routers/GlobalConfigRouter.js +94 -33
  151. package/lib/Routers/GraphQLRouter.js +41 -0
  152. package/lib/Routers/HooksRouter.js +43 -47
  153. package/lib/Routers/IAPValidationRouter.js +57 -70
  154. package/lib/Routers/InstallationsRouter.js +17 -25
  155. package/lib/Routers/LogsRouter.js +10 -25
  156. package/lib/Routers/PagesRouter.js +647 -0
  157. package/lib/Routers/PublicAPIRouter.js +104 -112
  158. package/lib/Routers/PurgeRouter.js +19 -29
  159. package/lib/Routers/PushRouter.js +14 -28
  160. package/lib/Routers/RolesRouter.js +7 -14
  161. package/lib/Routers/SchemasRouter.js +63 -42
  162. package/lib/Routers/SecurityRouter.js +34 -0
  163. package/lib/Routers/SessionsRouter.js +25 -38
  164. package/lib/Routers/UsersRouter.js +463 -190
  165. package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
  166. package/lib/SchemaMigrations/Migrations.js +30 -0
  167. package/lib/Security/Check.js +109 -0
  168. package/lib/Security/CheckGroup.js +44 -0
  169. package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
  170. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
  171. package/lib/Security/CheckGroups/CheckGroups.js +21 -0
  172. package/lib/Security/CheckRunner.js +213 -0
  173. package/lib/SharedRest.js +29 -0
  174. package/lib/StatusHandler.js +96 -93
  175. package/lib/TestUtils.js +70 -14
  176. package/lib/Utils.js +468 -0
  177. package/lib/batch.js +74 -40
  178. package/lib/cache.js +8 -8
  179. package/lib/cli/definitions/parse-live-query-server.js +4 -3
  180. package/lib/cli/definitions/parse-server.js +4 -3
  181. package/lib/cli/parse-live-query-server.js +9 -17
  182. package/lib/cli/parse-server.js +49 -47
  183. package/lib/cli/utils/commander.js +20 -29
  184. package/lib/cli/utils/runner.js +31 -32
  185. package/lib/cloud-code/Parse.Cloud.js +711 -36
  186. package/lib/cloud-code/Parse.Server.js +21 -0
  187. package/lib/cryptoUtils.js +6 -11
  188. package/lib/defaults.js +21 -15
  189. package/lib/deprecated.js +1 -1
  190. package/lib/index.js +78 -67
  191. package/lib/logger.js +12 -20
  192. package/lib/middlewares.js +484 -160
  193. package/lib/password.js +10 -6
  194. package/lib/request.js +175 -0
  195. package/lib/requiredParameter.js +4 -3
  196. package/lib/rest.js +157 -82
  197. package/lib/triggers.js +627 -185
  198. package/lib/vendor/README.md +3 -3
  199. package/lib/vendor/mongodbUrl.js +224 -137
  200. package/package.json +135 -57
  201. package/postinstall.js +38 -50
  202. package/public_html/invalid_verification_link.html +3 -3
  203. package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
  204. package/types/@types/deepcopy/index.d.ts +5 -0
  205. package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
  206. package/types/Options/index.d.ts +301 -0
  207. package/types/ParseServer.d.ts +65 -0
  208. package/types/eslint.config.mjs +30 -0
  209. package/types/index.d.ts +21 -0
  210. package/types/logger.d.ts +2 -0
  211. package/types/tests.ts +44 -0
  212. package/types/tsconfig.json +24 -0
  213. package/CHANGELOG.md +0 -1246
  214. package/PATENTS +0 -37
  215. package/bin/dev +0 -37
  216. package/lib/.DS_Store +0 -0
  217. package/lib/Adapters/Auth/common.js +0 -2
  218. package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
  219. package/lib/Controllers/SchemaCache.js +0 -97
  220. package/lib/LiveQuery/.DS_Store +0 -0
  221. package/lib/cli/utils/parsers.js +0 -77
  222. package/lib/cloud-code/.DS_Store +0 -0
  223. package/lib/cloud-code/HTTPResponse.js +0 -57
  224. package/lib/cloud-code/Untitled-1 +0 -123
  225. package/lib/cloud-code/httpRequest.js +0 -102
  226. package/lib/cloud-code/team.html +0 -123
  227. package/lib/graphql/ParseClass.js +0 -234
  228. package/lib/graphql/Schema.js +0 -197
  229. package/lib/graphql/index.js +0 -1
  230. package/lib/graphql/types/ACL.js +0 -35
  231. package/lib/graphql/types/Date.js +0 -25
  232. package/lib/graphql/types/File.js +0 -24
  233. package/lib/graphql/types/GeoPoint.js +0 -35
  234. package/lib/graphql/types/JSONObject.js +0 -30
  235. package/lib/graphql/types/NumberInput.js +0 -43
  236. package/lib/graphql/types/NumberQuery.js +0 -42
  237. package/lib/graphql/types/Pointer.js +0 -35
  238. package/lib/graphql/types/QueryConstraint.js +0 -61
  239. package/lib/graphql/types/StringQuery.js +0 -39
  240. package/lib/graphql/types/index.js +0 -110
@@ -1,59 +1,72 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.LiveQueryController = undefined;
7
-
8
- var _ParseCloudCodePublisher = require('../LiveQuery/ParseCloudCodePublisher');
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
- this.classNames = new Set(config.classNames);
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
- onAfterSave(className, currentObject, originalObject) {
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
- return this.classNames.has(className);
44
+ for (const name of this.classNames) {
45
+ if (name.test(className)) {
46
+ return true;
47
+ }
48
+ }
49
+ return false;
44
50
  }
45
-
46
- _makePublisherRequest(currentObject, originalObject) {
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Db250cm9sbGVycy9MaXZlUXVlcnlDb250cm9sbGVyLmpzIl0sIm5hbWVzIjpbIkxpdmVRdWVyeUNvbnRyb2xsZXIiLCJjb25zdHJ1Y3RvciIsImNvbmZpZyIsImNsYXNzTmFtZXMiLCJTZXQiLCJBcnJheSIsImxpdmVRdWVyeVB1Ymxpc2hlciIsIlBhcnNlQ2xvdWRDb2RlUHVibGlzaGVyIiwib25BZnRlclNhdmUiLCJjbGFzc05hbWUiLCJjdXJyZW50T2JqZWN0Iiwib3JpZ2luYWxPYmplY3QiLCJoYXNMaXZlUXVlcnkiLCJyZXEiLCJfbWFrZVB1Ymxpc2hlclJlcXVlc3QiLCJvbkNsb3VkQ29kZUFmdGVyU2F2ZSIsIm9uQWZ0ZXJEZWxldGUiLCJvbkNsb3VkQ29kZUFmdGVyRGVsZXRlIiwiaGFzIiwib2JqZWN0Iiwib3JpZ2luYWwiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDTyxNQUFNQSxtQkFBTixDQUEwQjs7QUFJL0JDLGNBQVlDLE1BQVosRUFBdUM7QUFDckM7QUFDQSxRQUFJLENBQUNBLE1BQUQsSUFBVyxDQUFDQSxPQUFPQyxVQUF2QixFQUFtQztBQUNqQyxXQUFLQSxVQUFMLEdBQWtCLElBQUlDLEdBQUosRUFBbEI7QUFDRCxLQUZELE1BRU8sSUFBSUYsT0FBT0MsVUFBUCxZQUE2QkUsS0FBakMsRUFBd0M7QUFDN0MsV0FBS0YsVUFBTCxHQUFrQixJQUFJQyxHQUFKLENBQVFGLE9BQU9DLFVBQWYsQ0FBbEI7QUFDRCxLQUZNLE1BRUE7QUFDTCxZQUFNLGdEQUFOO0FBQ0Q7QUFDRCxTQUFLRyxrQkFBTCxHQUEwQixJQUFJQyxnREFBSixDQUE0QkwsTUFBNUIsQ0FBMUI7QUFDRDs7QUFFRE0sY0FBWUMsU0FBWixFQUErQkMsYUFBL0IsRUFBbURDLGNBQW5ELEVBQXdFO0FBQ3RFLFFBQUksQ0FBQyxLQUFLQyxZQUFMLENBQWtCSCxTQUFsQixDQUFMLEVBQW1DO0FBQ2pDO0FBQ0Q7QUFDRCxVQUFNSSxNQUFNLEtBQUtDLHFCQUFMLENBQTJCSixhQUEzQixFQUEwQ0MsY0FBMUMsQ0FBWjtBQUNBLFNBQUtMLGtCQUFMLENBQXdCUyxvQkFBeEIsQ0FBNkNGLEdBQTdDO0FBQ0Q7O0FBRURHLGdCQUFjUCxTQUFkLEVBQWlDQyxhQUFqQyxFQUFxREMsY0FBckQsRUFBMEU7QUFDeEUsUUFBSSxDQUFDLEtBQUtDLFlBQUwsQ0FBa0JILFNBQWxCLENBQUwsRUFBbUM7QUFDakM7QUFDRDtBQUNELFVBQU1JLE1BQU0sS0FBS0MscUJBQUwsQ0FBMkJKLGFBQTNCLEVBQTBDQyxjQUExQyxDQUFaO0FBQ0EsU0FBS0wsa0JBQUwsQ0FBd0JXLHNCQUF4QixDQUErQ0osR0FBL0M7QUFDRDs7QUFFREQsZUFBYUgsU0FBYixFQUF5QztBQUN2QyxXQUFPLEtBQUtOLFVBQUwsQ0FBZ0JlLEdBQWhCLENBQW9CVCxTQUFwQixDQUFQO0FBQ0Q7O0FBRURLLHdCQUFzQkosYUFBdEIsRUFBMENDLGNBQTFDLEVBQW9FO0FBQ2xFLFVBQU1FLE1BQU07QUFDVk0sY0FBUVQ7QUFERSxLQUFaO0FBR0EsUUFBSUEsYUFBSixFQUFtQjtBQUNqQkcsVUFBSU8sUUFBSixHQUFlVCxjQUFmO0FBQ0Q7QUFDRCxXQUFPRSxHQUFQO0FBQ0Q7QUE1QzhCOztRQUFwQmIsbUIsR0FBQUEsbUI7a0JBK0NFQSxtQiIsImZpbGUiOiJMaXZlUXVlcnlDb250cm9sbGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGFyc2VDbG91ZENvZGVQdWJsaXNoZXIgfSBmcm9tICcuLi9MaXZlUXVlcnkvUGFyc2VDbG91ZENvZGVQdWJsaXNoZXInO1xuaW1wb3J0IHsgTGl2ZVF1ZXJ5T3B0aW9ucyB9IGZyb20gJy4uL09wdGlvbnMnO1xuZXhwb3J0IGNsYXNzIExpdmVRdWVyeUNvbnRyb2xsZXIge1xuICBjbGFzc05hbWVzOiBhbnk7XG4gIGxpdmVRdWVyeVB1Ymxpc2hlcjogYW55O1xuXG4gIGNvbnN0cnVjdG9yKGNvbmZpZzogP0xpdmVRdWVyeU9wdGlvbnMpIHtcbiAgICAvLyBJZiBjb25maWcgaXMgZW1wdHksIHdlIGp1c3QgYXNzdW1lIG5vIGNsYXNzcyBuZWVkcyB0byBiZSByZWdpc3RlcmVkIGFzIExpdmVRdWVyeVxuICAgIGlmICghY29uZmlnIHx8ICFjb25maWcuY2xhc3NOYW1lcykge1xuICAgICAgdGhpcy5jbGFzc05hbWVzID0gbmV3IFNldCgpO1xuICAgIH0gZWxzZSBpZiAoY29uZmlnLmNsYXNzTmFtZXMgaW5zdGFuY2VvZiBBcnJheSkge1xuICAgICAgdGhpcy5jbGFzc05hbWVzID0gbmV3IFNldChjb25maWcuY2xhc3NOYW1lcyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93ICdsaXZlUXVlcnkuY2xhc3NlcyBzaG91bGQgYmUgYW4gYXJyYXkgb2Ygc3RyaW5nJ1xuICAgIH1cbiAgICB0aGlzLmxpdmVRdWVyeVB1Ymxpc2hlciA9IG5ldyBQYXJzZUNsb3VkQ29kZVB1Ymxpc2hlcihjb25maWcpO1xuICB9XG5cbiAgb25BZnRlclNhdmUoY2xhc3NOYW1lOiBzdHJpbmcsIGN1cnJlbnRPYmplY3Q6IGFueSwgb3JpZ2luYWxPYmplY3Q6IGFueSkge1xuICAgIGlmICghdGhpcy5oYXNMaXZlUXVlcnkoY2xhc3NOYW1lKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBjb25zdCByZXEgPSB0aGlzLl9tYWtlUHVibGlzaGVyUmVxdWVzdChjdXJyZW50T2JqZWN0LCBvcmlnaW5hbE9iamVjdCk7XG4gICAgdGhpcy5saXZlUXVlcnlQdWJsaXNoZXIub25DbG91ZENvZGVBZnRlclNhdmUocmVxKTtcbiAgfVxuXG4gIG9uQWZ0ZXJEZWxldGUoY2xhc3NOYW1lOiBzdHJpbmcsIGN1cnJlbnRPYmplY3Q6IGFueSwgb3JpZ2luYWxPYmplY3Q6IGFueSkge1xuICAgIGlmICghdGhpcy5oYXNMaXZlUXVlcnkoY2xhc3NOYW1lKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBjb25zdCByZXEgPSB0aGlzLl9tYWtlUHVibGlzaGVyUmVxdWVzdChjdXJyZW50T2JqZWN0LCBvcmlnaW5hbE9iamVjdCk7XG4gICAgdGhpcy5saXZlUXVlcnlQdWJsaXNoZXIub25DbG91ZENvZGVBZnRlckRlbGV0ZShyZXEpO1xuICB9XG5cbiAgaGFzTGl2ZVF1ZXJ5KGNsYXNzTmFtZTogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuY2xhc3NOYW1lcy5oYXMoY2xhc3NOYW1lKTtcbiAgfVxuXG4gIF9tYWtlUHVibGlzaGVyUmVxdWVzdChjdXJyZW50T2JqZWN0OiBhbnksIG9yaWdpbmFsT2JqZWN0OiBhbnkpOiBhbnkge1xuICAgIGNvbnN0IHJlcSA9IHtcbiAgICAgIG9iamVjdDogY3VycmVudE9iamVjdFxuICAgIH07XG4gICAgaWYgKGN1cnJlbnRPYmplY3QpIHtcbiAgICAgIHJlcS5vcmlnaW5hbCA9IG9yaWdpbmFsT2JqZWN0O1xuICAgIH1cbiAgICByZXR1cm4gcmVxO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IExpdmVRdWVyeUNvbnRyb2xsZXI7XG4iXX0=
71
+ var _default = exports.default = LiveQueryController;
72
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfUGFyc2VDbG91ZENvZGVQdWJsaXNoZXIiLCJyZXF1aXJlIiwiX09wdGlvbnMiLCJfdHJpZ2dlcnMiLCJMaXZlUXVlcnlDb250cm9sbGVyIiwiY29uc3RydWN0b3IiLCJjb25maWciLCJjbGFzc05hbWVzIiwiU2V0IiwiQXJyYXkiLCJtYXAiLCJuYW1lIiwiX25hbWUiLCJnZXRDbGFzc05hbWUiLCJSZWdFeHAiLCJsaXZlUXVlcnlQdWJsaXNoZXIiLCJQYXJzZUNsb3VkQ29kZVB1Ymxpc2hlciIsImNvbm5lY3QiLCJvbkFmdGVyU2F2ZSIsImNsYXNzTmFtZSIsImN1cnJlbnRPYmplY3QiLCJvcmlnaW5hbE9iamVjdCIsImNsYXNzTGV2ZWxQZXJtaXNzaW9ucyIsImhhc0xpdmVRdWVyeSIsInJlcSIsIl9tYWtlUHVibGlzaGVyUmVxdWVzdCIsIm9uQ2xvdWRDb2RlQWZ0ZXJTYXZlIiwib25BZnRlckRlbGV0ZSIsIm9uQ2xvdWRDb2RlQWZ0ZXJEZWxldGUiLCJ0ZXN0IiwiY2xlYXJDYWNoZWRSb2xlcyIsInVzZXIiLCJvbkNsZWFyQ2FjaGVkUm9sZXMiLCJvYmplY3QiLCJvcmlnaW5hbCIsImV4cG9ydHMiLCJfZGVmYXVsdCIsImRlZmF1bHQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvQ29udHJvbGxlcnMvTGl2ZVF1ZXJ5Q29udHJvbGxlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQYXJzZUNsb3VkQ29kZVB1Ymxpc2hlciB9IGZyb20gJy4uL0xpdmVRdWVyeS9QYXJzZUNsb3VkQ29kZVB1Ymxpc2hlcic7XG5pbXBvcnQgeyBMaXZlUXVlcnlPcHRpb25zIH0gZnJvbSAnLi4vT3B0aW9ucyc7XG5pbXBvcnQgeyBnZXRDbGFzc05hbWUgfSBmcm9tICcuLy4uL3RyaWdnZXJzJztcbmV4cG9ydCBjbGFzcyBMaXZlUXVlcnlDb250cm9sbGVyIHtcbiAgY2xhc3NOYW1lczogYW55O1xuICBsaXZlUXVlcnlQdWJsaXNoZXI6IGFueTtcblxuICBjb25zdHJ1Y3Rvcihjb25maWc6ID9MaXZlUXVlcnlPcHRpb25zKSB7XG4gICAgLy8gSWYgY29uZmlnIGlzIGVtcHR5LCB3ZSBqdXN0IGFzc3VtZSBubyBjbGFzc3MgbmVlZHMgdG8gYmUgcmVnaXN0ZXJlZCBhcyBMaXZlUXVlcnlcbiAgICBpZiAoIWNvbmZpZyB8fCAhY29uZmlnLmNsYXNzTmFtZXMpIHtcbiAgICAgIHRoaXMuY2xhc3NOYW1lcyA9IG5ldyBTZXQoKTtcbiAgICB9IGVsc2UgaWYgKGNvbmZpZy5jbGFzc05hbWVzIGluc3RhbmNlb2YgQXJyYXkpIHtcbiAgICAgIGNvbnN0IGNsYXNzTmFtZXMgPSBjb25maWcuY2xhc3NOYW1lcy5tYXAobmFtZSA9PiB7XG4gICAgICAgIGNvbnN0IF9uYW1lID0gZ2V0Q2xhc3NOYW1lKG5hbWUpO1xuICAgICAgICByZXR1cm4gbmV3IFJlZ0V4cChgXiR7X25hbWV9JGApO1xuICAgICAgfSk7XG4gICAgICB0aGlzLmNsYXNzTmFtZXMgPSBuZXcgU2V0KGNsYXNzTmFtZXMpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyAnbGl2ZVF1ZXJ5LmNsYXNzZXMgc2hvdWxkIGJlIGFuIGFycmF5IG9mIHN0cmluZyc7XG4gICAgfVxuICAgIHRoaXMubGl2ZVF1ZXJ5UHVibGlzaGVyID0gbmV3IFBhcnNlQ2xvdWRDb2RlUHVibGlzaGVyKGNvbmZpZyk7XG4gIH1cblxuICBjb25uZWN0KCkge1xuICAgIHJldHVybiB0aGlzLmxpdmVRdWVyeVB1Ymxpc2hlci5jb25uZWN0KCk7XG4gIH1cblxuICBvbkFmdGVyU2F2ZShcbiAgICBjbGFzc05hbWU6IHN0cmluZyxcbiAgICBjdXJyZW50T2JqZWN0OiBhbnksXG4gICAgb3JpZ2luYWxPYmplY3Q6IGFueSxcbiAgICBjbGFzc0xldmVsUGVybWlzc2lvbnM6ID9hbnlcbiAgKSB7XG4gICAgaWYgKCF0aGlzLmhhc0xpdmVRdWVyeShjbGFzc05hbWUpKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGNvbnN0IHJlcSA9IHRoaXMuX21ha2VQdWJsaXNoZXJSZXF1ZXN0KGN1cnJlbnRPYmplY3QsIG9yaWdpbmFsT2JqZWN0LCBjbGFzc0xldmVsUGVybWlzc2lvbnMpO1xuICAgIHRoaXMubGl2ZVF1ZXJ5UHVibGlzaGVyLm9uQ2xvdWRDb2RlQWZ0ZXJTYXZlKHJlcSk7XG4gIH1cblxuICBvbkFmdGVyRGVsZXRlKFxuICAgIGNsYXNzTmFtZTogc3RyaW5nLFxuICAgIGN1cnJlbnRPYmplY3Q6IGFueSxcbiAgICBvcmlnaW5hbE9iamVjdDogYW55LFxuICAgIGNsYXNzTGV2ZWxQZXJtaXNzaW9uczogYW55XG4gICkge1xuICAgIGlmICghdGhpcy5oYXNMaXZlUXVlcnkoY2xhc3NOYW1lKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBjb25zdCByZXEgPSB0aGlzLl9tYWtlUHVibGlzaGVyUmVxdWVzdChjdXJyZW50T2JqZWN0LCBvcmlnaW5hbE9iamVjdCwgY2xhc3NMZXZlbFBlcm1pc3Npb25zKTtcbiAgICB0aGlzLmxpdmVRdWVyeVB1Ymxpc2hlci5vbkNsb3VkQ29kZUFmdGVyRGVsZXRlKHJlcSk7XG4gIH1cblxuICBoYXNMaXZlUXVlcnkoY2xhc3NOYW1lOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICBmb3IgKGNvbnN0IG5hbWUgb2YgdGhpcy5jbGFzc05hbWVzKSB7XG4gICAgICBpZiAobmFtZS50ZXN0KGNsYXNzTmFtZSkpIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGNsZWFyQ2FjaGVkUm9sZXModXNlcjogYW55KSB7XG4gICAgaWYgKCF1c2VyKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHJldHVybiB0aGlzLmxpdmVRdWVyeVB1Ymxpc2hlci5vbkNsZWFyQ2FjaGVkUm9sZXModXNlcik7XG4gIH1cblxuICBfbWFrZVB1Ymxpc2hlclJlcXVlc3QoY3VycmVudE9iamVjdDogYW55LCBvcmlnaW5hbE9iamVjdDogYW55LCBjbGFzc0xldmVsUGVybWlzc2lvbnM6ID9hbnkpOiBhbnkge1xuICAgIGNvbnN0IHJlcSA9IHtcbiAgICAgIG9iamVjdDogY3VycmVudE9iamVjdCxcbiAgICB9O1xuICAgIGlmIChjdXJyZW50T2JqZWN0KSB7XG4gICAgICByZXEub3JpZ2luYWwgPSBvcmlnaW5hbE9iamVjdDtcbiAgICB9XG4gICAgaWYgKGNsYXNzTGV2ZWxQZXJtaXNzaW9ucykge1xuICAgICAgcmVxLmNsYXNzTGV2ZWxQZXJtaXNzaW9ucyA9IGNsYXNzTGV2ZWxQZXJtaXNzaW9ucztcbiAgICB9XG4gICAgcmV0dXJuIHJlcTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBMaXZlUXVlcnlDb250cm9sbGVyO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSx3QkFBQSxHQUFBQyxPQUFBO0FBQ0EsSUFBQUMsUUFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsU0FBQSxHQUFBRixPQUFBO0FBQ08sTUFBTUcsbUJBQW1CLENBQUM7RUFJL0JDLFdBQVdBLENBQUNDLE1BQXlCLEVBQUU7SUFDckM7SUFDQSxJQUFJLENBQUNBLE1BQU0sSUFBSSxDQUFDQSxNQUFNLENBQUNDLFVBQVUsRUFBRTtNQUNqQyxJQUFJLENBQUNBLFVBQVUsR0FBRyxJQUFJQyxHQUFHLENBQUMsQ0FBQztJQUM3QixDQUFDLE1BQU0sSUFBSUYsTUFBTSxDQUFDQyxVQUFVLFlBQVlFLEtBQUssRUFBRTtNQUM3QyxNQUFNRixVQUFVLEdBQUdELE1BQU0sQ0FBQ0MsVUFBVSxDQUFDRyxHQUFHLENBQUNDLElBQUksSUFBSTtRQUMvQyxNQUFNQyxLQUFLLEdBQUcsSUFBQUMsc0JBQVksRUFBQ0YsSUFBSSxDQUFDO1FBQ2hDLE9BQU8sSUFBSUcsTUFBTSxDQUFDLElBQUlGLEtBQUssR0FBRyxDQUFDO01BQ2pDLENBQUMsQ0FBQztNQUNGLElBQUksQ0FBQ0wsVUFBVSxHQUFHLElBQUlDLEdBQUcsQ0FBQ0QsVUFBVSxDQUFDO0lBQ3ZDLENBQUMsTUFBTTtNQUNMLE1BQU0sZ0RBQWdEO0lBQ3hEO0lBQ0EsSUFBSSxDQUFDUSxrQkFBa0IsR0FBRyxJQUFJQyxnREFBdUIsQ0FBQ1YsTUFBTSxDQUFDO0VBQy9EO0VBRUFXLE9BQU9BLENBQUEsRUFBRztJQUNSLE9BQU8sSUFBSSxDQUFDRixrQkFBa0IsQ0FBQ0UsT0FBTyxDQUFDLENBQUM7RUFDMUM7RUFFQUMsV0FBV0EsQ0FDVEMsU0FBaUIsRUFDakJDLGFBQWtCLEVBQ2xCQyxjQUFtQixFQUNuQkMscUJBQTJCLEVBQzNCO0lBQ0EsSUFBSSxDQUFDLElBQUksQ0FBQ0MsWUFBWSxDQUFDSixTQUFTLENBQUMsRUFBRTtNQUNqQztJQUNGO0lBQ0EsTUFBTUssR0FBRyxHQUFHLElBQUksQ0FBQ0MscUJBQXFCLENBQUNMLGFBQWEsRUFBRUMsY0FBYyxFQUFFQyxxQkFBcUIsQ0FBQztJQUM1RixJQUFJLENBQUNQLGtCQUFrQixDQUFDVyxvQkFBb0IsQ0FBQ0YsR0FBRyxDQUFDO0VBQ25EO0VBRUFHLGFBQWFBLENBQ1hSLFNBQWlCLEVBQ2pCQyxhQUFrQixFQUNsQkMsY0FBbUIsRUFDbkJDLHFCQUEwQixFQUMxQjtJQUNBLElBQUksQ0FBQyxJQUFJLENBQUNDLFlBQVksQ0FBQ0osU0FBUyxDQUFDLEVBQUU7TUFDakM7SUFDRjtJQUNBLE1BQU1LLEdBQUcsR0FBRyxJQUFJLENBQUNDLHFCQUFxQixDQUFDTCxhQUFhLEVBQUVDLGNBQWMsRUFBRUMscUJBQXFCLENBQUM7SUFDNUYsSUFBSSxDQUFDUCxrQkFBa0IsQ0FBQ2Esc0JBQXNCLENBQUNKLEdBQUcsQ0FBQztFQUNyRDtFQUVBRCxZQUFZQSxDQUFDSixTQUFpQixFQUFXO0lBQ3ZDLEtBQUssTUFBTVIsSUFBSSxJQUFJLElBQUksQ0FBQ0osVUFBVSxFQUFFO01BQ2xDLElBQUlJLElBQUksQ0FBQ2tCLElBQUksQ0FBQ1YsU0FBUyxDQUFDLEVBQUU7UUFDeEIsT0FBTyxJQUFJO01BQ2I7SUFDRjtJQUNBLE9BQU8sS0FBSztFQUNkO0VBRUFXLGdCQUFnQkEsQ0FBQ0MsSUFBUyxFQUFFO0lBQzFCLElBQUksQ0FBQ0EsSUFBSSxFQUFFO01BQ1Q7SUFDRjtJQUNBLE9BQU8sSUFBSSxDQUFDaEIsa0JBQWtCLENBQUNpQixrQkFBa0IsQ0FBQ0QsSUFBSSxDQUFDO0VBQ3pEO0VBRUFOLHFCQUFxQkEsQ0FBQ0wsYUFBa0IsRUFBRUMsY0FBbUIsRUFBRUMscUJBQTJCLEVBQU87SUFDL0YsTUFBTUUsR0FBRyxHQUFHO01BQ1ZTLE1BQU0sRUFBRWI7SUFDVixDQUFDO0lBQ0QsSUFBSUEsYUFBYSxFQUFFO01BQ2pCSSxHQUFHLENBQUNVLFFBQVEsR0FBR2IsY0FBYztJQUMvQjtJQUNBLElBQUlDLHFCQUFxQixFQUFFO01BQ3pCRSxHQUFHLENBQUNGLHFCQUFxQixHQUFHQSxxQkFBcUI7SUFDbkQ7SUFDQSxPQUFPRSxHQUFHO0VBQ1o7QUFDRjtBQUFDVyxPQUFBLENBQUEvQixtQkFBQSxHQUFBQSxtQkFBQTtBQUFBLElBQUFnQyxRQUFBLEdBQUFELE9BQUEsQ0FBQUUsT0FBQSxHQUVjakMsbUJBQW1CIiwiaWdub3JlTGlzdCI6W119
@@ -1,43 +1,29 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.LoggerController = exports.LogOrder = exports.LogLevel = undefined;
7
-
8
- var _node = require('parse/node');
9
-
10
- var _AdaptableController = require('./AdaptableController');
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
- const logLevels = ['error', 'warn', 'info', 'debug', 'verbose', 'silly'];
37
-
38
- class LoggerController extends _AdaptableController2.default {
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
- maskSensitiveUrl(urlString) {
59
- const urlObj = _url2.default.parse(urlString, true);
60
- const query = urlObj.query;
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 + '=' + query[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
- }, { result: result });
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":";;;;;;;AAAA;;AACA;;;;AACA;;AACA;;;;;;AAEA,MAAMA,wBAAwB,KAAK,EAAL,GAAU,EAAV,GAAe,IAA7C;AACA,MAAMC,6BAA6B,IAAnC;AACA,MAAMC,mBAAmB,iBAAzB;;AAEO,MAAMC,8BAAW;AACtBC,QAAM,MADgB;AAEtBC,SAAO;AAFe,CAAjB;;AAKA,MAAMC,8BAAW;AACtBC,cAAY,MADU;AAEtBC,aAAW;AAFW,CAAjB;;AAKP,MAAMC,YAAY,CAChB,OADgB,EAEhB,MAFgB,EAGhB,MAHgB,EAIhB,OAJgB,EAKhB,SALgB,EAMhB,OANgB,CAAlB;;AASO,MAAMC,gBAAN,SAA+BC,6BAA/B,CAAmD;;AAExDC,cAAYC,OAAZ,EAAqBC,KAArB,EAA4BC,UAAU,EAACC,UAAU,MAAX,EAAtC,EAA0D;AACxD,UAAMH,OAAN,EAAeC,KAAf,EAAsBC,OAAtB;AACA,QAAIE,QAAQ,MAAZ;AACA,QAAIF,QAAQG,OAAZ,EAAqB;AACnBD,cAAQ,SAAR;AACD;AACD,QAAIF,QAAQC,QAAZ,EAAsB;AACpBC,cAAQF,QAAQC,QAAhB;AACD;AACD,UAAMG,QAAQV,UAAUW,OAAV,CAAkBH,KAAlB,CAAd,CATwD,CAShB;AACxCR,cAAUY,OAAV,CAAkB,CAACJ,KAAD,EAAQK,UAAR,KAAuB;AACvC,UAAIA,aAAaH,KAAjB,EAAwB;AAAE;AACxB,aAAKF,KAAL,IAAc,MAAM,CAAE,CAAtB;AACD;AACF,KAJD;AAKD;;AAEDM,mBAAiBC,SAAjB,EAA4B;AAC1B,UAAMC,SAASC,cAAIC,KAAJ,CAAUH,SAAV,EAAqB,IAArB,CAAf;AACA,UAAMI,QAAQH,OAAOG,KAArB;AACA,QAAIC,iBAAiB,GAArB;;AAEA,SAAI,MAAMC,GAAV,IAAiBF,KAAjB,EAAwB;AACtB,UAAGE,QAAQ,UAAX,EAAuB;AACrB;AACAD,0BAAkBC,MAAM,GAAN,GAAYF,MAAME,GAAN,CAAZ,GAAyB,GAA3C;AACD,OAHD,MAGO;AACL;AACAD,0BAAkBC,MAAM,GAAN,GAAY,UAAZ,GAAyB,GAA3C;AACD;AACF;;AAED;AACAD,qBAAiBA,eAAeE,KAAf,CAAqB,CAArB,EAAwB,CAAC,CAAzB,CAAjB;;AAEA;AACA,WAAON,OAAOO,QAAP,GAAkBH,cAAzB;AACD;;AAEDI,gBAAcC,QAAd,EAAwB;AACtB,WAAOA,SAASC,GAAT,CAAaC,KAAK;AACvB,UAAI,CAACA,CAAL,EAAQ;AACN,eAAOA,CAAP;AACD;;AAED,UAAI,OAAOA,CAAP,KAAa,QAAjB,EAA2B;AACzB,eAAOA,EAAEC,OAAF,CAAU,0BAAV,EAAsC,aAAtC,CAAP;AACD;AACD;;AAEA;AACA,UAAID,EAAEV,GAAN,EAAW;AACT;AACA,YAAI,OAAOU,EAAEV,GAAT,KAAiB,QAArB,EAA+B;AAC7BU,YAAEV,GAAF,GAAQ,KAAKH,gBAAL,CAAsBa,EAAEV,GAAxB,CAAR;AACD,SAFD,MAEO,IAAIY,MAAMC,OAAN,CAAcH,EAAEV,GAAhB,CAAJ,EAA0B;AAAE;AACjCU,YAAEV,GAAF,GAAQU,EAAEV,GAAF,CAAMS,GAAN,CAAUK,QAAQ;AACxB,gBAAI,OAAOA,IAAP,KAAgB,QAApB,EAA8B;AAC5B,qBAAO,KAAKjB,gBAAL,CAAsBiB,IAAtB,CAAP;AACD;;AAED,mBAAOA,IAAP;AACD,WANO,CAAR;AAOD;AACF;;AAED,UAAIJ,EAAEK,IAAN,EAAY;AACV,aAAK,MAAMX,GAAX,IAAkBY,OAAOC,IAAP,CAAYP,EAAEK,IAAd,CAAlB,EAAuC;AACrC,cAAIX,QAAQ,UAAZ,EAAwB;AACtBM,cAAEK,IAAF,CAAOX,GAAP,IAAc,UAAd;AACA;AACD;AACF;AACF;;AAED,UAAIM,EAAEQ,MAAN,EAAc;AACZ,aAAK,MAAMd,GAAX,IAAkBY,OAAOC,IAAP,CAAYP,EAAEQ,MAAd,CAAlB,EAAyC;AACvC,cAAId,QAAQ,UAAZ,EAAwB;AACtBM,cAAEQ,MAAF,CAASd,GAAT,IAAgB,UAAhB;AACA;AACD;AACF;AACF;;AAED,aAAOM,CAAP;AACD,KA7CM,CAAP;AA8CD;;AAEDS,MAAI5B,KAAJ,EAAW6B,IAAX,EAAiB;AACf;AACAA,WAAO,KAAKb,aAAL,CAAmB,CAAC,GAAGa,IAAJ,CAAnB,CAAP;AACAA,WAAO,GAAGC,MAAH,CAAU9B,KAAV,EAAiB6B,KAAKX,GAAL,CAAUa,GAAD,IAAS;AACxC,UAAI,OAAOA,GAAP,KAAe,UAAnB,EAA+B;AAAE,eAAOA,KAAP;AAAe;AAChD,aAAOA,GAAP;AACD,KAHuB,CAAjB,CAAP;AAIA,SAAKnC,OAAL,CAAagC,GAAb,CAAiBI,KAAjB,CAAuB,KAAKpC,OAA5B,EAAqCiC,IAArC;AACD;;AAEDI,SAAO;AACL,WAAO,KAAKL,GAAL,CAAS,MAAT,EAAiBM,SAAjB,CAAP;AACD;;AAEDC,UAAQ;AACN,WAAO,KAAKP,GAAL,CAAS,OAAT,EAAkBM,SAAlB,CAAP;AACD;;AAEDE,SAAO;AACL,WAAO,KAAKR,GAAL,CAAS,MAAT,EAAiBM,SAAjB,CAAP;AACD;;AAEDjC,YAAU;AACR,WAAO,KAAK2B,GAAL,CAAS,SAAT,EAAoBM,SAApB,CAAP;AACD;;AAEDG,UAAQ;AACN,WAAO,KAAKT,GAAL,CAAS,OAAT,EAAkBM,SAAlB,CAAP;AACD;;AAEDI,UAAQ;AACN,WAAO,KAAKV,GAAL,CAAS,OAAT,EAAkBM,SAAlB,CAAP;AACD;;AAEDK,aAAW;AACTC,UADS;AAET/B,OAFS;AAGTgC,WAHS;AAITjB;AAJS,GAAX,EAKG;AACD,SAAKvB,OAAL,CAAa,MAAM;AACjB,YAAMyC,kBAAkBC,KAAKC,SAAL,CAAepB,IAAf,EAAqB,IAArB,EAA2B,CAA3B,CAAxB;AACA,aAAQ,gBAAegB,MAAO,KAAI/B,GAAI,KAAIiC,eAAgB,EAA1D;AACD,KAHD,EAGG;AACDF,YADC;AAED/B,SAFC;AAGDgC,aAHC;AAIDjB;AAJC,KAHH;AASD;;AAEDqB,cAAY;AACVL,UADU;AAEV/B,OAFU;AAGVqC;AAHU,GAAZ,EAIG;AACD,SAAK7C,OAAL,CACE,MAAM;AAAE,YAAM8C,sBAAsBJ,KAAKC,SAAL,CAAeE,MAAf,EAAuB,IAAvB,EAA6B,CAA7B,CAA5B;AACN,aAAQ,kBAAiBN,MAAO,KAAI/B,GAAI,KAAIsC,mBAAoB,EAAhE;AACD,KAHH,EAIE,EAACD,QAAQA,MAAT,EAJF;AAMD;AACD;AACA,SAAOE,aAAP,CAAqBC,IAArB,EAA2B;AACzB,QAAI,CAACA,IAAL,EAAW;AACT,aAAO,IAAP;AACD;AACDA,WAAO,IAAIC,IAAJ,CAASD,IAAT,CAAP;;AAEA,QAAI,CAACE,MAAMF,KAAKG,OAAL,EAAN,CAAL,EAA4B;AAC1B,aAAOH,IAAP;AACD;;AAED,WAAO,IAAP;AACD;;AAEDI,qBAAmBC,MAAnB,EAA2B;AACzB,QAAIA,UAAUA,OAAOC,MAAP,GAAgBvE,0BAA9B,EAA0D;AACxD,YAAMwE,YAAYF,OAAOG,SAAP,CAAiB,CAAjB,EAAoBzE,0BAApB,IAAkDC,gBAApE;AACA,aAAOuE,SAAP;AACD;;AAED,WAAOF,MAAP;AACD;;AAED,SAAOI,YAAP,CAAoB5D,UAAU,EAA9B,EAAkC;AAChC,UAAM6D,OAAOlE,iBAAiBuD,aAAjB,CAA+BlD,QAAQ6D,IAAvC,KACX,IAAIT,IAAJ,CAASA,KAAKU,GAAL,KAAa,IAAI7E,qBAA1B,CADF;AAEA,UAAM8E,QAAQpE,iBAAiBuD,aAAjB,CAA+BlD,QAAQ+D,KAAvC,KAAiD,IAAIX,IAAJ,EAA/D;AACA,UAAMY,OAAOC,OAAOjE,QAAQgE,IAAf,KAAwB,EAArC;AACA,UAAME,QAAQlE,QAAQkE,KAAR,IAAiB3E,SAASC,UAAxC;AACA,UAAMU,QAAQF,QAAQE,KAAR,IAAiBd,SAASC,IAAxC;;AAEA,WAAO;AACLwE,UADK;AAELE,WAFK;AAGLC,UAHK;AAILE,WAJK;AAKLhE;AALK,KAAP;AAOD;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACAiE,UAAQnE,UAAU,EAAlB,EAAsB;AACpB,QAAI,CAAC,KAAKF,OAAV,EAAmB;AACjB,YAAM,IAAIsE,YAAMC,KAAV,CAAgBD,YAAMC,KAAN,CAAYC,kBAA5B,EACJ,iCADI,CAAN;AAED;AACD,QAAI,OAAO,KAAKxE,OAAL,CAAae,KAApB,KAA8B,UAAlC,EAA8C;AAC5C,YAAM,IAAIuD,YAAMC,KAAV,CAAgBD,YAAMC,KAAN,CAAYC,kBAA5B,EACJ,kDADI,CAAN;AAED;AACDtE,cAAUL,iBAAiBiE,YAAjB,CAA8B5D,OAA9B,CAAV;AACA,WAAO,KAAKF,OAAL,CAAae,KAAb,CAAmBb,OAAnB,CAAP;AACD;;AAEDuE,wBAAsB;AACpB,WAAOC,4BAAP;AACD;AAvNuD;;QAA7C7E,gB,GAAAA,gB;kBA0NEA,gB","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":[]}