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
package/lib/Config.js CHANGED
@@ -4,42 +4,32 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = exports.Config = void 0;
7
-
7
+ var _lodash = require("lodash");
8
+ var _net = _interopRequireDefault(require("net"));
8
9
  var _cache = _interopRequireDefault(require("./cache"));
9
-
10
10
  var _DatabaseController = _interopRequireDefault(require("./Controllers/DatabaseController"));
11
-
12
- var _net = _interopRequireDefault(require("net"));
13
-
11
+ var _LoggerController = require("./Controllers/LoggerController");
14
12
  var _Definitions = require("./Options/Definitions");
15
-
16
- var _lodash = require("lodash");
17
-
18
13
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
-
20
14
  // A Config object provides information about how a specific app is
21
15
  // configured.
22
16
  // mount is the URL for the root of the API; includes http, domain, etc.
17
+
23
18
  function removeTrailingSlash(str) {
24
19
  if (!str) {
25
20
  return str;
26
21
  }
27
-
28
22
  if (str.endsWith('/')) {
29
23
  str = str.substr(0, str.length - 1);
30
24
  }
31
-
32
25
  return str;
33
26
  }
34
-
35
27
  class Config {
36
28
  static get(applicationId, mount) {
37
29
  const cacheInfo = _cache.default.get(applicationId);
38
-
39
30
  if (!cacheInfo) {
40
31
  return;
41
32
  }
42
-
43
33
  const config = new Config();
44
34
  config.applicationId = applicationId;
45
35
  Object.keys(cacheInfo).forEach(key => {
@@ -54,16 +44,12 @@ class Config {
54
44
  config.generateEmailVerifyTokenExpiresAt = config.generateEmailVerifyTokenExpiresAt.bind(config);
55
45
  return config;
56
46
  }
57
-
58
47
  static put(serverConfiguration) {
59
48
  Config.validate(serverConfiguration);
60
-
61
49
  _cache.default.put(serverConfiguration.appId, serverConfiguration);
62
-
63
50
  Config.setupPasswordValidator(serverConfiguration.passwordPolicy);
64
51
  return serverConfiguration;
65
52
  }
66
-
67
53
  static validate({
68
54
  verifyUserEmails,
69
55
  userController,
@@ -89,14 +75,14 @@ class Config {
89
75
  enforcePrivateUsers,
90
76
  schema,
91
77
  requestKeywordDenylist,
92
- allowExpiredAuthDataToken
78
+ allowExpiredAuthDataToken,
79
+ logLevels,
80
+ rateLimit
93
81
  }) {
94
82
  if (masterKey === readOnlyMasterKey) {
95
83
  throw new Error('masterKey and readOnlyMasterKey should be different');
96
84
  }
97
-
98
85
  const emailAdapter = userController.adapter;
99
-
100
86
  if (verifyUserEmails) {
101
87
  this.validateEmailConfiguration({
102
88
  emailAdapter,
@@ -106,21 +92,17 @@ class Config {
106
92
  emailVerifyTokenReuseIfValid
107
93
  });
108
94
  }
109
-
110
95
  this.validateAccountLockoutPolicy(accountLockout);
111
96
  this.validatePasswordPolicy(passwordPolicy);
112
97
  this.validateFileUploadOptions(fileUpload);
113
-
114
98
  if (typeof revokeSessionOnPasswordReset !== 'boolean') {
115
99
  throw 'revokeSessionOnPasswordReset must be a boolean value';
116
100
  }
117
-
118
101
  if (publicServerURL) {
119
102
  if (!publicServerURL.startsWith('http://') && !publicServerURL.startsWith('https://')) {
120
103
  throw 'publicServerURL should be a valid HTTPS URL starting with https://';
121
104
  }
122
105
  }
123
-
124
106
  this.validateSessionConfiguration(sessionLength, expireInactiveSessions);
125
107
  this.validateMasterKeyIps(masterKeyIps);
126
108
  this.validateDefaultLimit(defaultLimit);
@@ -133,8 +115,9 @@ class Config {
133
115
  this.validateEnforcePrivateUsers(enforcePrivateUsers);
134
116
  this.validateAllowExpiredAuthDataToken(allowExpiredAuthDataToken);
135
117
  this.validateRequestKeywordDenylist(requestKeywordDenylist);
118
+ this.validateRateLimit(rateLimit);
119
+ this.validateLogLevels(logLevels);
136
120
  }
137
-
138
121
  static validateRequestKeywordDenylist(requestKeywordDenylist) {
139
122
  if (requestKeywordDenylist === undefined) {
140
123
  requestKeywordDenylist = requestKeywordDenylist.default;
@@ -142,158 +125,131 @@ class Config {
142
125
  throw 'Parse Server option requestKeywordDenylist must be an array.';
143
126
  }
144
127
  }
145
-
146
128
  static validateEnforcePrivateUsers(enforcePrivateUsers) {
147
129
  if (typeof enforcePrivateUsers !== 'boolean') {
148
130
  throw 'Parse Server option enforcePrivateUsers must be a boolean.';
149
131
  }
150
132
  }
151
-
152
133
  static validateAllowExpiredAuthDataToken(allowExpiredAuthDataToken) {
153
134
  if (typeof allowExpiredAuthDataToken !== 'boolean') {
154
135
  throw 'Parse Server option allowExpiredAuthDataToken must be a boolean.';
155
136
  }
156
137
  }
157
-
158
138
  static validateSecurityOptions(security) {
159
139
  if (Object.prototype.toString.call(security) !== '[object Object]') {
160
140
  throw 'Parse Server option security must be an object.';
161
141
  }
162
-
163
142
  if (security.enableCheck === undefined) {
164
143
  security.enableCheck = _Definitions.SecurityOptions.enableCheck.default;
165
144
  } else if (!(0, _lodash.isBoolean)(security.enableCheck)) {
166
145
  throw 'Parse Server option security.enableCheck must be a boolean.';
167
146
  }
168
-
169
147
  if (security.enableCheckLog === undefined) {
170
148
  security.enableCheckLog = _Definitions.SecurityOptions.enableCheckLog.default;
171
149
  } else if (!(0, _lodash.isBoolean)(security.enableCheckLog)) {
172
150
  throw 'Parse Server option security.enableCheckLog must be a boolean.';
173
151
  }
174
152
  }
175
-
176
153
  static validateSchemaOptions(schema) {
177
154
  if (!schema) return;
178
-
179
155
  if (Object.prototype.toString.call(schema) !== '[object Object]') {
180
156
  throw 'Parse Server option schema must be an object.';
181
157
  }
182
-
183
158
  if (schema.definitions === undefined) {
184
159
  schema.definitions = _Definitions.SchemaOptions.definitions.default;
185
160
  } else if (!Array.isArray(schema.definitions)) {
186
161
  throw 'Parse Server option schema.definitions must be an array.';
187
162
  }
188
-
189
163
  if (schema.strict === undefined) {
190
164
  schema.strict = _Definitions.SchemaOptions.strict.default;
191
165
  } else if (!(0, _lodash.isBoolean)(schema.strict)) {
192
166
  throw 'Parse Server option schema.strict must be a boolean.';
193
167
  }
194
-
195
168
  if (schema.deleteExtraFields === undefined) {
196
169
  schema.deleteExtraFields = _Definitions.SchemaOptions.deleteExtraFields.default;
197
170
  } else if (!(0, _lodash.isBoolean)(schema.deleteExtraFields)) {
198
171
  throw 'Parse Server option schema.deleteExtraFields must be a boolean.';
199
172
  }
200
-
201
173
  if (schema.recreateModifiedFields === undefined) {
202
174
  schema.recreateModifiedFields = _Definitions.SchemaOptions.recreateModifiedFields.default;
203
175
  } else if (!(0, _lodash.isBoolean)(schema.recreateModifiedFields)) {
204
176
  throw 'Parse Server option schema.recreateModifiedFields must be a boolean.';
205
177
  }
206
-
207
178
  if (schema.lockSchemas === undefined) {
208
179
  schema.lockSchemas = _Definitions.SchemaOptions.lockSchemas.default;
209
180
  } else if (!(0, _lodash.isBoolean)(schema.lockSchemas)) {
210
181
  throw 'Parse Server option schema.lockSchemas must be a boolean.';
211
182
  }
212
-
213
183
  if (schema.beforeMigration === undefined) {
214
184
  schema.beforeMigration = null;
215
185
  } else if (schema.beforeMigration !== null && typeof schema.beforeMigration !== 'function') {
216
186
  throw 'Parse Server option schema.beforeMigration must be a function.';
217
187
  }
218
-
219
188
  if (schema.afterMigration === undefined) {
220
189
  schema.afterMigration = null;
221
190
  } else if (schema.afterMigration !== null && typeof schema.afterMigration !== 'function') {
222
191
  throw 'Parse Server option schema.afterMigration must be a function.';
223
192
  }
224
193
  }
225
-
226
194
  static validatePagesOptions(pages) {
227
195
  if (Object.prototype.toString.call(pages) !== '[object Object]') {
228
196
  throw 'Parse Server option pages must be an object.';
229
197
  }
230
-
231
198
  if (pages.enableRouter === undefined) {
232
199
  pages.enableRouter = _Definitions.PagesOptions.enableRouter.default;
233
200
  } else if (!(0, _lodash.isBoolean)(pages.enableRouter)) {
234
201
  throw 'Parse Server option pages.enableRouter must be a boolean.';
235
202
  }
236
-
237
203
  if (pages.enableLocalization === undefined) {
238
204
  pages.enableLocalization = _Definitions.PagesOptions.enableLocalization.default;
239
205
  } else if (!(0, _lodash.isBoolean)(pages.enableLocalization)) {
240
206
  throw 'Parse Server option pages.enableLocalization must be a boolean.';
241
207
  }
242
-
243
208
  if (pages.localizationJsonPath === undefined) {
244
209
  pages.localizationJsonPath = _Definitions.PagesOptions.localizationJsonPath.default;
245
210
  } else if (!(0, _lodash.isString)(pages.localizationJsonPath)) {
246
211
  throw 'Parse Server option pages.localizationJsonPath must be a string.';
247
212
  }
248
-
249
213
  if (pages.localizationFallbackLocale === undefined) {
250
214
  pages.localizationFallbackLocale = _Definitions.PagesOptions.localizationFallbackLocale.default;
251
215
  } else if (!(0, _lodash.isString)(pages.localizationFallbackLocale)) {
252
216
  throw 'Parse Server option pages.localizationFallbackLocale must be a string.';
253
217
  }
254
-
255
218
  if (pages.placeholders === undefined) {
256
219
  pages.placeholders = _Definitions.PagesOptions.placeholders.default;
257
220
  } else if (Object.prototype.toString.call(pages.placeholders) !== '[object Object]' && typeof pages.placeholders !== 'function') {
258
221
  throw 'Parse Server option pages.placeholders must be an object or a function.';
259
222
  }
260
-
261
223
  if (pages.forceRedirect === undefined) {
262
224
  pages.forceRedirect = _Definitions.PagesOptions.forceRedirect.default;
263
225
  } else if (!(0, _lodash.isBoolean)(pages.forceRedirect)) {
264
226
  throw 'Parse Server option pages.forceRedirect must be a boolean.';
265
227
  }
266
-
267
228
  if (pages.pagesPath === undefined) {
268
229
  pages.pagesPath = _Definitions.PagesOptions.pagesPath.default;
269
230
  } else if (!(0, _lodash.isString)(pages.pagesPath)) {
270
231
  throw 'Parse Server option pages.pagesPath must be a string.';
271
232
  }
272
-
273
233
  if (pages.pagesEndpoint === undefined) {
274
234
  pages.pagesEndpoint = _Definitions.PagesOptions.pagesEndpoint.default;
275
235
  } else if (!(0, _lodash.isString)(pages.pagesEndpoint)) {
276
236
  throw 'Parse Server option pages.pagesEndpoint must be a string.';
277
237
  }
278
-
279
238
  if (pages.customUrls === undefined) {
280
239
  pages.customUrls = _Definitions.PagesOptions.customUrls.default;
281
240
  } else if (Object.prototype.toString.call(pages.customUrls) !== '[object Object]') {
282
241
  throw 'Parse Server option pages.customUrls must be an object.';
283
242
  }
284
-
285
243
  if (pages.customRoutes === undefined) {
286
244
  pages.customRoutes = _Definitions.PagesOptions.customRoutes.default;
287
245
  } else if (!(pages.customRoutes instanceof Array)) {
288
246
  throw 'Parse Server option pages.customRoutes must be an array.';
289
247
  }
290
248
  }
291
-
292
249
  static validateIdempotencyOptions(idempotencyOptions) {
293
250
  if (!idempotencyOptions) {
294
251
  return;
295
252
  }
296
-
297
253
  if (idempotencyOptions.ttl === undefined) {
298
254
  idempotencyOptions.ttl = _Definitions.IdempotencyOptions.ttl.default;
299
255
  } else if (!isNaN(idempotencyOptions.ttl) && idempotencyOptions.ttl <= 0) {
@@ -301,24 +257,20 @@ class Config {
301
257
  } else if (isNaN(idempotencyOptions.ttl)) {
302
258
  throw 'idempotency TTL value must be a number';
303
259
  }
304
-
305
260
  if (!idempotencyOptions.paths) {
306
261
  idempotencyOptions.paths = _Definitions.IdempotencyOptions.paths.default;
307
262
  } else if (!(idempotencyOptions.paths instanceof Array)) {
308
263
  throw 'idempotency paths must be of an array of strings';
309
264
  }
310
265
  }
311
-
312
266
  static validateAccountLockoutPolicy(accountLockout) {
313
267
  if (accountLockout) {
314
268
  if (typeof accountLockout.duration !== 'number' || accountLockout.duration <= 0 || accountLockout.duration > 99999) {
315
269
  throw 'Account lockout duration should be greater than 0 and less than 100000';
316
270
  }
317
-
318
271
  if (!Number.isInteger(accountLockout.threshold) || accountLockout.threshold < 1 || accountLockout.threshold > 999) {
319
272
  throw 'Account lockout threshold should be an integer greater than 0 and less than 1000';
320
273
  }
321
-
322
274
  if (accountLockout.unlockOnPasswordReset === undefined) {
323
275
  accountLockout.unlockOnPasswordReset = _Definitions.AccountLockoutOptions.unlockOnPasswordReset.default;
324
276
  } else if (!(0, _lodash.isBoolean)(accountLockout.unlockOnPasswordReset)) {
@@ -326,17 +278,14 @@ class Config {
326
278
  }
327
279
  }
328
280
  }
329
-
330
281
  static validatePasswordPolicy(passwordPolicy) {
331
282
  if (passwordPolicy) {
332
283
  if (passwordPolicy.maxPasswordAge !== undefined && (typeof passwordPolicy.maxPasswordAge !== 'number' || passwordPolicy.maxPasswordAge < 0)) {
333
284
  throw 'passwordPolicy.maxPasswordAge must be a positive number';
334
285
  }
335
-
336
286
  if (passwordPolicy.resetTokenValidityDuration !== undefined && (typeof passwordPolicy.resetTokenValidityDuration !== 'number' || passwordPolicy.resetTokenValidityDuration <= 0)) {
337
287
  throw 'passwordPolicy.resetTokenValidityDuration must be a positive number';
338
288
  }
339
-
340
289
  if (passwordPolicy.validatorPattern) {
341
290
  if (typeof passwordPolicy.validatorPattern === 'string') {
342
291
  passwordPolicy.validatorPattern = new RegExp(passwordPolicy.validatorPattern);
@@ -344,30 +293,25 @@ class Config {
344
293
  throw 'passwordPolicy.validatorPattern must be a regex string or RegExp object.';
345
294
  }
346
295
  }
347
-
348
296
  if (passwordPolicy.validatorCallback && typeof passwordPolicy.validatorCallback !== 'function') {
349
297
  throw 'passwordPolicy.validatorCallback must be a function.';
350
298
  }
351
-
352
299
  if (passwordPolicy.doNotAllowUsername && typeof passwordPolicy.doNotAllowUsername !== 'boolean') {
353
300
  throw 'passwordPolicy.doNotAllowUsername must be a boolean value.';
354
301
  }
355
-
356
302
  if (passwordPolicy.maxPasswordHistory && (!Number.isInteger(passwordPolicy.maxPasswordHistory) || passwordPolicy.maxPasswordHistory <= 0 || passwordPolicy.maxPasswordHistory > 20)) {
357
303
  throw 'passwordPolicy.maxPasswordHistory must be an integer ranging 0 - 20';
358
304
  }
359
-
360
305
  if (passwordPolicy.resetTokenReuseIfValid && typeof passwordPolicy.resetTokenReuseIfValid !== 'boolean') {
361
306
  throw 'resetTokenReuseIfValid must be a boolean value';
362
307
  }
363
-
364
308
  if (passwordPolicy.resetTokenReuseIfValid && !passwordPolicy.resetTokenValidityDuration) {
365
309
  throw 'You cannot use resetTokenReuseIfValid without resetTokenValidityDuration';
366
310
  }
367
311
  }
368
- } // if the passwordPolicy.validatorPattern is configured then setup a callback to process the pattern
369
-
312
+ }
370
313
 
314
+ // if the passwordPolicy.validatorPattern is configured then setup a callback to process the pattern
371
315
  static setupPasswordValidator(passwordPolicy) {
372
316
  if (passwordPolicy && passwordPolicy.validatorPattern) {
373
317
  passwordPolicy.patternValidator = value => {
@@ -375,7 +319,6 @@ class Config {
375
319
  };
376
320
  }
377
321
  }
378
-
379
322
  static validateEmailConfiguration({
380
323
  emailAdapter,
381
324
  appName,
@@ -386,15 +329,12 @@ class Config {
386
329
  if (!emailAdapter) {
387
330
  throw 'An emailAdapter is required for e-mail verification and password resets.';
388
331
  }
389
-
390
332
  if (typeof appName !== 'string') {
391
333
  throw 'An app name is required for e-mail verification and password resets.';
392
334
  }
393
-
394
335
  if (typeof publicServerURL !== 'string') {
395
336
  throw 'A public server url is required for e-mail verification and password resets.';
396
337
  }
397
-
398
338
  if (emailVerifyTokenValidityDuration) {
399
339
  if (isNaN(emailVerifyTokenValidityDuration)) {
400
340
  throw 'Email verify token validity duration must be a valid number.';
@@ -402,16 +342,13 @@ class Config {
402
342
  throw 'Email verify token validity duration must be a value greater than 0.';
403
343
  }
404
344
  }
405
-
406
345
  if (emailVerifyTokenReuseIfValid && typeof emailVerifyTokenReuseIfValid !== 'boolean') {
407
346
  throw 'emailVerifyTokenReuseIfValid must be a boolean value';
408
347
  }
409
-
410
348
  if (emailVerifyTokenReuseIfValid && !emailVerifyTokenValidityDuration) {
411
349
  throw 'You cannot use emailVerifyTokenReuseIfValid without emailVerifyTokenValidityDuration';
412
350
  }
413
351
  }
414
-
415
352
  static validateFileUploadOptions(fileUpload) {
416
353
  try {
417
354
  if (fileUpload == null || typeof fileUpload !== 'object' || fileUpload instanceof Array) {
@@ -421,51 +358,44 @@ class Config {
421
358
  if (e instanceof ReferenceError) {
422
359
  return;
423
360
  }
424
-
425
361
  throw e;
426
362
  }
427
-
428
363
  if (fileUpload.enableForAnonymousUser === undefined) {
429
364
  fileUpload.enableForAnonymousUser = _Definitions.FileUploadOptions.enableForAnonymousUser.default;
430
365
  } else if (typeof fileUpload.enableForAnonymousUser !== 'boolean') {
431
366
  throw 'fileUpload.enableForAnonymousUser must be a boolean value.';
432
367
  }
433
-
434
368
  if (fileUpload.enableForPublic === undefined) {
435
369
  fileUpload.enableForPublic = _Definitions.FileUploadOptions.enableForPublic.default;
436
370
  } else if (typeof fileUpload.enableForPublic !== 'boolean') {
437
371
  throw 'fileUpload.enableForPublic must be a boolean value.';
438
372
  }
439
-
440
373
  if (fileUpload.enableForAuthenticatedUser === undefined) {
441
374
  fileUpload.enableForAuthenticatedUser = _Definitions.FileUploadOptions.enableForAuthenticatedUser.default;
442
375
  } else if (typeof fileUpload.enableForAuthenticatedUser !== 'boolean') {
443
376
  throw 'fileUpload.enableForAuthenticatedUser must be a boolean value.';
444
377
  }
445
378
  }
446
-
447
379
  static validateMasterKeyIps(masterKeyIps) {
448
- for (const ip of masterKeyIps) {
380
+ for (let ip of masterKeyIps) {
381
+ if (ip.includes('/')) {
382
+ ip = ip.split('/')[0];
383
+ }
449
384
  if (!_net.default.isIP(ip)) {
450
- throw `Invalid ip in masterKeyIps: ${ip}`;
385
+ throw `The Parse Server option "masterKeyIps" contains an invalid IP address "${ip}".`;
451
386
  }
452
387
  }
453
388
  }
454
-
455
389
  get mount() {
456
390
  var mount = this._mount;
457
-
458
391
  if (this.publicServerURL) {
459
392
  mount = this.publicServerURL;
460
393
  }
461
-
462
394
  return mount;
463
395
  }
464
-
465
396
  set mount(newValue) {
466
397
  this._mount = newValue;
467
398
  }
468
-
469
399
  static validateSessionConfiguration(sessionLength, expireInactiveSessions) {
470
400
  if (expireInactiveSessions) {
471
401
  if (isNaN(sessionLength)) {
@@ -475,27 +405,22 @@ class Config {
475
405
  }
476
406
  }
477
407
  }
478
-
479
408
  static validateDefaultLimit(defaultLimit) {
480
409
  if (defaultLimit == null) {
481
410
  defaultLimit = _Definitions.ParseServerOptions.defaultLimit.default;
482
411
  }
483
-
484
412
  if (typeof defaultLimit !== 'number') {
485
413
  throw 'Default limit must be a number.';
486
414
  }
487
-
488
415
  if (defaultLimit <= 0) {
489
416
  throw 'Default limit must be a value greater than 0.';
490
417
  }
491
418
  }
492
-
493
419
  static validateMaxLimit(maxLimit) {
494
420
  if (maxLimit <= 0) {
495
421
  throw 'Max limit must be a value greater than 0.';
496
422
  }
497
423
  }
498
-
499
424
  static validateAllowHeaders(allowHeaders) {
500
425
  if (![null, undefined].includes(allowHeaders)) {
501
426
  if (Array.isArray(allowHeaders)) {
@@ -511,84 +436,115 @@ class Config {
511
436
  }
512
437
  }
513
438
  }
514
-
439
+ static validateLogLevels(logLevels) {
440
+ for (const key of Object.keys(_Definitions.LogLevels)) {
441
+ if (logLevels[key]) {
442
+ if (_LoggerController.logLevels.indexOf(logLevels[key]) === -1) {
443
+ throw `'${key}' must be one of ${JSON.stringify(_LoggerController.logLevels)}`;
444
+ }
445
+ } else {
446
+ logLevels[key] = _Definitions.LogLevels[key].default;
447
+ }
448
+ }
449
+ }
450
+ static validateRateLimit(rateLimit) {
451
+ if (!rateLimit) {
452
+ return;
453
+ }
454
+ if (Object.prototype.toString.call(rateLimit) !== '[object Object]' && !Array.isArray(rateLimit)) {
455
+ throw `rateLimit must be an array or object`;
456
+ }
457
+ const options = Array.isArray(rateLimit) ? rateLimit : [rateLimit];
458
+ for (const option of options) {
459
+ if (Object.prototype.toString.call(option) !== '[object Object]') {
460
+ throw `rateLimit must be an array of objects`;
461
+ }
462
+ if (option.requestPath == null) {
463
+ throw `rateLimit.requestPath must be defined`;
464
+ }
465
+ if (typeof option.requestPath !== 'string') {
466
+ throw `rateLimit.requestPath must be a string`;
467
+ }
468
+ if (option.requestTimeWindow == null) {
469
+ throw `rateLimit.requestTimeWindow must be defined`;
470
+ }
471
+ if (typeof option.requestTimeWindow !== 'number') {
472
+ throw `rateLimit.requestTimeWindow must be a number`;
473
+ }
474
+ if (option.includeInternalRequests && typeof option.includeInternalRequests !== 'boolean') {
475
+ throw `rateLimit.includeInternalRequests must be a boolean`;
476
+ }
477
+ if (option.requestCount == null) {
478
+ throw `rateLimit.requestCount must be defined`;
479
+ }
480
+ if (typeof option.requestCount !== 'number') {
481
+ throw `rateLimit.requestCount must be a number`;
482
+ }
483
+ if (option.errorResponseMessage && typeof option.errorResponseMessage !== 'string') {
484
+ throw `rateLimit.errorResponseMessage must be a string`;
485
+ }
486
+ }
487
+ }
515
488
  generateEmailVerifyTokenExpiresAt() {
516
489
  if (!this.verifyUserEmails || !this.emailVerifyTokenValidityDuration) {
517
490
  return undefined;
518
491
  }
519
-
520
492
  var now = new Date();
521
493
  return new Date(now.getTime() + this.emailVerifyTokenValidityDuration * 1000);
522
494
  }
523
-
524
495
  generatePasswordResetTokenExpiresAt() {
525
496
  if (!this.passwordPolicy || !this.passwordPolicy.resetTokenValidityDuration) {
526
497
  return undefined;
527
498
  }
528
-
529
499
  const now = new Date();
530
500
  return new Date(now.getTime() + this.passwordPolicy.resetTokenValidityDuration * 1000);
531
501
  }
532
-
533
502
  generateSessionExpiresAt() {
534
503
  if (!this.expireInactiveSessions) {
535
504
  return undefined;
536
505
  }
537
-
538
506
  var now = new Date();
539
507
  return new Date(now.getTime() + this.sessionLength * 1000);
540
508
  }
541
-
542
509
  get invalidLinkURL() {
543
510
  return this.customPages.invalidLink || `${this.publicServerURL}/apps/invalid_link.html`;
544
511
  }
545
-
546
512
  get invalidVerificationLinkURL() {
547
513
  return this.customPages.invalidVerificationLink || `${this.publicServerURL}/apps/invalid_verification_link.html`;
548
514
  }
549
-
550
515
  get linkSendSuccessURL() {
551
516
  return this.customPages.linkSendSuccess || `${this.publicServerURL}/apps/link_send_success.html`;
552
517
  }
553
-
554
518
  get linkSendFailURL() {
555
519
  return this.customPages.linkSendFail || `${this.publicServerURL}/apps/link_send_fail.html`;
556
520
  }
557
-
558
521
  get verifyEmailSuccessURL() {
559
522
  return this.customPages.verifyEmailSuccess || `${this.publicServerURL}/apps/verify_email_success.html`;
560
523
  }
561
-
562
524
  get choosePasswordURL() {
563
525
  return this.customPages.choosePassword || `${this.publicServerURL}/apps/choose_password`;
564
526
  }
565
-
566
527
  get requestResetPasswordURL() {
567
528
  return `${this.publicServerURL}/${this.pagesEndpoint}/${this.applicationId}/request_password_reset`;
568
529
  }
569
-
570
530
  get passwordResetSuccessURL() {
571
531
  return this.customPages.passwordResetSuccess || `${this.publicServerURL}/apps/password_reset_success.html`;
572
532
  }
573
-
574
533
  get parseFrameURL() {
575
534
  return this.customPages.parseFrameURL;
576
535
  }
577
-
578
536
  get verifyEmailURL() {
579
537
  return `${this.publicServerURL}/${this.pagesEndpoint}/${this.applicationId}/verify_email`;
580
- } // TODO: Remove this function once PagesRouter replaces the PublicAPIRouter;
581
- // the (default) endpoint has to be defined in PagesRouter only.
582
-
538
+ }
583
539
 
540
+ // TODO: Remove this function once PagesRouter replaces the PublicAPIRouter;
541
+ // the (default) endpoint has to be defined in PagesRouter only.
584
542
  get pagesEndpoint() {
585
543
  return this.pages && this.pages.enableRouter && this.pages.pagesEndpoint ? this.pages.pagesEndpoint : 'apps';
586
544
  }
587
-
588
545
  }
589
-
590
546
  exports.Config = Config;
591
547
  var _default = Config;
592
548
  exports.default = _default;
593
549
  module.exports = Config;
594
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Config.js"],"names":["removeTrailingSlash","str","endsWith","substr","length","Config","get","applicationId","mount","cacheInfo","AppCache","config","Object","keys","forEach","key","database","DatabaseController","databaseController","adapter","generateSessionExpiresAt","bind","generateEmailVerifyTokenExpiresAt","put","serverConfiguration","validate","appId","setupPasswordValidator","passwordPolicy","verifyUserEmails","userController","appName","publicServerURL","revokeSessionOnPasswordReset","expireInactiveSessions","sessionLength","defaultLimit","maxLimit","emailVerifyTokenValidityDuration","accountLockout","masterKeyIps","masterKey","readOnlyMasterKey","allowHeaders","idempotencyOptions","emailVerifyTokenReuseIfValid","fileUpload","pages","security","enforcePrivateUsers","schema","requestKeywordDenylist","allowExpiredAuthDataToken","Error","emailAdapter","validateEmailConfiguration","validateAccountLockoutPolicy","validatePasswordPolicy","validateFileUploadOptions","startsWith","validateSessionConfiguration","validateMasterKeyIps","validateDefaultLimit","validateMaxLimit","validateAllowHeaders","validateIdempotencyOptions","validatePagesOptions","validateSecurityOptions","validateSchemaOptions","validateEnforcePrivateUsers","validateAllowExpiredAuthDataToken","validateRequestKeywordDenylist","undefined","default","Array","isArray","prototype","toString","call","enableCheck","SecurityOptions","enableCheckLog","definitions","SchemaOptions","strict","deleteExtraFields","recreateModifiedFields","lockSchemas","beforeMigration","afterMigration","enableRouter","PagesOptions","enableLocalization","localizationJsonPath","localizationFallbackLocale","placeholders","forceRedirect","pagesPath","pagesEndpoint","customUrls","customRoutes","ttl","IdempotencyOptions","isNaN","paths","duration","Number","isInteger","threshold","unlockOnPasswordReset","AccountLockoutOptions","maxPasswordAge","resetTokenValidityDuration","validatorPattern","RegExp","validatorCallback","doNotAllowUsername","maxPasswordHistory","resetTokenReuseIfValid","patternValidator","value","test","e","ReferenceError","enableForAnonymousUser","FileUploadOptions","enableForPublic","enableForAuthenticatedUser","ip","net","isIP","_mount","newValue","ParseServerOptions","includes","header","trim","now","Date","getTime","generatePasswordResetTokenExpiresAt","invalidLinkURL","customPages","invalidLink","invalidVerificationLinkURL","invalidVerificationLink","linkSendSuccessURL","linkSendSuccess","linkSendFailURL","linkSendFail","verifyEmailSuccessURL","verifyEmailSuccess","choosePasswordURL","choosePassword","requestResetPasswordURL","passwordResetSuccessURL","passwordResetSuccess","parseFrameURL","verifyEmailURL","module","exports"],"mappings":";;;;;;;AAIA;;AACA;;AACA;;AACA;;AASA;;;;AAhBA;AACA;AACA;AAgBA,SAASA,mBAAT,CAA6BC,GAA7B,EAAkC;AAChC,MAAI,CAACA,GAAL,EAAU;AACR,WAAOA,GAAP;AACD;;AACD,MAAIA,GAAG,CAACC,QAAJ,CAAa,GAAb,CAAJ,EAAuB;AACrBD,IAAAA,GAAG,GAAGA,GAAG,CAACE,MAAJ,CAAW,CAAX,EAAcF,GAAG,CAACG,MAAJ,GAAa,CAA3B,CAAN;AACD;;AACD,SAAOH,GAAP;AACD;;AAEM,MAAMI,MAAN,CAAa;AACR,SAAHC,GAAG,CAACC,aAAD,EAAwBC,KAAxB,EAAuC;AAC/C,UAAMC,SAAS,GAAGC,eAASJ,GAAT,CAAaC,aAAb,CAAlB;;AACA,QAAI,CAACE,SAAL,EAAgB;AACd;AACD;;AACD,UAAME,MAAM,GAAG,IAAIN,MAAJ,EAAf;AACAM,IAAAA,MAAM,CAACJ,aAAP,GAAuBA,aAAvB;AACAK,IAAAA,MAAM,CAACC,IAAP,CAAYJ,SAAZ,EAAuBK,OAAvB,CAA+BC,GAAG,IAAI;AACpC,UAAIA,GAAG,IAAI,oBAAX,EAAiC;AAC/BJ,QAAAA,MAAM,CAACK,QAAP,GAAkB,IAAIC,2BAAJ,CAAuBR,SAAS,CAACS,kBAAV,CAA6BC,OAApD,EAA6DR,MAA7D,CAAlB;AACD,OAFD,MAEO;AACLA,QAAAA,MAAM,CAACI,GAAD,CAAN,GAAcN,SAAS,CAACM,GAAD,CAAvB;AACD;AACF,KAND;AAOAJ,IAAAA,MAAM,CAACH,KAAP,GAAeR,mBAAmB,CAACQ,KAAD,CAAlC;AACAG,IAAAA,MAAM,CAACS,wBAAP,GAAkCT,MAAM,CAACS,wBAAP,CAAgCC,IAAhC,CAAqCV,MAArC,CAAlC;AACAA,IAAAA,MAAM,CAACW,iCAAP,GAA2CX,MAAM,CAACW,iCAAP,CAAyCD,IAAzC,CACzCV,MADyC,CAA3C;AAGA,WAAOA,MAAP;AACD;;AAES,SAAHY,GAAG,CAACC,mBAAD,EAAsB;AAC9BnB,IAAAA,MAAM,CAACoB,QAAP,CAAgBD,mBAAhB;;AACAd,mBAASa,GAAT,CAAaC,mBAAmB,CAACE,KAAjC,EAAwCF,mBAAxC;;AACAnB,IAAAA,MAAM,CAACsB,sBAAP,CAA8BH,mBAAmB,CAACI,cAAlD;AACA,WAAOJ,mBAAP;AACD;;AAEc,SAARC,QAAQ,CAAC;AACdI,IAAAA,gBADc;AAEdC,IAAAA,cAFc;AAGdC,IAAAA,OAHc;AAIdC,IAAAA,eAJc;AAKdC,IAAAA,4BALc;AAMdC,IAAAA,sBANc;AAOdC,IAAAA,aAPc;AAQdC,IAAAA,YARc;AASdC,IAAAA,QATc;AAUdC,IAAAA,gCAVc;AAWdC,IAAAA,cAXc;AAYdX,IAAAA,cAZc;AAadY,IAAAA,YAbc;AAcdC,IAAAA,SAdc;AAedC,IAAAA,iBAfc;AAgBdC,IAAAA,YAhBc;AAiBdC,IAAAA,kBAjBc;AAkBdC,IAAAA,4BAlBc;AAmBdC,IAAAA,UAnBc;AAoBdC,IAAAA,KApBc;AAqBdC,IAAAA,QArBc;AAsBdC,IAAAA,mBAtBc;AAuBdC,IAAAA,MAvBc;AAwBdC,IAAAA,sBAxBc;AAyBdC,IAAAA;AAzBc,GAAD,EA0BZ;AACD,QAAIX,SAAS,KAAKC,iBAAlB,EAAqC;AACnC,YAAM,IAAIW,KAAJ,CAAU,qDAAV,CAAN;AACD;;AAED,UAAMC,YAAY,GAAGxB,cAAc,CAACX,OAApC;;AACA,QAAIU,gBAAJ,EAAsB;AACpB,WAAK0B,0BAAL,CAAgC;AAC9BD,QAAAA,YAD8B;AAE9BvB,QAAAA,OAF8B;AAG9BC,QAAAA,eAH8B;AAI9BM,QAAAA,gCAJ8B;AAK9BO,QAAAA;AAL8B,OAAhC;AAOD;;AAED,SAAKW,4BAAL,CAAkCjB,cAAlC;AACA,SAAKkB,sBAAL,CAA4B7B,cAA5B;AACA,SAAK8B,yBAAL,CAA+BZ,UAA/B;;AAEA,QAAI,OAAOb,4BAAP,KAAwC,SAA5C,EAAuD;AACrD,YAAM,sDAAN;AACD;;AAED,QAAID,eAAJ,EAAqB;AACnB,UAAI,CAACA,eAAe,CAAC2B,UAAhB,CAA2B,SAA3B,CAAD,IAA0C,CAAC3B,eAAe,CAAC2B,UAAhB,CAA2B,UAA3B,CAA/C,EAAuF;AACrF,cAAM,oEAAN;AACD;AACF;;AACD,SAAKC,4BAAL,CAAkCzB,aAAlC,EAAiDD,sBAAjD;AACA,SAAK2B,oBAAL,CAA0BrB,YAA1B;AACA,SAAKsB,oBAAL,CAA0B1B,YAA1B;AACA,SAAK2B,gBAAL,CAAsB1B,QAAtB;AACA,SAAK2B,oBAAL,CAA0BrB,YAA1B;AACA,SAAKsB,0BAAL,CAAgCrB,kBAAhC;AACA,SAAKsB,oBAAL,CAA0BnB,KAA1B;AACA,SAAKoB,uBAAL,CAA6BnB,QAA7B;AACA,SAAKoB,qBAAL,CAA2BlB,MAA3B;AACA,SAAKmB,2BAAL,CAAiCpB,mBAAjC;AACA,SAAKqB,iCAAL,CAAuClB,yBAAvC;AACA,SAAKmB,8BAAL,CAAoCpB,sBAApC;AACD;;AAEoC,SAA9BoB,8BAA8B,CAACpB,sBAAD,EAAyB;AAC5D,QAAIA,sBAAsB,KAAKqB,SAA/B,EAA0C;AACxCrB,MAAAA,sBAAsB,GAAGA,sBAAsB,CAACsB,OAAhD;AACD,KAFD,MAEO,IAAI,CAACC,KAAK,CAACC,OAAN,CAAcxB,sBAAd,CAAL,EAA4C;AACjD,YAAM,8DAAN;AACD;AACF;;AAEiC,SAA3BkB,2BAA2B,CAACpB,mBAAD,EAAsB;AACtD,QAAI,OAAOA,mBAAP,KAA+B,SAAnC,EAA8C;AAC5C,YAAM,4DAAN;AACD;AACF;;AAEuC,SAAjCqB,iCAAiC,CAAClB,yBAAD,EAA4B;AAClE,QAAI,OAAOA,yBAAP,KAAqC,SAAzC,EAAoD;AAClD,YAAM,kEAAN;AACD;AACF;;AAE6B,SAAvBe,uBAAuB,CAACnB,QAAD,EAAW;AACvC,QAAIpC,MAAM,CAACgE,SAAP,CAAiBC,QAAjB,CAA0BC,IAA1B,CAA+B9B,QAA/B,MAA6C,iBAAjD,EAAoE;AAClE,YAAM,iDAAN;AACD;;AACD,QAAIA,QAAQ,CAAC+B,WAAT,KAAyBP,SAA7B,EAAwC;AACtCxB,MAAAA,QAAQ,CAAC+B,WAAT,GAAuBC,6BAAgBD,WAAhB,CAA4BN,OAAnD;AACD,KAFD,MAEO,IAAI,CAAC,uBAAUzB,QAAQ,CAAC+B,WAAnB,CAAL,EAAsC;AAC3C,YAAM,6DAAN;AACD;;AACD,QAAI/B,QAAQ,CAACiC,cAAT,KAA4BT,SAAhC,EAA2C;AACzCxB,MAAAA,QAAQ,CAACiC,cAAT,GAA0BD,6BAAgBC,cAAhB,CAA+BR,OAAzD;AACD,KAFD,MAEO,IAAI,CAAC,uBAAUzB,QAAQ,CAACiC,cAAnB,CAAL,EAAyC;AAC9C,YAAM,gEAAN;AACD;AACF;;AAE2B,SAArBb,qBAAqB,CAAClB,MAAD,EAAwB;AAClD,QAAI,CAACA,MAAL,EAAa;;AACb,QAAItC,MAAM,CAACgE,SAAP,CAAiBC,QAAjB,CAA0BC,IAA1B,CAA+B5B,MAA/B,MAA2C,iBAA/C,EAAkE;AAChE,YAAM,+CAAN;AACD;;AACD,QAAIA,MAAM,CAACgC,WAAP,KAAuBV,SAA3B,EAAsC;AACpCtB,MAAAA,MAAM,CAACgC,WAAP,GAAqBC,2BAAcD,WAAd,CAA0BT,OAA/C;AACD,KAFD,MAEO,IAAI,CAACC,KAAK,CAACC,OAAN,CAAczB,MAAM,CAACgC,WAArB,CAAL,EAAwC;AAC7C,YAAM,0DAAN;AACD;;AACD,QAAIhC,MAAM,CAACkC,MAAP,KAAkBZ,SAAtB,EAAiC;AAC/BtB,MAAAA,MAAM,CAACkC,MAAP,GAAgBD,2BAAcC,MAAd,CAAqBX,OAArC;AACD,KAFD,MAEO,IAAI,CAAC,uBAAUvB,MAAM,CAACkC,MAAjB,CAAL,EAA+B;AACpC,YAAM,sDAAN;AACD;;AACD,QAAIlC,MAAM,CAACmC,iBAAP,KAA6Bb,SAAjC,EAA4C;AAC1CtB,MAAAA,MAAM,CAACmC,iBAAP,GAA2BF,2BAAcE,iBAAd,CAAgCZ,OAA3D;AACD,KAFD,MAEO,IAAI,CAAC,uBAAUvB,MAAM,CAACmC,iBAAjB,CAAL,EAA0C;AAC/C,YAAM,iEAAN;AACD;;AACD,QAAInC,MAAM,CAACoC,sBAAP,KAAkCd,SAAtC,EAAiD;AAC/CtB,MAAAA,MAAM,CAACoC,sBAAP,GAAgCH,2BAAcG,sBAAd,CAAqCb,OAArE;AACD,KAFD,MAEO,IAAI,CAAC,uBAAUvB,MAAM,CAACoC,sBAAjB,CAAL,EAA+C;AACpD,YAAM,sEAAN;AACD;;AACD,QAAIpC,MAAM,CAACqC,WAAP,KAAuBf,SAA3B,EAAsC;AACpCtB,MAAAA,MAAM,CAACqC,WAAP,GAAqBJ,2BAAcI,WAAd,CAA0Bd,OAA/C;AACD,KAFD,MAEO,IAAI,CAAC,uBAAUvB,MAAM,CAACqC,WAAjB,CAAL,EAAoC;AACzC,YAAM,2DAAN;AACD;;AACD,QAAIrC,MAAM,CAACsC,eAAP,KAA2BhB,SAA/B,EAA0C;AACxCtB,MAAAA,MAAM,CAACsC,eAAP,GAAyB,IAAzB;AACD,KAFD,MAEO,IAAItC,MAAM,CAACsC,eAAP,KAA2B,IAA3B,IAAmC,OAAOtC,MAAM,CAACsC,eAAd,KAAkC,UAAzE,EAAqF;AAC1F,YAAM,gEAAN;AACD;;AACD,QAAItC,MAAM,CAACuC,cAAP,KAA0BjB,SAA9B,EAAyC;AACvCtB,MAAAA,MAAM,CAACuC,cAAP,GAAwB,IAAxB;AACD,KAFD,MAEO,IAAIvC,MAAM,CAACuC,cAAP,KAA0B,IAA1B,IAAkC,OAAOvC,MAAM,CAACuC,cAAd,KAAiC,UAAvE,EAAmF;AACxF,YAAM,+DAAN;AACD;AACF;;AAE0B,SAApBvB,oBAAoB,CAACnB,KAAD,EAAQ;AACjC,QAAInC,MAAM,CAACgE,SAAP,CAAiBC,QAAjB,CAA0BC,IAA1B,CAA+B/B,KAA/B,MAA0C,iBAA9C,EAAiE;AAC/D,YAAM,8CAAN;AACD;;AACD,QAAIA,KAAK,CAAC2C,YAAN,KAAuBlB,SAA3B,EAAsC;AACpCzB,MAAAA,KAAK,CAAC2C,YAAN,GAAqBC,0BAAaD,YAAb,CAA0BjB,OAA/C;AACD,KAFD,MAEO,IAAI,CAAC,uBAAU1B,KAAK,CAAC2C,YAAhB,CAAL,EAAoC;AACzC,YAAM,2DAAN;AACD;;AACD,QAAI3C,KAAK,CAAC6C,kBAAN,KAA6BpB,SAAjC,EAA4C;AAC1CzB,MAAAA,KAAK,CAAC6C,kBAAN,GAA2BD,0BAAaC,kBAAb,CAAgCnB,OAA3D;AACD,KAFD,MAEO,IAAI,CAAC,uBAAU1B,KAAK,CAAC6C,kBAAhB,CAAL,EAA0C;AAC/C,YAAM,iEAAN;AACD;;AACD,QAAI7C,KAAK,CAAC8C,oBAAN,KAA+BrB,SAAnC,EAA8C;AAC5CzB,MAAAA,KAAK,CAAC8C,oBAAN,GAA6BF,0BAAaE,oBAAb,CAAkCpB,OAA/D;AACD,KAFD,MAEO,IAAI,CAAC,sBAAS1B,KAAK,CAAC8C,oBAAf,CAAL,EAA2C;AAChD,YAAM,kEAAN;AACD;;AACD,QAAI9C,KAAK,CAAC+C,0BAAN,KAAqCtB,SAAzC,EAAoD;AAClDzB,MAAAA,KAAK,CAAC+C,0BAAN,GAAmCH,0BAAaG,0BAAb,CAAwCrB,OAA3E;AACD,KAFD,MAEO,IAAI,CAAC,sBAAS1B,KAAK,CAAC+C,0BAAf,CAAL,EAAiD;AACtD,YAAM,wEAAN;AACD;;AACD,QAAI/C,KAAK,CAACgD,YAAN,KAAuBvB,SAA3B,EAAsC;AACpCzB,MAAAA,KAAK,CAACgD,YAAN,GAAqBJ,0BAAaI,YAAb,CAA0BtB,OAA/C;AACD,KAFD,MAEO,IACL7D,MAAM,CAACgE,SAAP,CAAiBC,QAAjB,CAA0BC,IAA1B,CAA+B/B,KAAK,CAACgD,YAArC,MAAuD,iBAAvD,IACA,OAAOhD,KAAK,CAACgD,YAAb,KAA8B,UAFzB,EAGL;AACA,YAAM,yEAAN;AACD;;AACD,QAAIhD,KAAK,CAACiD,aAAN,KAAwBxB,SAA5B,EAAuC;AACrCzB,MAAAA,KAAK,CAACiD,aAAN,GAAsBL,0BAAaK,aAAb,CAA2BvB,OAAjD;AACD,KAFD,MAEO,IAAI,CAAC,uBAAU1B,KAAK,CAACiD,aAAhB,CAAL,EAAqC;AAC1C,YAAM,4DAAN;AACD;;AACD,QAAIjD,KAAK,CAACkD,SAAN,KAAoBzB,SAAxB,EAAmC;AACjCzB,MAAAA,KAAK,CAACkD,SAAN,GAAkBN,0BAAaM,SAAb,CAAuBxB,OAAzC;AACD,KAFD,MAEO,IAAI,CAAC,sBAAS1B,KAAK,CAACkD,SAAf,CAAL,EAAgC;AACrC,YAAM,uDAAN;AACD;;AACD,QAAIlD,KAAK,CAACmD,aAAN,KAAwB1B,SAA5B,EAAuC;AACrCzB,MAAAA,KAAK,CAACmD,aAAN,GAAsBP,0BAAaO,aAAb,CAA2BzB,OAAjD;AACD,KAFD,MAEO,IAAI,CAAC,sBAAS1B,KAAK,CAACmD,aAAf,CAAL,EAAoC;AACzC,YAAM,2DAAN;AACD;;AACD,QAAInD,KAAK,CAACoD,UAAN,KAAqB3B,SAAzB,EAAoC;AAClCzB,MAAAA,KAAK,CAACoD,UAAN,GAAmBR,0BAAaQ,UAAb,CAAwB1B,OAA3C;AACD,KAFD,MAEO,IAAI7D,MAAM,CAACgE,SAAP,CAAiBC,QAAjB,CAA0BC,IAA1B,CAA+B/B,KAAK,CAACoD,UAArC,MAAqD,iBAAzD,EAA4E;AACjF,YAAM,yDAAN;AACD;;AACD,QAAIpD,KAAK,CAACqD,YAAN,KAAuB5B,SAA3B,EAAsC;AACpCzB,MAAAA,KAAK,CAACqD,YAAN,GAAqBT,0BAAaS,YAAb,CAA0B3B,OAA/C;AACD,KAFD,MAEO,IAAI,EAAE1B,KAAK,CAACqD,YAAN,YAA8B1B,KAAhC,CAAJ,EAA4C;AACjD,YAAM,0DAAN;AACD;AACF;;AAEgC,SAA1BT,0BAA0B,CAACrB,kBAAD,EAAqB;AACpD,QAAI,CAACA,kBAAL,EAAyB;AACvB;AACD;;AACD,QAAIA,kBAAkB,CAACyD,GAAnB,KAA2B7B,SAA/B,EAA0C;AACxC5B,MAAAA,kBAAkB,CAACyD,GAAnB,GAAyBC,gCAAmBD,GAAnB,CAAuB5B,OAAhD;AACD,KAFD,MAEO,IAAI,CAAC8B,KAAK,CAAC3D,kBAAkB,CAACyD,GAApB,CAAN,IAAkCzD,kBAAkB,CAACyD,GAAnB,IAA0B,CAAhE,EAAmE;AACxE,YAAM,sDAAN;AACD,KAFM,MAEA,IAAIE,KAAK,CAAC3D,kBAAkB,CAACyD,GAApB,CAAT,EAAmC;AACxC,YAAM,wCAAN;AACD;;AACD,QAAI,CAACzD,kBAAkB,CAAC4D,KAAxB,EAA+B;AAC7B5D,MAAAA,kBAAkB,CAAC4D,KAAnB,GAA2BF,gCAAmBE,KAAnB,CAAyB/B,OAApD;AACD,KAFD,MAEO,IAAI,EAAE7B,kBAAkB,CAAC4D,KAAnB,YAAoC9B,KAAtC,CAAJ,EAAkD;AACvD,YAAM,kDAAN;AACD;AACF;;AAEkC,SAA5BlB,4BAA4B,CAACjB,cAAD,EAAiB;AAClD,QAAIA,cAAJ,EAAoB;AAClB,UACE,OAAOA,cAAc,CAACkE,QAAtB,KAAmC,QAAnC,IACAlE,cAAc,CAACkE,QAAf,IAA2B,CAD3B,IAEAlE,cAAc,CAACkE,QAAf,GAA0B,KAH5B,EAIE;AACA,cAAM,wEAAN;AACD;;AAED,UACE,CAACC,MAAM,CAACC,SAAP,CAAiBpE,cAAc,CAACqE,SAAhC,CAAD,IACArE,cAAc,CAACqE,SAAf,GAA2B,CAD3B,IAEArE,cAAc,CAACqE,SAAf,GAA2B,GAH7B,EAIE;AACA,cAAM,kFAAN;AACD;;AAED,UAAIrE,cAAc,CAACsE,qBAAf,KAAyCrC,SAA7C,EAAwD;AACtDjC,QAAAA,cAAc,CAACsE,qBAAf,GAAuCC,mCAAsBD,qBAAtB,CAA4CpC,OAAnF;AACD,OAFD,MAEO,IAAI,CAAC,uBAAUlC,cAAc,CAACsE,qBAAzB,CAAL,EAAsD;AAC3D,cAAM,6EAAN;AACD;AACF;AACF;;AAE4B,SAAtBpD,sBAAsB,CAAC7B,cAAD,EAAiB;AAC5C,QAAIA,cAAJ,EAAoB;AAClB,UACEA,cAAc,CAACmF,cAAf,KAAkCvC,SAAlC,KACC,OAAO5C,cAAc,CAACmF,cAAtB,KAAyC,QAAzC,IAAqDnF,cAAc,CAACmF,cAAf,GAAgC,CADtF,CADF,EAGE;AACA,cAAM,yDAAN;AACD;;AAED,UACEnF,cAAc,CAACoF,0BAAf,KAA8CxC,SAA9C,KACC,OAAO5C,cAAc,CAACoF,0BAAtB,KAAqD,QAArD,IACCpF,cAAc,CAACoF,0BAAf,IAA6C,CAF/C,CADF,EAIE;AACA,cAAM,qEAAN;AACD;;AAED,UAAIpF,cAAc,CAACqF,gBAAnB,EAAqC;AACnC,YAAI,OAAOrF,cAAc,CAACqF,gBAAtB,KAA2C,QAA/C,EAAyD;AACvDrF,UAAAA,cAAc,CAACqF,gBAAf,GAAkC,IAAIC,MAAJ,CAAWtF,cAAc,CAACqF,gBAA1B,CAAlC;AACD,SAFD,MAEO,IAAI,EAAErF,cAAc,CAACqF,gBAAf,YAA2CC,MAA7C,CAAJ,EAA0D;AAC/D,gBAAM,0EAAN;AACD;AACF;;AAED,UACEtF,cAAc,CAACuF,iBAAf,IACA,OAAOvF,cAAc,CAACuF,iBAAtB,KAA4C,UAF9C,EAGE;AACA,cAAM,sDAAN;AACD;;AAED,UACEvF,cAAc,CAACwF,kBAAf,IACA,OAAOxF,cAAc,CAACwF,kBAAtB,KAA6C,SAF/C,EAGE;AACA,cAAM,4DAAN;AACD;;AAED,UACExF,cAAc,CAACyF,kBAAf,KACC,CAACX,MAAM,CAACC,SAAP,CAAiB/E,cAAc,CAACyF,kBAAhC,CAAD,IACCzF,cAAc,CAACyF,kBAAf,IAAqC,CADtC,IAECzF,cAAc,CAACyF,kBAAf,GAAoC,EAHtC,CADF,EAKE;AACA,cAAM,qEAAN;AACD;;AAED,UACEzF,cAAc,CAAC0F,sBAAf,IACA,OAAO1F,cAAc,CAAC0F,sBAAtB,KAAiD,SAFnD,EAGE;AACA,cAAM,gDAAN;AACD;;AACD,UAAI1F,cAAc,CAAC0F,sBAAf,IAAyC,CAAC1F,cAAc,CAACoF,0BAA7D,EAAyF;AACvF,cAAM,0EAAN;AACD;AACF;AACF,GAlViB,CAoVlB;;;AAC6B,SAAtBrF,sBAAsB,CAACC,cAAD,EAAiB;AAC5C,QAAIA,cAAc,IAAIA,cAAc,CAACqF,gBAArC,EAAuD;AACrDrF,MAAAA,cAAc,CAAC2F,gBAAf,GAAkCC,KAAK,IAAI;AACzC,eAAO5F,cAAc,CAACqF,gBAAf,CAAgCQ,IAAhC,CAAqCD,KAArC,CAAP;AACD,OAFD;AAGD;AACF;;AAEgC,SAA1BjE,0BAA0B,CAAC;AAChCD,IAAAA,YADgC;AAEhCvB,IAAAA,OAFgC;AAGhCC,IAAAA,eAHgC;AAIhCM,IAAAA,gCAJgC;AAKhCO,IAAAA;AALgC,GAAD,EAM9B;AACD,QAAI,CAACS,YAAL,EAAmB;AACjB,YAAM,0EAAN;AACD;;AACD,QAAI,OAAOvB,OAAP,KAAmB,QAAvB,EAAiC;AAC/B,YAAM,sEAAN;AACD;;AACD,QAAI,OAAOC,eAAP,KAA2B,QAA/B,EAAyC;AACvC,YAAM,8EAAN;AACD;;AACD,QAAIM,gCAAJ,EAAsC;AACpC,UAAIiE,KAAK,CAACjE,gCAAD,CAAT,EAA6C;AAC3C,cAAM,8DAAN;AACD,OAFD,MAEO,IAAIA,gCAAgC,IAAI,CAAxC,EAA2C;AAChD,cAAM,sEAAN;AACD;AACF;;AACD,QAAIO,4BAA4B,IAAI,OAAOA,4BAAP,KAAwC,SAA5E,EAAuF;AACrF,YAAM,sDAAN;AACD;;AACD,QAAIA,4BAA4B,IAAI,CAACP,gCAArC,EAAuE;AACrE,YAAM,sFAAN;AACD;AACF;;AAE+B,SAAzBoB,yBAAyB,CAACZ,UAAD,EAAa;AAC3C,QAAI;AACF,UAAIA,UAAU,IAAI,IAAd,IAAsB,OAAOA,UAAP,KAAsB,QAA5C,IAAwDA,UAAU,YAAY4B,KAAlF,EAAyF;AACvF,cAAM,qCAAN;AACD;AACF,KAJD,CAIE,OAAOgD,CAAP,EAAU;AACV,UAAIA,CAAC,YAAYC,cAAjB,EAAiC;AAC/B;AACD;;AACD,YAAMD,CAAN;AACD;;AACD,QAAI5E,UAAU,CAAC8E,sBAAX,KAAsCpD,SAA1C,EAAqD;AACnD1B,MAAAA,UAAU,CAAC8E,sBAAX,GAAoCC,+BAAkBD,sBAAlB,CAAyCnD,OAA7E;AACD,KAFD,MAEO,IAAI,OAAO3B,UAAU,CAAC8E,sBAAlB,KAA6C,SAAjD,EAA4D;AACjE,YAAM,4DAAN;AACD;;AACD,QAAI9E,UAAU,CAACgF,eAAX,KAA+BtD,SAAnC,EAA8C;AAC5C1B,MAAAA,UAAU,CAACgF,eAAX,GAA6BD,+BAAkBC,eAAlB,CAAkCrD,OAA/D;AACD,KAFD,MAEO,IAAI,OAAO3B,UAAU,CAACgF,eAAlB,KAAsC,SAA1C,EAAqD;AAC1D,YAAM,qDAAN;AACD;;AACD,QAAIhF,UAAU,CAACiF,0BAAX,KAA0CvD,SAA9C,EAAyD;AACvD1B,MAAAA,UAAU,CAACiF,0BAAX,GAAwCF,+BAAkBE,0BAAlB,CAA6CtD,OAArF;AACD,KAFD,MAEO,IAAI,OAAO3B,UAAU,CAACiF,0BAAlB,KAAiD,SAArD,EAAgE;AACrE,YAAM,gEAAN;AACD;AACF;;AAE0B,SAApBlE,oBAAoB,CAACrB,YAAD,EAAe;AACxC,SAAK,MAAMwF,EAAX,IAAiBxF,YAAjB,EAA+B;AAC7B,UAAI,CAACyF,aAAIC,IAAJ,CAASF,EAAT,CAAL,EAAmB;AACjB,cAAO,+BAA8BA,EAAG,EAAxC;AACD;AACF;AACF;;AAEQ,MAALxH,KAAK,GAAG;AACV,QAAIA,KAAK,GAAG,KAAK2H,MAAjB;;AACA,QAAI,KAAKnG,eAAT,EAA0B;AACxBxB,MAAAA,KAAK,GAAG,KAAKwB,eAAb;AACD;;AACD,WAAOxB,KAAP;AACD;;AAEQ,MAALA,KAAK,CAAC4H,QAAD,EAAW;AAClB,SAAKD,MAAL,GAAcC,QAAd;AACD;;AAEkC,SAA5BxE,4BAA4B,CAACzB,aAAD,EAAgBD,sBAAhB,EAAwC;AACzE,QAAIA,sBAAJ,EAA4B;AAC1B,UAAIqE,KAAK,CAACpE,aAAD,CAAT,EAA0B;AACxB,cAAM,wCAAN;AACD,OAFD,MAEO,IAAIA,aAAa,IAAI,CAArB,EAAwB;AAC7B,cAAM,gDAAN;AACD;AACF;AACF;;AAE0B,SAApB2B,oBAAoB,CAAC1B,YAAD,EAAe;AACxC,QAAIA,YAAY,IAAI,IAApB,EAA0B;AACxBA,MAAAA,YAAY,GAAGiG,gCAAmBjG,YAAnB,CAAgCqC,OAA/C;AACD;;AACD,QAAI,OAAOrC,YAAP,KAAwB,QAA5B,EAAsC;AACpC,YAAM,iCAAN;AACD;;AACD,QAAIA,YAAY,IAAI,CAApB,EAAuB;AACrB,YAAM,+CAAN;AACD;AACF;;AAEsB,SAAhB2B,gBAAgB,CAAC1B,QAAD,EAAW;AAChC,QAAIA,QAAQ,IAAI,CAAhB,EAAmB;AACjB,YAAM,2CAAN;AACD;AACF;;AAE0B,SAApB2B,oBAAoB,CAACrB,YAAD,EAAe;AACxC,QAAI,CAAC,CAAC,IAAD,EAAO6B,SAAP,EAAkB8D,QAAlB,CAA2B3F,YAA3B,CAAL,EAA+C;AAC7C,UAAI+B,KAAK,CAACC,OAAN,CAAchC,YAAd,CAAJ,EAAiC;AAC/BA,QAAAA,YAAY,CAAC7B,OAAb,CAAqByH,MAAM,IAAI;AAC7B,cAAI,OAAOA,MAAP,KAAkB,QAAtB,EAAgC;AAC9B,kBAAM,yCAAN;AACD,WAFD,MAEO,IAAI,CAACA,MAAM,CAACC,IAAP,GAAcpI,MAAnB,EAA2B;AAChC,kBAAM,8CAAN;AACD;AACF,SAND;AAOD,OARD,MAQO;AACL,cAAM,gCAAN;AACD;AACF;AACF;;AAEDkB,EAAAA,iCAAiC,GAAG;AAClC,QAAI,CAAC,KAAKO,gBAAN,IAA0B,CAAC,KAAKS,gCAApC,EAAsE;AACpE,aAAOkC,SAAP;AACD;;AACD,QAAIiE,GAAG,GAAG,IAAIC,IAAJ,EAAV;AACA,WAAO,IAAIA,IAAJ,CAASD,GAAG,CAACE,OAAJ,KAAgB,KAAKrG,gCAAL,GAAwC,IAAjE,CAAP;AACD;;AAEDsG,EAAAA,mCAAmC,GAAG;AACpC,QAAI,CAAC,KAAKhH,cAAN,IAAwB,CAAC,KAAKA,cAAL,CAAoBoF,0BAAjD,EAA6E;AAC3E,aAAOxC,SAAP;AACD;;AACD,UAAMiE,GAAG,GAAG,IAAIC,IAAJ,EAAZ;AACA,WAAO,IAAIA,IAAJ,CAASD,GAAG,CAACE,OAAJ,KAAgB,KAAK/G,cAAL,CAAoBoF,0BAApB,GAAiD,IAA1E,CAAP;AACD;;AAED5F,EAAAA,wBAAwB,GAAG;AACzB,QAAI,CAAC,KAAKc,sBAAV,EAAkC;AAChC,aAAOsC,SAAP;AACD;;AACD,QAAIiE,GAAG,GAAG,IAAIC,IAAJ,EAAV;AACA,WAAO,IAAIA,IAAJ,CAASD,GAAG,CAACE,OAAJ,KAAgB,KAAKxG,aAAL,GAAqB,IAA9C,CAAP;AACD;;AAEiB,MAAd0G,cAAc,GAAG;AACnB,WAAO,KAAKC,WAAL,CAAiBC,WAAjB,IAAiC,GAAE,KAAK/G,eAAgB,yBAA/D;AACD;;AAE6B,MAA1BgH,0BAA0B,GAAG;AAC/B,WACE,KAAKF,WAAL,CAAiBG,uBAAjB,IACC,GAAE,KAAKjH,eAAgB,sCAF1B;AAID;;AAEqB,MAAlBkH,kBAAkB,GAAG;AACvB,WACE,KAAKJ,WAAL,CAAiBK,eAAjB,IAAqC,GAAE,KAAKnH,eAAgB,8BAD9D;AAGD;;AAEkB,MAAfoH,eAAe,GAAG;AACpB,WAAO,KAAKN,WAAL,CAAiBO,YAAjB,IAAkC,GAAE,KAAKrH,eAAgB,2BAAhE;AACD;;AAEwB,MAArBsH,qBAAqB,GAAG;AAC1B,WACE,KAAKR,WAAL,CAAiBS,kBAAjB,IACC,GAAE,KAAKvH,eAAgB,iCAF1B;AAID;;AAEoB,MAAjBwH,iBAAiB,GAAG;AACtB,WAAO,KAAKV,WAAL,CAAiBW,cAAjB,IAAoC,GAAE,KAAKzH,eAAgB,uBAAlE;AACD;;AAE0B,MAAvB0H,uBAAuB,GAAG;AAC5B,WAAQ,GAAE,KAAK1H,eAAgB,IAAG,KAAKkE,aAAc,IAAG,KAAK3F,aAAc,yBAA3E;AACD;;AAE0B,MAAvBoJ,uBAAuB,GAAG;AAC5B,WACE,KAAKb,WAAL,CAAiBc,oBAAjB,IACC,GAAE,KAAK5H,eAAgB,mCAF1B;AAID;;AAEgB,MAAb6H,aAAa,GAAG;AAClB,WAAO,KAAKf,WAAL,CAAiBe,aAAxB;AACD;;AAEiB,MAAdC,cAAc,GAAG;AACnB,WAAQ,GAAE,KAAK9H,eAAgB,IAAG,KAAKkE,aAAc,IAAG,KAAK3F,aAAc,eAA3E;AACD,GAjiBiB,CAmiBlB;AACA;;;AACiB,MAAb2F,aAAa,GAAG;AAClB,WAAO,KAAKnD,KAAL,IAAc,KAAKA,KAAL,CAAW2C,YAAzB,IAAyC,KAAK3C,KAAL,CAAWmD,aAApD,GACH,KAAKnD,KAAL,CAAWmD,aADR,GAEH,MAFJ;AAGD;;AAziBiB;;;eA4iBL7F,M;;AACf0J,MAAM,CAACC,OAAP,GAAiB3J,MAAjB","sourcesContent":["// A Config object provides information about how a specific app is\n// configured.\n// mount is the URL for the root of the API; includes http, domain, etc.\n\nimport AppCache from './cache';\nimport DatabaseController from './Controllers/DatabaseController';\nimport net from 'net';\nimport {\n  IdempotencyOptions,\n  FileUploadOptions,\n  AccountLockoutOptions,\n  PagesOptions,\n  SecurityOptions,\n  SchemaOptions,\n  ParseServerOptions,\n} from './Options/Definitions';\nimport { isBoolean, isString } from 'lodash';\n\nfunction removeTrailingSlash(str) {\n  if (!str) {\n    return str;\n  }\n  if (str.endsWith('/')) {\n    str = str.substr(0, str.length - 1);\n  }\n  return str;\n}\n\nexport class Config {\n  static get(applicationId: string, mount: string) {\n    const cacheInfo = AppCache.get(applicationId);\n    if (!cacheInfo) {\n      return;\n    }\n    const config = new Config();\n    config.applicationId = applicationId;\n    Object.keys(cacheInfo).forEach(key => {\n      if (key == 'databaseController') {\n        config.database = new DatabaseController(cacheInfo.databaseController.adapter, config);\n      } else {\n        config[key] = cacheInfo[key];\n      }\n    });\n    config.mount = removeTrailingSlash(mount);\n    config.generateSessionExpiresAt = config.generateSessionExpiresAt.bind(config);\n    config.generateEmailVerifyTokenExpiresAt = config.generateEmailVerifyTokenExpiresAt.bind(\n      config\n    );\n    return config;\n  }\n\n  static put(serverConfiguration) {\n    Config.validate(serverConfiguration);\n    AppCache.put(serverConfiguration.appId, serverConfiguration);\n    Config.setupPasswordValidator(serverConfiguration.passwordPolicy);\n    return serverConfiguration;\n  }\n\n  static validate({\n    verifyUserEmails,\n    userController,\n    appName,\n    publicServerURL,\n    revokeSessionOnPasswordReset,\n    expireInactiveSessions,\n    sessionLength,\n    defaultLimit,\n    maxLimit,\n    emailVerifyTokenValidityDuration,\n    accountLockout,\n    passwordPolicy,\n    masterKeyIps,\n    masterKey,\n    readOnlyMasterKey,\n    allowHeaders,\n    idempotencyOptions,\n    emailVerifyTokenReuseIfValid,\n    fileUpload,\n    pages,\n    security,\n    enforcePrivateUsers,\n    schema,\n    requestKeywordDenylist,\n    allowExpiredAuthDataToken,\n  }) {\n    if (masterKey === readOnlyMasterKey) {\n      throw new Error('masterKey and readOnlyMasterKey should be different');\n    }\n\n    const emailAdapter = userController.adapter;\n    if (verifyUserEmails) {\n      this.validateEmailConfiguration({\n        emailAdapter,\n        appName,\n        publicServerURL,\n        emailVerifyTokenValidityDuration,\n        emailVerifyTokenReuseIfValid,\n      });\n    }\n\n    this.validateAccountLockoutPolicy(accountLockout);\n    this.validatePasswordPolicy(passwordPolicy);\n    this.validateFileUploadOptions(fileUpload);\n\n    if (typeof revokeSessionOnPasswordReset !== 'boolean') {\n      throw 'revokeSessionOnPasswordReset must be a boolean value';\n    }\n\n    if (publicServerURL) {\n      if (!publicServerURL.startsWith('http://') && !publicServerURL.startsWith('https://')) {\n        throw 'publicServerURL should be a valid HTTPS URL starting with https://';\n      }\n    }\n    this.validateSessionConfiguration(sessionLength, expireInactiveSessions);\n    this.validateMasterKeyIps(masterKeyIps);\n    this.validateDefaultLimit(defaultLimit);\n    this.validateMaxLimit(maxLimit);\n    this.validateAllowHeaders(allowHeaders);\n    this.validateIdempotencyOptions(idempotencyOptions);\n    this.validatePagesOptions(pages);\n    this.validateSecurityOptions(security);\n    this.validateSchemaOptions(schema);\n    this.validateEnforcePrivateUsers(enforcePrivateUsers);\n    this.validateAllowExpiredAuthDataToken(allowExpiredAuthDataToken);\n    this.validateRequestKeywordDenylist(requestKeywordDenylist);\n  }\n\n  static validateRequestKeywordDenylist(requestKeywordDenylist) {\n    if (requestKeywordDenylist === undefined) {\n      requestKeywordDenylist = requestKeywordDenylist.default;\n    } else if (!Array.isArray(requestKeywordDenylist)) {\n      throw 'Parse Server option requestKeywordDenylist must be an array.';\n    }\n  }\n\n  static validateEnforcePrivateUsers(enforcePrivateUsers) {\n    if (typeof enforcePrivateUsers !== 'boolean') {\n      throw 'Parse Server option enforcePrivateUsers must be a boolean.';\n    }\n  }\n\n  static validateAllowExpiredAuthDataToken(allowExpiredAuthDataToken) {\n    if (typeof allowExpiredAuthDataToken !== 'boolean') {\n      throw 'Parse Server option allowExpiredAuthDataToken must be a boolean.';\n    }\n  }\n\n  static validateSecurityOptions(security) {\n    if (Object.prototype.toString.call(security) !== '[object Object]') {\n      throw 'Parse Server option security must be an object.';\n    }\n    if (security.enableCheck === undefined) {\n      security.enableCheck = SecurityOptions.enableCheck.default;\n    } else if (!isBoolean(security.enableCheck)) {\n      throw 'Parse Server option security.enableCheck must be a boolean.';\n    }\n    if (security.enableCheckLog === undefined) {\n      security.enableCheckLog = SecurityOptions.enableCheckLog.default;\n    } else if (!isBoolean(security.enableCheckLog)) {\n      throw 'Parse Server option security.enableCheckLog must be a boolean.';\n    }\n  }\n\n  static validateSchemaOptions(schema: SchemaOptions) {\n    if (!schema) return;\n    if (Object.prototype.toString.call(schema) !== '[object Object]') {\n      throw 'Parse Server option schema must be an object.';\n    }\n    if (schema.definitions === undefined) {\n      schema.definitions = SchemaOptions.definitions.default;\n    } else if (!Array.isArray(schema.definitions)) {\n      throw 'Parse Server option schema.definitions must be an array.';\n    }\n    if (schema.strict === undefined) {\n      schema.strict = SchemaOptions.strict.default;\n    } else if (!isBoolean(schema.strict)) {\n      throw 'Parse Server option schema.strict must be a boolean.';\n    }\n    if (schema.deleteExtraFields === undefined) {\n      schema.deleteExtraFields = SchemaOptions.deleteExtraFields.default;\n    } else if (!isBoolean(schema.deleteExtraFields)) {\n      throw 'Parse Server option schema.deleteExtraFields must be a boolean.';\n    }\n    if (schema.recreateModifiedFields === undefined) {\n      schema.recreateModifiedFields = SchemaOptions.recreateModifiedFields.default;\n    } else if (!isBoolean(schema.recreateModifiedFields)) {\n      throw 'Parse Server option schema.recreateModifiedFields must be a boolean.';\n    }\n    if (schema.lockSchemas === undefined) {\n      schema.lockSchemas = SchemaOptions.lockSchemas.default;\n    } else if (!isBoolean(schema.lockSchemas)) {\n      throw 'Parse Server option schema.lockSchemas must be a boolean.';\n    }\n    if (schema.beforeMigration === undefined) {\n      schema.beforeMigration = null;\n    } else if (schema.beforeMigration !== null && typeof schema.beforeMigration !== 'function') {\n      throw 'Parse Server option schema.beforeMigration must be a function.';\n    }\n    if (schema.afterMigration === undefined) {\n      schema.afterMigration = null;\n    } else if (schema.afterMigration !== null && typeof schema.afterMigration !== 'function') {\n      throw 'Parse Server option schema.afterMigration must be a function.';\n    }\n  }\n\n  static validatePagesOptions(pages) {\n    if (Object.prototype.toString.call(pages) !== '[object Object]') {\n      throw 'Parse Server option pages must be an object.';\n    }\n    if (pages.enableRouter === undefined) {\n      pages.enableRouter = PagesOptions.enableRouter.default;\n    } else if (!isBoolean(pages.enableRouter)) {\n      throw 'Parse Server option pages.enableRouter must be a boolean.';\n    }\n    if (pages.enableLocalization === undefined) {\n      pages.enableLocalization = PagesOptions.enableLocalization.default;\n    } else if (!isBoolean(pages.enableLocalization)) {\n      throw 'Parse Server option pages.enableLocalization must be a boolean.';\n    }\n    if (pages.localizationJsonPath === undefined) {\n      pages.localizationJsonPath = PagesOptions.localizationJsonPath.default;\n    } else if (!isString(pages.localizationJsonPath)) {\n      throw 'Parse Server option pages.localizationJsonPath must be a string.';\n    }\n    if (pages.localizationFallbackLocale === undefined) {\n      pages.localizationFallbackLocale = PagesOptions.localizationFallbackLocale.default;\n    } else if (!isString(pages.localizationFallbackLocale)) {\n      throw 'Parse Server option pages.localizationFallbackLocale must be a string.';\n    }\n    if (pages.placeholders === undefined) {\n      pages.placeholders = PagesOptions.placeholders.default;\n    } else if (\n      Object.prototype.toString.call(pages.placeholders) !== '[object Object]' &&\n      typeof pages.placeholders !== 'function'\n    ) {\n      throw 'Parse Server option pages.placeholders must be an object or a function.';\n    }\n    if (pages.forceRedirect === undefined) {\n      pages.forceRedirect = PagesOptions.forceRedirect.default;\n    } else if (!isBoolean(pages.forceRedirect)) {\n      throw 'Parse Server option pages.forceRedirect must be a boolean.';\n    }\n    if (pages.pagesPath === undefined) {\n      pages.pagesPath = PagesOptions.pagesPath.default;\n    } else if (!isString(pages.pagesPath)) {\n      throw 'Parse Server option pages.pagesPath must be a string.';\n    }\n    if (pages.pagesEndpoint === undefined) {\n      pages.pagesEndpoint = PagesOptions.pagesEndpoint.default;\n    } else if (!isString(pages.pagesEndpoint)) {\n      throw 'Parse Server option pages.pagesEndpoint must be a string.';\n    }\n    if (pages.customUrls === undefined) {\n      pages.customUrls = PagesOptions.customUrls.default;\n    } else if (Object.prototype.toString.call(pages.customUrls) !== '[object Object]') {\n      throw 'Parse Server option pages.customUrls must be an object.';\n    }\n    if (pages.customRoutes === undefined) {\n      pages.customRoutes = PagesOptions.customRoutes.default;\n    } else if (!(pages.customRoutes instanceof Array)) {\n      throw 'Parse Server option pages.customRoutes must be an array.';\n    }\n  }\n\n  static validateIdempotencyOptions(idempotencyOptions) {\n    if (!idempotencyOptions) {\n      return;\n    }\n    if (idempotencyOptions.ttl === undefined) {\n      idempotencyOptions.ttl = IdempotencyOptions.ttl.default;\n    } else if (!isNaN(idempotencyOptions.ttl) && idempotencyOptions.ttl <= 0) {\n      throw 'idempotency TTL value must be greater than 0 seconds';\n    } else if (isNaN(idempotencyOptions.ttl)) {\n      throw 'idempotency TTL value must be a number';\n    }\n    if (!idempotencyOptions.paths) {\n      idempotencyOptions.paths = IdempotencyOptions.paths.default;\n    } else if (!(idempotencyOptions.paths instanceof Array)) {\n      throw 'idempotency paths must be of an array of strings';\n    }\n  }\n\n  static validateAccountLockoutPolicy(accountLockout) {\n    if (accountLockout) {\n      if (\n        typeof accountLockout.duration !== 'number' ||\n        accountLockout.duration <= 0 ||\n        accountLockout.duration > 99999\n      ) {\n        throw 'Account lockout duration should be greater than 0 and less than 100000';\n      }\n\n      if (\n        !Number.isInteger(accountLockout.threshold) ||\n        accountLockout.threshold < 1 ||\n        accountLockout.threshold > 999\n      ) {\n        throw 'Account lockout threshold should be an integer greater than 0 and less than 1000';\n      }\n\n      if (accountLockout.unlockOnPasswordReset === undefined) {\n        accountLockout.unlockOnPasswordReset = AccountLockoutOptions.unlockOnPasswordReset.default;\n      } else if (!isBoolean(accountLockout.unlockOnPasswordReset)) {\n        throw 'Parse Server option accountLockout.unlockOnPasswordReset must be a boolean.';\n      }\n    }\n  }\n\n  static validatePasswordPolicy(passwordPolicy) {\n    if (passwordPolicy) {\n      if (\n        passwordPolicy.maxPasswordAge !== undefined &&\n        (typeof passwordPolicy.maxPasswordAge !== 'number' || passwordPolicy.maxPasswordAge < 0)\n      ) {\n        throw 'passwordPolicy.maxPasswordAge must be a positive number';\n      }\n\n      if (\n        passwordPolicy.resetTokenValidityDuration !== undefined &&\n        (typeof passwordPolicy.resetTokenValidityDuration !== 'number' ||\n          passwordPolicy.resetTokenValidityDuration <= 0)\n      ) {\n        throw 'passwordPolicy.resetTokenValidityDuration must be a positive number';\n      }\n\n      if (passwordPolicy.validatorPattern) {\n        if (typeof passwordPolicy.validatorPattern === 'string') {\n          passwordPolicy.validatorPattern = new RegExp(passwordPolicy.validatorPattern);\n        } else if (!(passwordPolicy.validatorPattern instanceof RegExp)) {\n          throw 'passwordPolicy.validatorPattern must be a regex string or RegExp object.';\n        }\n      }\n\n      if (\n        passwordPolicy.validatorCallback &&\n        typeof passwordPolicy.validatorCallback !== 'function'\n      ) {\n        throw 'passwordPolicy.validatorCallback must be a function.';\n      }\n\n      if (\n        passwordPolicy.doNotAllowUsername &&\n        typeof passwordPolicy.doNotAllowUsername !== 'boolean'\n      ) {\n        throw 'passwordPolicy.doNotAllowUsername must be a boolean value.';\n      }\n\n      if (\n        passwordPolicy.maxPasswordHistory &&\n        (!Number.isInteger(passwordPolicy.maxPasswordHistory) ||\n          passwordPolicy.maxPasswordHistory <= 0 ||\n          passwordPolicy.maxPasswordHistory > 20)\n      ) {\n        throw 'passwordPolicy.maxPasswordHistory must be an integer ranging 0 - 20';\n      }\n\n      if (\n        passwordPolicy.resetTokenReuseIfValid &&\n        typeof passwordPolicy.resetTokenReuseIfValid !== 'boolean'\n      ) {\n        throw 'resetTokenReuseIfValid must be a boolean value';\n      }\n      if (passwordPolicy.resetTokenReuseIfValid && !passwordPolicy.resetTokenValidityDuration) {\n        throw 'You cannot use resetTokenReuseIfValid without resetTokenValidityDuration';\n      }\n    }\n  }\n\n  // if the passwordPolicy.validatorPattern is configured then setup a callback to process the pattern\n  static setupPasswordValidator(passwordPolicy) {\n    if (passwordPolicy && passwordPolicy.validatorPattern) {\n      passwordPolicy.patternValidator = value => {\n        return passwordPolicy.validatorPattern.test(value);\n      };\n    }\n  }\n\n  static validateEmailConfiguration({\n    emailAdapter,\n    appName,\n    publicServerURL,\n    emailVerifyTokenValidityDuration,\n    emailVerifyTokenReuseIfValid,\n  }) {\n    if (!emailAdapter) {\n      throw 'An emailAdapter is required for e-mail verification and password resets.';\n    }\n    if (typeof appName !== 'string') {\n      throw 'An app name is required for e-mail verification and password resets.';\n    }\n    if (typeof publicServerURL !== 'string') {\n      throw 'A public server url is required for e-mail verification and password resets.';\n    }\n    if (emailVerifyTokenValidityDuration) {\n      if (isNaN(emailVerifyTokenValidityDuration)) {\n        throw 'Email verify token validity duration must be a valid number.';\n      } else if (emailVerifyTokenValidityDuration <= 0) {\n        throw 'Email verify token validity duration must be a value greater than 0.';\n      }\n    }\n    if (emailVerifyTokenReuseIfValid && typeof emailVerifyTokenReuseIfValid !== 'boolean') {\n      throw 'emailVerifyTokenReuseIfValid must be a boolean value';\n    }\n    if (emailVerifyTokenReuseIfValid && !emailVerifyTokenValidityDuration) {\n      throw 'You cannot use emailVerifyTokenReuseIfValid without emailVerifyTokenValidityDuration';\n    }\n  }\n\n  static validateFileUploadOptions(fileUpload) {\n    try {\n      if (fileUpload == null || typeof fileUpload !== 'object' || fileUpload instanceof Array) {\n        throw 'fileUpload must be an object value.';\n      }\n    } catch (e) {\n      if (e instanceof ReferenceError) {\n        return;\n      }\n      throw e;\n    }\n    if (fileUpload.enableForAnonymousUser === undefined) {\n      fileUpload.enableForAnonymousUser = FileUploadOptions.enableForAnonymousUser.default;\n    } else if (typeof fileUpload.enableForAnonymousUser !== 'boolean') {\n      throw 'fileUpload.enableForAnonymousUser must be a boolean value.';\n    }\n    if (fileUpload.enableForPublic === undefined) {\n      fileUpload.enableForPublic = FileUploadOptions.enableForPublic.default;\n    } else if (typeof fileUpload.enableForPublic !== 'boolean') {\n      throw 'fileUpload.enableForPublic must be a boolean value.';\n    }\n    if (fileUpload.enableForAuthenticatedUser === undefined) {\n      fileUpload.enableForAuthenticatedUser = FileUploadOptions.enableForAuthenticatedUser.default;\n    } else if (typeof fileUpload.enableForAuthenticatedUser !== 'boolean') {\n      throw 'fileUpload.enableForAuthenticatedUser must be a boolean value.';\n    }\n  }\n\n  static validateMasterKeyIps(masterKeyIps) {\n    for (const ip of masterKeyIps) {\n      if (!net.isIP(ip)) {\n        throw `Invalid ip in masterKeyIps: ${ip}`;\n      }\n    }\n  }\n\n  get mount() {\n    var mount = this._mount;\n    if (this.publicServerURL) {\n      mount = this.publicServerURL;\n    }\n    return mount;\n  }\n\n  set mount(newValue) {\n    this._mount = newValue;\n  }\n\n  static validateSessionConfiguration(sessionLength, expireInactiveSessions) {\n    if (expireInactiveSessions) {\n      if (isNaN(sessionLength)) {\n        throw 'Session length must be a valid number.';\n      } else if (sessionLength <= 0) {\n        throw 'Session length must be a value greater than 0.';\n      }\n    }\n  }\n\n  static validateDefaultLimit(defaultLimit) {\n    if (defaultLimit == null) {\n      defaultLimit = ParseServerOptions.defaultLimit.default;\n    }\n    if (typeof defaultLimit !== 'number') {\n      throw 'Default limit must be a number.';\n    }\n    if (defaultLimit <= 0) {\n      throw 'Default limit must be a value greater than 0.';\n    }\n  }\n\n  static validateMaxLimit(maxLimit) {\n    if (maxLimit <= 0) {\n      throw 'Max limit must be a value greater than 0.';\n    }\n  }\n\n  static validateAllowHeaders(allowHeaders) {\n    if (![null, undefined].includes(allowHeaders)) {\n      if (Array.isArray(allowHeaders)) {\n        allowHeaders.forEach(header => {\n          if (typeof header !== 'string') {\n            throw 'Allow headers must only contain strings';\n          } else if (!header.trim().length) {\n            throw 'Allow headers must not contain empty strings';\n          }\n        });\n      } else {\n        throw 'Allow headers must be an array';\n      }\n    }\n  }\n\n  generateEmailVerifyTokenExpiresAt() {\n    if (!this.verifyUserEmails || !this.emailVerifyTokenValidityDuration) {\n      return undefined;\n    }\n    var now = new Date();\n    return new Date(now.getTime() + this.emailVerifyTokenValidityDuration * 1000);\n  }\n\n  generatePasswordResetTokenExpiresAt() {\n    if (!this.passwordPolicy || !this.passwordPolicy.resetTokenValidityDuration) {\n      return undefined;\n    }\n    const now = new Date();\n    return new Date(now.getTime() + this.passwordPolicy.resetTokenValidityDuration * 1000);\n  }\n\n  generateSessionExpiresAt() {\n    if (!this.expireInactiveSessions) {\n      return undefined;\n    }\n    var now = new Date();\n    return new Date(now.getTime() + this.sessionLength * 1000);\n  }\n\n  get invalidLinkURL() {\n    return this.customPages.invalidLink || `${this.publicServerURL}/apps/invalid_link.html`;\n  }\n\n  get invalidVerificationLinkURL() {\n    return (\n      this.customPages.invalidVerificationLink ||\n      `${this.publicServerURL}/apps/invalid_verification_link.html`\n    );\n  }\n\n  get linkSendSuccessURL() {\n    return (\n      this.customPages.linkSendSuccess || `${this.publicServerURL}/apps/link_send_success.html`\n    );\n  }\n\n  get linkSendFailURL() {\n    return this.customPages.linkSendFail || `${this.publicServerURL}/apps/link_send_fail.html`;\n  }\n\n  get verifyEmailSuccessURL() {\n    return (\n      this.customPages.verifyEmailSuccess ||\n      `${this.publicServerURL}/apps/verify_email_success.html`\n    );\n  }\n\n  get choosePasswordURL() {\n    return this.customPages.choosePassword || `${this.publicServerURL}/apps/choose_password`;\n  }\n\n  get requestResetPasswordURL() {\n    return `${this.publicServerURL}/${this.pagesEndpoint}/${this.applicationId}/request_password_reset`;\n  }\n\n  get passwordResetSuccessURL() {\n    return (\n      this.customPages.passwordResetSuccess ||\n      `${this.publicServerURL}/apps/password_reset_success.html`\n    );\n  }\n\n  get parseFrameURL() {\n    return this.customPages.parseFrameURL;\n  }\n\n  get verifyEmailURL() {\n    return `${this.publicServerURL}/${this.pagesEndpoint}/${this.applicationId}/verify_email`;\n  }\n\n  // TODO: Remove this function once PagesRouter replaces the PublicAPIRouter;\n  // the (default) endpoint has to be defined in PagesRouter only.\n  get pagesEndpoint() {\n    return this.pages && this.pages.enableRouter && this.pages.pagesEndpoint\n      ? this.pages.pagesEndpoint\n      : 'apps';\n  }\n}\n\nexport default Config;\nmodule.exports = Config;\n"]}
550
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["removeTrailingSlash","str","endsWith","substr","length","Config","get","applicationId","mount","cacheInfo","AppCache","config","Object","keys","forEach","key","database","DatabaseController","databaseController","adapter","generateSessionExpiresAt","bind","generateEmailVerifyTokenExpiresAt","put","serverConfiguration","validate","appId","setupPasswordValidator","passwordPolicy","verifyUserEmails","userController","appName","publicServerURL","revokeSessionOnPasswordReset","expireInactiveSessions","sessionLength","defaultLimit","maxLimit","emailVerifyTokenValidityDuration","accountLockout","masterKeyIps","masterKey","readOnlyMasterKey","allowHeaders","idempotencyOptions","emailVerifyTokenReuseIfValid","fileUpload","pages","security","enforcePrivateUsers","schema","requestKeywordDenylist","allowExpiredAuthDataToken","logLevels","rateLimit","Error","emailAdapter","validateEmailConfiguration","validateAccountLockoutPolicy","validatePasswordPolicy","validateFileUploadOptions","startsWith","validateSessionConfiguration","validateMasterKeyIps","validateDefaultLimit","validateMaxLimit","validateAllowHeaders","validateIdempotencyOptions","validatePagesOptions","validateSecurityOptions","validateSchemaOptions","validateEnforcePrivateUsers","validateAllowExpiredAuthDataToken","validateRequestKeywordDenylist","validateRateLimit","validateLogLevels","undefined","default","Array","isArray","prototype","toString","call","enableCheck","SecurityOptions","isBoolean","enableCheckLog","definitions","SchemaOptions","strict","deleteExtraFields","recreateModifiedFields","lockSchemas","beforeMigration","afterMigration","enableRouter","PagesOptions","enableLocalization","localizationJsonPath","isString","localizationFallbackLocale","placeholders","forceRedirect","pagesPath","pagesEndpoint","customUrls","customRoutes","ttl","IdempotencyOptions","isNaN","paths","duration","Number","isInteger","threshold","unlockOnPasswordReset","AccountLockoutOptions","maxPasswordAge","resetTokenValidityDuration","validatorPattern","RegExp","validatorCallback","doNotAllowUsername","maxPasswordHistory","resetTokenReuseIfValid","patternValidator","value","test","e","ReferenceError","enableForAnonymousUser","FileUploadOptions","enableForPublic","enableForAuthenticatedUser","ip","includes","split","net","isIP","_mount","newValue","ParseServerOptions","header","trim","LogLevels","validLogLevels","indexOf","JSON","stringify","options","option","requestPath","requestTimeWindow","includeInternalRequests","requestCount","errorResponseMessage","now","Date","getTime","generatePasswordResetTokenExpiresAt","invalidLinkURL","customPages","invalidLink","invalidVerificationLinkURL","invalidVerificationLink","linkSendSuccessURL","linkSendSuccess","linkSendFailURL","linkSendFail","verifyEmailSuccessURL","verifyEmailSuccess","choosePasswordURL","choosePassword","requestResetPasswordURL","passwordResetSuccessURL","passwordResetSuccess","parseFrameURL","verifyEmailURL","module","exports"],"sources":["../src/Config.js"],"sourcesContent":["// A Config object provides information about how a specific app is\n// configured.\n// mount is the URL for the root of the API; includes http, domain, etc.\n\nimport { isBoolean, isString } from 'lodash';\nimport net from 'net';\nimport AppCache from './cache';\nimport DatabaseController from './Controllers/DatabaseController';\nimport { logLevels as validLogLevels } from './Controllers/LoggerController';\nimport {\n  AccountLockoutOptions,\n  FileUploadOptions,\n  IdempotencyOptions,\n  LogLevels,\n  PagesOptions,\n  ParseServerOptions,\n  SchemaOptions,\n  SecurityOptions,\n} from './Options/Definitions';\n\nfunction removeTrailingSlash(str) {\n  if (!str) {\n    return str;\n  }\n  if (str.endsWith('/')) {\n    str = str.substr(0, str.length - 1);\n  }\n  return str;\n}\n\nexport class Config {\n  static get(applicationId: string, mount: string) {\n    const cacheInfo = AppCache.get(applicationId);\n    if (!cacheInfo) {\n      return;\n    }\n    const config = new Config();\n    config.applicationId = applicationId;\n    Object.keys(cacheInfo).forEach(key => {\n      if (key == 'databaseController') {\n        config.database = new DatabaseController(cacheInfo.databaseController.adapter, config);\n      } else {\n        config[key] = cacheInfo[key];\n      }\n    });\n    config.mount = removeTrailingSlash(mount);\n    config.generateSessionExpiresAt = config.generateSessionExpiresAt.bind(config);\n    config.generateEmailVerifyTokenExpiresAt = config.generateEmailVerifyTokenExpiresAt.bind(\n      config\n    );\n    return config;\n  }\n\n  static put(serverConfiguration) {\n    Config.validate(serverConfiguration);\n    AppCache.put(serverConfiguration.appId, serverConfiguration);\n    Config.setupPasswordValidator(serverConfiguration.passwordPolicy);\n    return serverConfiguration;\n  }\n\n  static validate({\n    verifyUserEmails,\n    userController,\n    appName,\n    publicServerURL,\n    revokeSessionOnPasswordReset,\n    expireInactiveSessions,\n    sessionLength,\n    defaultLimit,\n    maxLimit,\n    emailVerifyTokenValidityDuration,\n    accountLockout,\n    passwordPolicy,\n    masterKeyIps,\n    masterKey,\n    readOnlyMasterKey,\n    allowHeaders,\n    idempotencyOptions,\n    emailVerifyTokenReuseIfValid,\n    fileUpload,\n    pages,\n    security,\n    enforcePrivateUsers,\n    schema,\n    requestKeywordDenylist,\n    allowExpiredAuthDataToken,\n    logLevels,\n    rateLimit,\n  }) {\n    if (masterKey === readOnlyMasterKey) {\n      throw new Error('masterKey and readOnlyMasterKey should be different');\n    }\n\n    const emailAdapter = userController.adapter;\n    if (verifyUserEmails) {\n      this.validateEmailConfiguration({\n        emailAdapter,\n        appName,\n        publicServerURL,\n        emailVerifyTokenValidityDuration,\n        emailVerifyTokenReuseIfValid,\n      });\n    }\n\n    this.validateAccountLockoutPolicy(accountLockout);\n    this.validatePasswordPolicy(passwordPolicy);\n    this.validateFileUploadOptions(fileUpload);\n\n    if (typeof revokeSessionOnPasswordReset !== 'boolean') {\n      throw 'revokeSessionOnPasswordReset must be a boolean value';\n    }\n\n    if (publicServerURL) {\n      if (!publicServerURL.startsWith('http://') && !publicServerURL.startsWith('https://')) {\n        throw 'publicServerURL should be a valid HTTPS URL starting with https://';\n      }\n    }\n    this.validateSessionConfiguration(sessionLength, expireInactiveSessions);\n    this.validateMasterKeyIps(masterKeyIps);\n    this.validateDefaultLimit(defaultLimit);\n    this.validateMaxLimit(maxLimit);\n    this.validateAllowHeaders(allowHeaders);\n    this.validateIdempotencyOptions(idempotencyOptions);\n    this.validatePagesOptions(pages);\n    this.validateSecurityOptions(security);\n    this.validateSchemaOptions(schema);\n    this.validateEnforcePrivateUsers(enforcePrivateUsers);\n    this.validateAllowExpiredAuthDataToken(allowExpiredAuthDataToken);\n    this.validateRequestKeywordDenylist(requestKeywordDenylist);\n    this.validateRateLimit(rateLimit);\n    this.validateLogLevels(logLevels);\n  }\n\n  static validateRequestKeywordDenylist(requestKeywordDenylist) {\n    if (requestKeywordDenylist === undefined) {\n      requestKeywordDenylist = requestKeywordDenylist.default;\n    } else if (!Array.isArray(requestKeywordDenylist)) {\n      throw 'Parse Server option requestKeywordDenylist must be an array.';\n    }\n  }\n\n  static validateEnforcePrivateUsers(enforcePrivateUsers) {\n    if (typeof enforcePrivateUsers !== 'boolean') {\n      throw 'Parse Server option enforcePrivateUsers must be a boolean.';\n    }\n  }\n\n  static validateAllowExpiredAuthDataToken(allowExpiredAuthDataToken) {\n    if (typeof allowExpiredAuthDataToken !== 'boolean') {\n      throw 'Parse Server option allowExpiredAuthDataToken must be a boolean.';\n    }\n  }\n\n  static validateSecurityOptions(security) {\n    if (Object.prototype.toString.call(security) !== '[object Object]') {\n      throw 'Parse Server option security must be an object.';\n    }\n    if (security.enableCheck === undefined) {\n      security.enableCheck = SecurityOptions.enableCheck.default;\n    } else if (!isBoolean(security.enableCheck)) {\n      throw 'Parse Server option security.enableCheck must be a boolean.';\n    }\n    if (security.enableCheckLog === undefined) {\n      security.enableCheckLog = SecurityOptions.enableCheckLog.default;\n    } else if (!isBoolean(security.enableCheckLog)) {\n      throw 'Parse Server option security.enableCheckLog must be a boolean.';\n    }\n  }\n\n  static validateSchemaOptions(schema: SchemaOptions) {\n    if (!schema) return;\n    if (Object.prototype.toString.call(schema) !== '[object Object]') {\n      throw 'Parse Server option schema must be an object.';\n    }\n    if (schema.definitions === undefined) {\n      schema.definitions = SchemaOptions.definitions.default;\n    } else if (!Array.isArray(schema.definitions)) {\n      throw 'Parse Server option schema.definitions must be an array.';\n    }\n    if (schema.strict === undefined) {\n      schema.strict = SchemaOptions.strict.default;\n    } else if (!isBoolean(schema.strict)) {\n      throw 'Parse Server option schema.strict must be a boolean.';\n    }\n    if (schema.deleteExtraFields === undefined) {\n      schema.deleteExtraFields = SchemaOptions.deleteExtraFields.default;\n    } else if (!isBoolean(schema.deleteExtraFields)) {\n      throw 'Parse Server option schema.deleteExtraFields must be a boolean.';\n    }\n    if (schema.recreateModifiedFields === undefined) {\n      schema.recreateModifiedFields = SchemaOptions.recreateModifiedFields.default;\n    } else if (!isBoolean(schema.recreateModifiedFields)) {\n      throw 'Parse Server option schema.recreateModifiedFields must be a boolean.';\n    }\n    if (schema.lockSchemas === undefined) {\n      schema.lockSchemas = SchemaOptions.lockSchemas.default;\n    } else if (!isBoolean(schema.lockSchemas)) {\n      throw 'Parse Server option schema.lockSchemas must be a boolean.';\n    }\n    if (schema.beforeMigration === undefined) {\n      schema.beforeMigration = null;\n    } else if (schema.beforeMigration !== null && typeof schema.beforeMigration !== 'function') {\n      throw 'Parse Server option schema.beforeMigration must be a function.';\n    }\n    if (schema.afterMigration === undefined) {\n      schema.afterMigration = null;\n    } else if (schema.afterMigration !== null && typeof schema.afterMigration !== 'function') {\n      throw 'Parse Server option schema.afterMigration must be a function.';\n    }\n  }\n\n  static validatePagesOptions(pages) {\n    if (Object.prototype.toString.call(pages) !== '[object Object]') {\n      throw 'Parse Server option pages must be an object.';\n    }\n    if (pages.enableRouter === undefined) {\n      pages.enableRouter = PagesOptions.enableRouter.default;\n    } else if (!isBoolean(pages.enableRouter)) {\n      throw 'Parse Server option pages.enableRouter must be a boolean.';\n    }\n    if (pages.enableLocalization === undefined) {\n      pages.enableLocalization = PagesOptions.enableLocalization.default;\n    } else if (!isBoolean(pages.enableLocalization)) {\n      throw 'Parse Server option pages.enableLocalization must be a boolean.';\n    }\n    if (pages.localizationJsonPath === undefined) {\n      pages.localizationJsonPath = PagesOptions.localizationJsonPath.default;\n    } else if (!isString(pages.localizationJsonPath)) {\n      throw 'Parse Server option pages.localizationJsonPath must be a string.';\n    }\n    if (pages.localizationFallbackLocale === undefined) {\n      pages.localizationFallbackLocale = PagesOptions.localizationFallbackLocale.default;\n    } else if (!isString(pages.localizationFallbackLocale)) {\n      throw 'Parse Server option pages.localizationFallbackLocale must be a string.';\n    }\n    if (pages.placeholders === undefined) {\n      pages.placeholders = PagesOptions.placeholders.default;\n    } else if (\n      Object.prototype.toString.call(pages.placeholders) !== '[object Object]' &&\n      typeof pages.placeholders !== 'function'\n    ) {\n      throw 'Parse Server option pages.placeholders must be an object or a function.';\n    }\n    if (pages.forceRedirect === undefined) {\n      pages.forceRedirect = PagesOptions.forceRedirect.default;\n    } else if (!isBoolean(pages.forceRedirect)) {\n      throw 'Parse Server option pages.forceRedirect must be a boolean.';\n    }\n    if (pages.pagesPath === undefined) {\n      pages.pagesPath = PagesOptions.pagesPath.default;\n    } else if (!isString(pages.pagesPath)) {\n      throw 'Parse Server option pages.pagesPath must be a string.';\n    }\n    if (pages.pagesEndpoint === undefined) {\n      pages.pagesEndpoint = PagesOptions.pagesEndpoint.default;\n    } else if (!isString(pages.pagesEndpoint)) {\n      throw 'Parse Server option pages.pagesEndpoint must be a string.';\n    }\n    if (pages.customUrls === undefined) {\n      pages.customUrls = PagesOptions.customUrls.default;\n    } else if (Object.prototype.toString.call(pages.customUrls) !== '[object Object]') {\n      throw 'Parse Server option pages.customUrls must be an object.';\n    }\n    if (pages.customRoutes === undefined) {\n      pages.customRoutes = PagesOptions.customRoutes.default;\n    } else if (!(pages.customRoutes instanceof Array)) {\n      throw 'Parse Server option pages.customRoutes must be an array.';\n    }\n  }\n\n  static validateIdempotencyOptions(idempotencyOptions) {\n    if (!idempotencyOptions) {\n      return;\n    }\n    if (idempotencyOptions.ttl === undefined) {\n      idempotencyOptions.ttl = IdempotencyOptions.ttl.default;\n    } else if (!isNaN(idempotencyOptions.ttl) && idempotencyOptions.ttl <= 0) {\n      throw 'idempotency TTL value must be greater than 0 seconds';\n    } else if (isNaN(idempotencyOptions.ttl)) {\n      throw 'idempotency TTL value must be a number';\n    }\n    if (!idempotencyOptions.paths) {\n      idempotencyOptions.paths = IdempotencyOptions.paths.default;\n    } else if (!(idempotencyOptions.paths instanceof Array)) {\n      throw 'idempotency paths must be of an array of strings';\n    }\n  }\n\n  static validateAccountLockoutPolicy(accountLockout) {\n    if (accountLockout) {\n      if (\n        typeof accountLockout.duration !== 'number' ||\n        accountLockout.duration <= 0 ||\n        accountLockout.duration > 99999\n      ) {\n        throw 'Account lockout duration should be greater than 0 and less than 100000';\n      }\n\n      if (\n        !Number.isInteger(accountLockout.threshold) ||\n        accountLockout.threshold < 1 ||\n        accountLockout.threshold > 999\n      ) {\n        throw 'Account lockout threshold should be an integer greater than 0 and less than 1000';\n      }\n\n      if (accountLockout.unlockOnPasswordReset === undefined) {\n        accountLockout.unlockOnPasswordReset = AccountLockoutOptions.unlockOnPasswordReset.default;\n      } else if (!isBoolean(accountLockout.unlockOnPasswordReset)) {\n        throw 'Parse Server option accountLockout.unlockOnPasswordReset must be a boolean.';\n      }\n    }\n  }\n\n  static validatePasswordPolicy(passwordPolicy) {\n    if (passwordPolicy) {\n      if (\n        passwordPolicy.maxPasswordAge !== undefined &&\n        (typeof passwordPolicy.maxPasswordAge !== 'number' || passwordPolicy.maxPasswordAge < 0)\n      ) {\n        throw 'passwordPolicy.maxPasswordAge must be a positive number';\n      }\n\n      if (\n        passwordPolicy.resetTokenValidityDuration !== undefined &&\n        (typeof passwordPolicy.resetTokenValidityDuration !== 'number' ||\n          passwordPolicy.resetTokenValidityDuration <= 0)\n      ) {\n        throw 'passwordPolicy.resetTokenValidityDuration must be a positive number';\n      }\n\n      if (passwordPolicy.validatorPattern) {\n        if (typeof passwordPolicy.validatorPattern === 'string') {\n          passwordPolicy.validatorPattern = new RegExp(passwordPolicy.validatorPattern);\n        } else if (!(passwordPolicy.validatorPattern instanceof RegExp)) {\n          throw 'passwordPolicy.validatorPattern must be a regex string or RegExp object.';\n        }\n      }\n\n      if (\n        passwordPolicy.validatorCallback &&\n        typeof passwordPolicy.validatorCallback !== 'function'\n      ) {\n        throw 'passwordPolicy.validatorCallback must be a function.';\n      }\n\n      if (\n        passwordPolicy.doNotAllowUsername &&\n        typeof passwordPolicy.doNotAllowUsername !== 'boolean'\n      ) {\n        throw 'passwordPolicy.doNotAllowUsername must be a boolean value.';\n      }\n\n      if (\n        passwordPolicy.maxPasswordHistory &&\n        (!Number.isInteger(passwordPolicy.maxPasswordHistory) ||\n          passwordPolicy.maxPasswordHistory <= 0 ||\n          passwordPolicy.maxPasswordHistory > 20)\n      ) {\n        throw 'passwordPolicy.maxPasswordHistory must be an integer ranging 0 - 20';\n      }\n\n      if (\n        passwordPolicy.resetTokenReuseIfValid &&\n        typeof passwordPolicy.resetTokenReuseIfValid !== 'boolean'\n      ) {\n        throw 'resetTokenReuseIfValid must be a boolean value';\n      }\n      if (passwordPolicy.resetTokenReuseIfValid && !passwordPolicy.resetTokenValidityDuration) {\n        throw 'You cannot use resetTokenReuseIfValid without resetTokenValidityDuration';\n      }\n    }\n  }\n\n  // if the passwordPolicy.validatorPattern is configured then setup a callback to process the pattern\n  static setupPasswordValidator(passwordPolicy) {\n    if (passwordPolicy && passwordPolicy.validatorPattern) {\n      passwordPolicy.patternValidator = value => {\n        return passwordPolicy.validatorPattern.test(value);\n      };\n    }\n  }\n\n  static validateEmailConfiguration({\n    emailAdapter,\n    appName,\n    publicServerURL,\n    emailVerifyTokenValidityDuration,\n    emailVerifyTokenReuseIfValid,\n  }) {\n    if (!emailAdapter) {\n      throw 'An emailAdapter is required for e-mail verification and password resets.';\n    }\n    if (typeof appName !== 'string') {\n      throw 'An app name is required for e-mail verification and password resets.';\n    }\n    if (typeof publicServerURL !== 'string') {\n      throw 'A public server url is required for e-mail verification and password resets.';\n    }\n    if (emailVerifyTokenValidityDuration) {\n      if (isNaN(emailVerifyTokenValidityDuration)) {\n        throw 'Email verify token validity duration must be a valid number.';\n      } else if (emailVerifyTokenValidityDuration <= 0) {\n        throw 'Email verify token validity duration must be a value greater than 0.';\n      }\n    }\n    if (emailVerifyTokenReuseIfValid && typeof emailVerifyTokenReuseIfValid !== 'boolean') {\n      throw 'emailVerifyTokenReuseIfValid must be a boolean value';\n    }\n    if (emailVerifyTokenReuseIfValid && !emailVerifyTokenValidityDuration) {\n      throw 'You cannot use emailVerifyTokenReuseIfValid without emailVerifyTokenValidityDuration';\n    }\n  }\n\n  static validateFileUploadOptions(fileUpload) {\n    try {\n      if (fileUpload == null || typeof fileUpload !== 'object' || fileUpload instanceof Array) {\n        throw 'fileUpload must be an object value.';\n      }\n    } catch (e) {\n      if (e instanceof ReferenceError) {\n        return;\n      }\n      throw e;\n    }\n    if (fileUpload.enableForAnonymousUser === undefined) {\n      fileUpload.enableForAnonymousUser = FileUploadOptions.enableForAnonymousUser.default;\n    } else if (typeof fileUpload.enableForAnonymousUser !== 'boolean') {\n      throw 'fileUpload.enableForAnonymousUser must be a boolean value.';\n    }\n    if (fileUpload.enableForPublic === undefined) {\n      fileUpload.enableForPublic = FileUploadOptions.enableForPublic.default;\n    } else if (typeof fileUpload.enableForPublic !== 'boolean') {\n      throw 'fileUpload.enableForPublic must be a boolean value.';\n    }\n    if (fileUpload.enableForAuthenticatedUser === undefined) {\n      fileUpload.enableForAuthenticatedUser = FileUploadOptions.enableForAuthenticatedUser.default;\n    } else if (typeof fileUpload.enableForAuthenticatedUser !== 'boolean') {\n      throw 'fileUpload.enableForAuthenticatedUser must be a boolean value.';\n    }\n  }\n\n  static validateMasterKeyIps(masterKeyIps) {\n    for (let ip of masterKeyIps) {\n      if (ip.includes('/')) {\n        ip = ip.split('/')[0];\n      }\n      if (!net.isIP(ip)) {\n        throw `The Parse Server option \"masterKeyIps\" contains an invalid IP address \"${ip}\".`;\n      }\n    }\n  }\n\n  get mount() {\n    var mount = this._mount;\n    if (this.publicServerURL) {\n      mount = this.publicServerURL;\n    }\n    return mount;\n  }\n\n  set mount(newValue) {\n    this._mount = newValue;\n  }\n\n  static validateSessionConfiguration(sessionLength, expireInactiveSessions) {\n    if (expireInactiveSessions) {\n      if (isNaN(sessionLength)) {\n        throw 'Session length must be a valid number.';\n      } else if (sessionLength <= 0) {\n        throw 'Session length must be a value greater than 0.';\n      }\n    }\n  }\n\n  static validateDefaultLimit(defaultLimit) {\n    if (defaultLimit == null) {\n      defaultLimit = ParseServerOptions.defaultLimit.default;\n    }\n    if (typeof defaultLimit !== 'number') {\n      throw 'Default limit must be a number.';\n    }\n    if (defaultLimit <= 0) {\n      throw 'Default limit must be a value greater than 0.';\n    }\n  }\n\n  static validateMaxLimit(maxLimit) {\n    if (maxLimit <= 0) {\n      throw 'Max limit must be a value greater than 0.';\n    }\n  }\n\n  static validateAllowHeaders(allowHeaders) {\n    if (![null, undefined].includes(allowHeaders)) {\n      if (Array.isArray(allowHeaders)) {\n        allowHeaders.forEach(header => {\n          if (typeof header !== 'string') {\n            throw 'Allow headers must only contain strings';\n          } else if (!header.trim().length) {\n            throw 'Allow headers must not contain empty strings';\n          }\n        });\n      } else {\n        throw 'Allow headers must be an array';\n      }\n    }\n  }\n\n  static validateLogLevels(logLevels) {\n    for (const key of Object.keys(LogLevels)) {\n      if (logLevels[key]) {\n        if (validLogLevels.indexOf(logLevels[key]) === -1) {\n          throw `'${key}' must be one of ${JSON.stringify(validLogLevels)}`;\n        }\n      } else {\n        logLevels[key] = LogLevels[key].default;\n      }\n    }\n  }\n\n  static validateRateLimit(rateLimit) {\n    if (!rateLimit) {\n      return;\n    }\n    if (\n      Object.prototype.toString.call(rateLimit) !== '[object Object]' &&\n      !Array.isArray(rateLimit)\n    ) {\n      throw `rateLimit must be an array or object`;\n    }\n    const options = Array.isArray(rateLimit) ? rateLimit : [rateLimit];\n    for (const option of options) {\n      if (Object.prototype.toString.call(option) !== '[object Object]') {\n        throw `rateLimit must be an array of objects`;\n      }\n      if (option.requestPath == null) {\n        throw `rateLimit.requestPath must be defined`;\n      }\n      if (typeof option.requestPath !== 'string') {\n        throw `rateLimit.requestPath must be a string`;\n      }\n      if (option.requestTimeWindow == null) {\n        throw `rateLimit.requestTimeWindow must be defined`;\n      }\n      if (typeof option.requestTimeWindow !== 'number') {\n        throw `rateLimit.requestTimeWindow must be a number`;\n      }\n      if (option.includeInternalRequests && typeof option.includeInternalRequests !== 'boolean') {\n        throw `rateLimit.includeInternalRequests must be a boolean`;\n      }\n      if (option.requestCount == null) {\n        throw `rateLimit.requestCount must be defined`;\n      }\n      if (typeof option.requestCount !== 'number') {\n        throw `rateLimit.requestCount must be a number`;\n      }\n      if (option.errorResponseMessage && typeof option.errorResponseMessage !== 'string') {\n        throw `rateLimit.errorResponseMessage must be a string`;\n      }\n    }\n  }\n\n  generateEmailVerifyTokenExpiresAt() {\n    if (!this.verifyUserEmails || !this.emailVerifyTokenValidityDuration) {\n      return undefined;\n    }\n    var now = new Date();\n    return new Date(now.getTime() + this.emailVerifyTokenValidityDuration * 1000);\n  }\n\n  generatePasswordResetTokenExpiresAt() {\n    if (!this.passwordPolicy || !this.passwordPolicy.resetTokenValidityDuration) {\n      return undefined;\n    }\n    const now = new Date();\n    return new Date(now.getTime() + this.passwordPolicy.resetTokenValidityDuration * 1000);\n  }\n\n  generateSessionExpiresAt() {\n    if (!this.expireInactiveSessions) {\n      return undefined;\n    }\n    var now = new Date();\n    return new Date(now.getTime() + this.sessionLength * 1000);\n  }\n\n  get invalidLinkURL() {\n    return this.customPages.invalidLink || `${this.publicServerURL}/apps/invalid_link.html`;\n  }\n\n  get invalidVerificationLinkURL() {\n    return (\n      this.customPages.invalidVerificationLink ||\n      `${this.publicServerURL}/apps/invalid_verification_link.html`\n    );\n  }\n\n  get linkSendSuccessURL() {\n    return (\n      this.customPages.linkSendSuccess || `${this.publicServerURL}/apps/link_send_success.html`\n    );\n  }\n\n  get linkSendFailURL() {\n    return this.customPages.linkSendFail || `${this.publicServerURL}/apps/link_send_fail.html`;\n  }\n\n  get verifyEmailSuccessURL() {\n    return (\n      this.customPages.verifyEmailSuccess ||\n      `${this.publicServerURL}/apps/verify_email_success.html`\n    );\n  }\n\n  get choosePasswordURL() {\n    return this.customPages.choosePassword || `${this.publicServerURL}/apps/choose_password`;\n  }\n\n  get requestResetPasswordURL() {\n    return `${this.publicServerURL}/${this.pagesEndpoint}/${this.applicationId}/request_password_reset`;\n  }\n\n  get passwordResetSuccessURL() {\n    return (\n      this.customPages.passwordResetSuccess ||\n      `${this.publicServerURL}/apps/password_reset_success.html`\n    );\n  }\n\n  get parseFrameURL() {\n    return this.customPages.parseFrameURL;\n  }\n\n  get verifyEmailURL() {\n    return `${this.publicServerURL}/${this.pagesEndpoint}/${this.applicationId}/verify_email`;\n  }\n\n  // TODO: Remove this function once PagesRouter replaces the PublicAPIRouter;\n  // the (default) endpoint has to be defined in PagesRouter only.\n  get pagesEndpoint() {\n    return this.pages && this.pages.enableRouter && this.pages.pagesEndpoint\n      ? this.pages.pagesEndpoint\n      : 'apps';\n  }\n}\n\nexport default Config;\nmodule.exports = Config;\n"],"mappings":"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"}