parse-server 6.0.0-alpha.2 → 6.0.0-alpha.21

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 (191) hide show
  1. package/README.md +45 -17
  2. package/lib/AccountLockout.js +11 -26
  3. package/lib/Adapters/AdapterLoader.js +8 -14
  4. package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
  5. package/lib/Adapters/Auth/AuthAdapter.js +7 -16
  6. package/lib/Adapters/Auth/OAuth1Client.js +32 -57
  7. package/lib/Adapters/Auth/apple.js +6 -22
  8. package/lib/Adapters/Auth/facebook.js +7 -37
  9. package/lib/Adapters/Auth/gcenter.js +8 -37
  10. package/lib/Adapters/Auth/github.js +7 -10
  11. package/lib/Adapters/Auth/google.js +11 -34
  12. package/lib/Adapters/Auth/gpgames.js +5 -8
  13. package/lib/Adapters/Auth/httpsRequest.js +1 -7
  14. package/lib/Adapters/Auth/index.js +20 -65
  15. package/lib/Adapters/Auth/instagram.js +5 -9
  16. package/lib/Adapters/Auth/janraincapture.js +8 -12
  17. package/lib/Adapters/Auth/janrainengage.js +7 -11
  18. package/lib/Adapters/Auth/keycloak.js +5 -19
  19. package/lib/Adapters/Auth/ldap.js +1 -15
  20. package/lib/Adapters/Auth/line.js +7 -10
  21. package/lib/Adapters/Auth/linkedin.js +7 -12
  22. package/lib/Adapters/Auth/meetup.js +7 -10
  23. package/lib/Adapters/Auth/microsoft.js +7 -10
  24. package/lib/Adapters/Auth/oauth2.js +6 -18
  25. package/lib/Adapters/Auth/phantauth.js +8 -10
  26. package/lib/Adapters/Auth/qq.js +7 -13
  27. package/lib/Adapters/Auth/spotify.js +7 -14
  28. package/lib/Adapters/Auth/twitter.js +5 -15
  29. package/lib/Adapters/Auth/vkontakte.js +9 -15
  30. package/lib/Adapters/Auth/wechat.js +7 -10
  31. package/lib/Adapters/Auth/weibo.js +7 -11
  32. package/lib/Adapters/Cache/CacheAdapter.js +4 -12
  33. package/lib/Adapters/Cache/InMemoryCache.js +5 -19
  34. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
  35. package/lib/Adapters/Cache/LRUCache.js +1 -11
  36. package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
  37. package/lib/Adapters/Cache/RedisCacheAdapter.js +46 -87
  38. package/lib/Adapters/Cache/SchemaCache.js +1 -6
  39. package/lib/Adapters/Email/MailAdapter.js +2 -7
  40. package/lib/Adapters/Files/FilesAdapter.js +7 -21
  41. package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
  42. package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
  43. package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
  44. package/lib/Adapters/Logger/WinstonLogger.js +3 -30
  45. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
  46. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
  47. package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
  48. package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
  49. package/lib/Adapters/PubSub/RedisPubSub.js +13 -10
  50. package/lib/Adapters/Push/PushAdapter.js +2 -8
  51. package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
  52. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
  53. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
  54. package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
  55. package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
  56. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
  57. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
  58. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
  59. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  60. package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
  61. package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
  62. package/lib/Auth.js +54 -121
  63. package/lib/ClientSDK.js +3 -11
  64. package/lib/Config.js +69 -113
  65. package/lib/Controllers/AdaptableController.js +6 -18
  66. package/lib/Controllers/AnalyticsController.js +1 -9
  67. package/lib/Controllers/CacheController.js +3 -23
  68. package/lib/Controllers/DatabaseController.js +147 -345
  69. package/lib/Controllers/FilesController.js +5 -34
  70. package/lib/Controllers/HooksController.js +1 -51
  71. package/lib/Controllers/LiveQueryController.js +4 -23
  72. package/lib/Controllers/LoggerController.js +15 -54
  73. package/lib/Controllers/ParseGraphQLController.js +49 -104
  74. package/lib/Controllers/PushController.js +20 -59
  75. package/lib/Controllers/SchemaController.js +154 -344
  76. package/lib/Controllers/UserController.js +11 -72
  77. package/lib/Controllers/index.js +19 -68
  78. package/lib/Controllers/types.js +1 -1
  79. package/lib/Deprecator/Deprecations.js +1 -8
  80. package/lib/Deprecator/Deprecator.js +9 -18
  81. package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
  82. package/lib/GraphQL/ParseGraphQLServer.js +2 -29
  83. package/lib/GraphQL/helpers/objectsMutations.js +2 -12
  84. package/lib/GraphQL/helpers/objectsQueries.js +18 -76
  85. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
  86. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
  87. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
  88. package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
  89. package/lib/GraphQL/loaders/filesMutations.js +2 -19
  90. package/lib/GraphQL/loaders/functionsMutations.js +6 -17
  91. package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
  92. package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
  93. package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
  94. package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
  95. package/lib/GraphQL/loaders/schemaMutations.js +1 -20
  96. package/lib/GraphQL/loaders/schemaQueries.js +1 -14
  97. package/lib/GraphQL/loaders/schemaTypes.js +2 -6
  98. package/lib/GraphQL/loaders/usersMutations.js +6 -28
  99. package/lib/GraphQL/loaders/usersQueries.js +4 -26
  100. package/lib/GraphQL/parseGraphQLUtils.js +6 -19
  101. package/lib/GraphQL/transformers/className.js +1 -4
  102. package/lib/GraphQL/transformers/constraintType.js +1 -20
  103. package/lib/GraphQL/transformers/inputType.js +1 -20
  104. package/lib/GraphQL/transformers/mutation.js +6 -51
  105. package/lib/GraphQL/transformers/outputType.js +1 -20
  106. package/lib/GraphQL/transformers/query.js +6 -42
  107. package/lib/GraphQL/transformers/schemaFields.js +7 -34
  108. package/lib/KeyPromiseQueue.js +1 -12
  109. package/lib/LiveQuery/Client.js +1 -25
  110. package/lib/LiveQuery/Id.js +1 -7
  111. package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
  112. package/lib/LiveQuery/ParseLiveQueryServer.js +92 -306
  113. package/lib/LiveQuery/ParsePubSub.js +1 -12
  114. package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
  115. package/lib/LiveQuery/QueryTools.js +14 -116
  116. package/lib/LiveQuery/RequestSchema.js +1 -1
  117. package/lib/LiveQuery/SessionTokenCache.js +1 -17
  118. package/lib/LiveQuery/Subscription.js +4 -18
  119. package/lib/LiveQuery/equalObjects.js +2 -14
  120. package/lib/Options/Definitions.js +79 -10
  121. package/lib/Options/docs.js +23 -3
  122. package/lib/Options/index.js +4 -12
  123. package/lib/Options/parsers.js +1 -18
  124. package/lib/Page.js +1 -9
  125. package/lib/ParseMessageQueue.js +1 -10
  126. package/lib/ParseServer.js +144 -182
  127. package/lib/ParseServerRESTController.js +6 -33
  128. package/lib/PromiseRouter.js +16 -50
  129. package/lib/Push/PushQueue.js +3 -15
  130. package/lib/Push/PushWorker.js +7 -32
  131. package/lib/Push/utils.js +9 -38
  132. package/lib/RestQuery.js +105 -242
  133. package/lib/RestWrite.js +212 -377
  134. package/lib/Routers/AggregateRouter.js +14 -51
  135. package/lib/Routers/AnalyticsRouter.js +2 -8
  136. package/lib/Routers/AudiencesRouter.js +1 -15
  137. package/lib/Routers/ClassesRouter.js +3 -53
  138. package/lib/Routers/CloudCodeRouter.js +1 -19
  139. package/lib/Routers/FeaturesRouter.js +1 -10
  140. package/lib/Routers/FilesRouter.js +29 -76
  141. package/lib/Routers/FunctionsRouter.js +5 -28
  142. package/lib/Routers/GlobalConfigRouter.js +4 -18
  143. package/lib/Routers/GraphQLRouter.js +1 -14
  144. package/lib/Routers/HooksRouter.js +1 -29
  145. package/lib/Routers/IAPValidationRouter.js +6 -29
  146. package/lib/Routers/InstallationsRouter.js +2 -12
  147. package/lib/Routers/LogsRouter.js +4 -16
  148. package/lib/Routers/PagesRouter.js +69 -129
  149. package/lib/Routers/PublicAPIRouter.js +3 -62
  150. package/lib/Routers/PurgeRouter.js +1 -15
  151. package/lib/Routers/PushRouter.js +2 -18
  152. package/lib/Routers/RolesRouter.js +1 -7
  153. package/lib/Routers/SchemasRouter.js +4 -34
  154. package/lib/Routers/SecurityRouter.js +1 -12
  155. package/lib/Routers/SessionsRouter.js +3 -19
  156. package/lib/Routers/UsersRouter.js +58 -155
  157. package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
  158. package/lib/SchemaMigrations/Migrations.js +2 -8
  159. package/lib/Security/Check.js +8 -16
  160. package/lib/Security/CheckGroup.js +4 -11
  161. package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
  162. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
  163. package/lib/Security/CheckGroups/CheckGroups.js +1 -4
  164. package/lib/Security/CheckRunner.js +22 -41
  165. package/lib/StatusHandler.js +12 -69
  166. package/lib/TestUtils.js +1 -6
  167. package/lib/Utils.js +27 -66
  168. package/lib/batch.js +17 -28
  169. package/lib/cache.js +1 -3
  170. package/lib/cli/definitions/parse-live-query-server.js +1 -3
  171. package/lib/cli/definitions/parse-server.js +1 -3
  172. package/lib/cli/parse-live-query-server.js +1 -6
  173. package/lib/cli/parse-server.js +11 -21
  174. package/lib/cli/utils/commander.js +13 -51
  175. package/lib/cli/utils/runner.js +1 -14
  176. package/lib/cloud-code/Parse.Cloud.js +71 -92
  177. package/lib/cryptoUtils.js +11 -19
  178. package/lib/defaults.js +2 -14
  179. package/lib/deprecated.js +1 -2
  180. package/lib/index.js +16 -34
  181. package/lib/logger.js +6 -13
  182. package/lib/middlewares.js +147 -151
  183. package/lib/password.js +6 -10
  184. package/lib/request.js +173 -2
  185. package/lib/requiredParameter.js +1 -3
  186. package/lib/rest.js +19 -41
  187. package/lib/triggers.js +54 -252
  188. package/lib/vendor/mongodbUrl.js +125 -305
  189. package/package.json +22 -19
  190. package/lib/cloud-code/HTTPResponse.js +0 -73
  191. package/lib/cloud-code/httpRequest.js +0 -192
@@ -3,16 +3,11 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.default = exports.LoggerController = exports.LogOrder = exports.LogLevel = void 0;
7
-
6
+ exports.logLevels = exports.default = exports.LoggerController = exports.LogOrder = exports.LogLevel = void 0;
8
7
  var _node = require("parse/node");
9
-
10
8
  var _AdaptableController = _interopRequireDefault(require("./AdaptableController"));
11
-
12
9
  var _LoggerAdapter = require("../Adapters/Logger/LoggerAdapter");
13
-
14
10
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
-
16
11
  const MILLISECONDS_IN_A_DAY = 24 * 60 * 60 * 1000;
17
12
  const LOG_STRING_TRUNCATE_LENGTH = 1000;
18
13
  const truncationMarker = '... (truncated)';
@@ -27,24 +22,20 @@ const LogOrder = {
27
22
  };
28
23
  exports.LogOrder = LogOrder;
29
24
  const logLevels = ['error', 'warn', 'info', 'debug', 'verbose', 'silly'];
30
-
25
+ exports.logLevels = logLevels;
31
26
  class LoggerController extends _AdaptableController.default {
32
27
  constructor(adapter, appId, options = {
33
28
  logLevel: 'info'
34
29
  }) {
35
30
  super(adapter, appId, options);
36
31
  let level = 'info';
37
-
38
32
  if (options.verbose) {
39
33
  level = 'verbose';
40
34
  }
41
-
42
35
  if (options.logLevel) {
43
36
  level = options.logLevel;
44
37
  }
45
-
46
38
  const index = logLevels.indexOf(level); // info by default
47
-
48
39
  logLevels.forEach((level, levelIndex) => {
49
40
  if (levelIndex > index) {
50
41
  // silence the levels that are > maxIndex
@@ -52,14 +43,11 @@ class LoggerController extends _AdaptableController.default {
52
43
  }
53
44
  });
54
45
  }
55
-
56
46
  maskSensitiveUrl(path) {
57
47
  const urlString = 'http://localhost' + path; // prepend dummy string to make a real URL
58
-
59
48
  const urlObj = new URL(urlString);
60
49
  const query = urlObj.searchParams;
61
50
  let sanitizedQuery = '?';
62
-
63
51
  for (const [key, value] of query) {
64
52
  if (key !== 'password') {
65
53
  // normal value
@@ -68,26 +56,25 @@ class LoggerController extends _AdaptableController.default {
68
56
  // password value, redact it
69
57
  sanitizedQuery += key + '=' + '********' + '&';
70
58
  }
71
- } // trim last character, ? or &
72
-
59
+ }
73
60
 
74
- sanitizedQuery = sanitizedQuery.slice(0, -1); // return original path name with sanitized params attached
61
+ // trim last character, ? or &
62
+ sanitizedQuery = sanitizedQuery.slice(0, -1);
75
63
 
64
+ // return original path name with sanitized params attached
76
65
  return urlObj.pathname + sanitizedQuery;
77
66
  }
78
-
79
67
  maskSensitive(argArray) {
80
68
  return argArray.map(e => {
81
69
  if (!e) {
82
70
  return e;
83
71
  }
84
-
85
72
  if (typeof e === 'string') {
86
73
  return e.replace(/(password".?:.?")[^"]*"/g, '$1********"');
87
- } // else it is an object...
88
- // check the url
89
-
74
+ }
75
+ // else it is an object...
90
76
 
77
+ // check the url
91
78
  if (e.url) {
92
79
  // for strings
93
80
  if (typeof e.url === 'string') {
@@ -98,12 +85,10 @@ class LoggerController extends _AdaptableController.default {
98
85
  if (typeof item === 'string') {
99
86
  return this.maskSensitiveUrl(item);
100
87
  }
101
-
102
88
  return item;
103
89
  });
104
90
  }
105
91
  }
106
-
107
92
  if (e.body) {
108
93
  for (const key of Object.keys(e.body)) {
109
94
  if (key === 'password') {
@@ -112,7 +97,6 @@ class LoggerController extends _AdaptableController.default {
112
97
  }
113
98
  }
114
99
  }
115
-
116
100
  if (e.params) {
117
101
  for (const key of Object.keys(e.params)) {
118
102
  if (key === 'password') {
@@ -121,11 +105,9 @@ class LoggerController extends _AdaptableController.default {
121
105
  }
122
106
  }
123
107
  }
124
-
125
108
  return e;
126
109
  });
127
110
  }
128
-
129
111
  log(level, args) {
130
112
  // make the passed in arguments object an array with the spread operator
131
113
  args = this.maskSensitive([...args]);
@@ -133,36 +115,28 @@ class LoggerController extends _AdaptableController.default {
133
115
  if (typeof arg === 'function') {
134
116
  return arg();
135
117
  }
136
-
137
118
  return arg;
138
119
  }));
139
120
  this.adapter.log.apply(this.adapter, args);
140
121
  }
141
-
142
122
  info() {
143
123
  return this.log('info', arguments);
144
124
  }
145
-
146
125
  error() {
147
126
  return this.log('error', arguments);
148
127
  }
149
-
150
128
  warn() {
151
129
  return this.log('warn', arguments);
152
130
  }
153
-
154
131
  verbose() {
155
132
  return this.log('verbose', arguments);
156
133
  }
157
-
158
134
  debug() {
159
135
  return this.log('debug', arguments);
160
136
  }
161
-
162
137
  silly() {
163
138
  return this.log('silly', arguments);
164
139
  }
165
-
166
140
  logRequest({
167
141
  method,
168
142
  url,
@@ -179,7 +153,6 @@ class LoggerController extends _AdaptableController.default {
179
153
  body
180
154
  });
181
155
  }
182
-
183
156
  logResponse({
184
157
  method,
185
158
  url,
@@ -191,32 +164,25 @@ class LoggerController extends _AdaptableController.default {
191
164
  }, {
192
165
  result: result
193
166
  });
194
- } // check that date input is valid
195
-
196
-
167
+ }
168
+ // check that date input is valid
197
169
  static validDateTime(date) {
198
170
  if (!date) {
199
171
  return null;
200
172
  }
201
-
202
173
  date = new Date(date);
203
-
204
174
  if (!isNaN(date.getTime())) {
205
175
  return date;
206
176
  }
207
-
208
177
  return null;
209
178
  }
210
-
211
179
  truncateLogMessage(string) {
212
180
  if (string && string.length > LOG_STRING_TRUNCATE_LENGTH) {
213
181
  const truncated = string.substring(0, LOG_STRING_TRUNCATE_LENGTH) + truncationMarker;
214
182
  return truncated;
215
183
  }
216
-
217
184
  return string;
218
185
  }
219
-
220
186
  static parseOptions(options = {}) {
221
187
  const from = LoggerController.validDateTime(options.from) || new Date(Date.now() - 7 * MILLISECONDS_IN_A_DAY);
222
188
  const until = LoggerController.validDateTime(options.until) || new Date();
@@ -230,35 +196,30 @@ class LoggerController extends _AdaptableController.default {
230
196
  order,
231
197
  level
232
198
  };
233
- } // Returns a promise for a {response} object.
199
+ }
200
+
201
+ // Returns a promise for a {response} object.
234
202
  // query params:
235
203
  // level (optional) Level of logging you want to query for (info || error)
236
204
  // from (optional) Start time for the search. Defaults to 1 week ago.
237
205
  // until (optional) End time for the search. Defaults to current time.
238
206
  // order (optional) Direction of results returned, either “asc” or “desc”. Defaults to “desc”.
239
207
  // size (optional) Number of rows returned by search. Defaults to 10
240
-
241
-
242
208
  getLogs(options = {}) {
243
209
  if (!this.adapter) {
244
210
  throw new _node.Parse.Error(_node.Parse.Error.PUSH_MISCONFIGURED, 'Logger adapter is not available');
245
211
  }
246
-
247
212
  if (typeof this.adapter.query !== 'function') {
248
213
  throw new _node.Parse.Error(_node.Parse.Error.PUSH_MISCONFIGURED, 'Querying logs is not supported with this adapter');
249
214
  }
250
-
251
215
  options = LoggerController.parseOptions(options);
252
216
  return this.adapter.query(options);
253
217
  }
254
-
255
218
  expectedAdapterType() {
256
219
  return _LoggerAdapter.LoggerAdapter;
257
220
  }
258
-
259
221
  }
260
-
261
222
  exports.LoggerController = LoggerController;
262
223
  var _default = LoggerController;
263
224
  exports.default = _default;
264
- //# 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","path","urlString","urlObj","URL","query","searchParams","sanitizedQuery","key","value","slice","pathname","maskSensitive","argArray","map","e","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"],"mappings":"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","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\nconst logLevels = ['error', 'warn', 'info', 'debug', 'verbose', 'silly'];\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"]}
225
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"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","path","urlString","urlObj","URL","query","searchParams","sanitizedQuery","key","value","slice","pathname","maskSensitive","argArray","map","e","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"],"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'];\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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"}