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/Auth.js CHANGED
@@ -1,23 +1,16 @@
1
1
  "use strict";
2
2
 
3
3
  var _util = require("util");
4
-
5
4
  var _triggers = require("./triggers");
6
-
7
5
  var _Deprecator = _interopRequireDefault(require("./Deprecator/Deprecator"));
8
-
9
6
  var _logger = require("./logger");
10
-
11
7
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
-
13
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
14
-
15
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
16
-
17
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
18
-
8
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
9
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
10
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
11
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
12
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
19
13
  const Parse = require('parse/node');
20
-
21
14
  // An Auth object tells you who is requesting something and whether
22
15
  // the master key was used.
23
16
  // userObject is a Parse.User and can be null if there's no user.
@@ -34,54 +27,53 @@ function Auth({
34
27
  this.installationId = installationId;
35
28
  this.isMaster = isMaster;
36
29
  this.user = user;
37
- this.isReadOnly = isReadOnly; // Assuming a users roles won't change during a single request, we'll
38
- // only load them once.
30
+ this.isReadOnly = isReadOnly;
39
31
 
32
+ // Assuming a users roles won't change during a single request, we'll
33
+ // only load them once.
40
34
  this.userRoles = [];
41
35
  this.fetchedRoles = false;
42
36
  this.rolePromise = null;
43
- } // Whether this auth could possibly modify the given user id.
44
- // It still could be forbidden via ACLs even if this returns true.
45
-
37
+ }
46
38
 
39
+ // Whether this auth could possibly modify the given user id.
40
+ // It still could be forbidden via ACLs even if this returns true.
47
41
  Auth.prototype.isUnauthenticated = function () {
48
42
  if (this.isMaster) {
49
43
  return false;
50
44
  }
51
-
52
45
  if (this.user) {
53
46
  return false;
54
47
  }
55
-
56
48
  return true;
57
- }; // A helper to get a master-level Auth object
58
-
49
+ };
59
50
 
51
+ // A helper to get a master-level Auth object
60
52
  function master(config) {
61
53
  return new Auth({
62
54
  config,
63
55
  isMaster: true
64
56
  });
65
- } // A helper to get a master-level Auth object
66
-
57
+ }
67
58
 
59
+ // A helper to get a master-level Auth object
68
60
  function readOnly(config) {
69
61
  return new Auth({
70
62
  config,
71
63
  isMaster: true,
72
64
  isReadOnly: true
73
65
  });
74
- } // A helper to get a nobody-level Auth object
75
-
66
+ }
76
67
 
68
+ // A helper to get a nobody-level Auth object
77
69
  function nobody(config) {
78
70
  return new Auth({
79
71
  config,
80
72
  isMaster: false
81
73
  });
82
- } // Returns a promise that resolves to an Auth object
83
-
74
+ }
84
75
 
76
+ // Returns a promise that resolves to an Auth object
85
77
  const getAuthForSessionToken = async function ({
86
78
  config,
87
79
  cacheController,
@@ -89,10 +81,8 @@ const getAuthForSessionToken = async function ({
89
81
  installationId
90
82
  }) {
91
83
  cacheController = cacheController || config && config.cacheController;
92
-
93
84
  if (cacheController) {
94
85
  const userJSON = await cacheController.user.get(sessionToken);
95
-
96
86
  if (userJSON) {
97
87
  const cachedUser = Parse.Object.fromJSON(userJSON);
98
88
  return Promise.resolve(new Auth({
@@ -104,17 +94,13 @@ const getAuthForSessionToken = async function ({
104
94
  }));
105
95
  }
106
96
  }
107
-
108
97
  let results;
109
-
110
98
  if (config) {
111
99
  const restOptions = {
112
100
  limit: 1,
113
101
  include: 'user'
114
102
  };
115
-
116
103
  const RestQuery = require('./RestQuery');
117
-
118
104
  const query = new RestQuery(config, master(config), '_Session', {
119
105
  sessionToken
120
106
  }, restOptions);
@@ -124,27 +110,21 @@ const getAuthForSessionToken = async function ({
124
110
  useMasterKey: true
125
111
  })).map(obj => obj.toJSON());
126
112
  }
127
-
128
113
  if (results.length !== 1 || !results[0]['user']) {
129
114
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
130
115
  }
131
-
132
116
  const now = new Date(),
133
- expiresAt = results[0].expiresAt ? new Date(results[0].expiresAt.iso) : undefined;
134
-
117
+ expiresAt = results[0].expiresAt ? new Date(results[0].expiresAt.iso) : undefined;
135
118
  if (expiresAt < now) {
136
119
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');
137
120
  }
138
-
139
121
  const obj = results[0]['user'];
140
122
  delete obj.password;
141
123
  obj['className'] = '_User';
142
124
  obj['sessionToken'] = sessionToken;
143
-
144
125
  if (cacheController) {
145
126
  cacheController.user.put(sessionToken, obj);
146
127
  }
147
-
148
128
  const userObject = Parse.Object.fromJSON(obj);
149
129
  return new Auth({
150
130
  config,
@@ -154,7 +134,6 @@ const getAuthForSessionToken = async function ({
154
134
  user: userObject
155
135
  });
156
136
  };
157
-
158
137
  var getAuthForLegacySessionToken = function ({
159
138
  config,
160
139
  sessionToken,
@@ -163,19 +142,15 @@ var getAuthForLegacySessionToken = function ({
163
142
  var restOptions = {
164
143
  limit: 1
165
144
  };
166
-
167
145
  const RestQuery = require('./RestQuery');
168
-
169
146
  var query = new RestQuery(config, master(config), '_User', {
170
147
  sessionToken
171
148
  }, restOptions);
172
149
  return query.execute().then(response => {
173
150
  var results = response.results;
174
-
175
151
  if (results.length !== 1) {
176
152
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');
177
153
  }
178
-
179
154
  const obj = results[0];
180
155
  obj.className = '_User';
181
156
  const userObject = Parse.Object.fromJSON(obj);
@@ -186,30 +161,25 @@ var getAuthForLegacySessionToken = function ({
186
161
  user: userObject
187
162
  });
188
163
  });
189
- }; // Returns a promise that resolves to an array of role names
190
-
164
+ };
191
165
 
166
+ // Returns a promise that resolves to an array of role names
192
167
  Auth.prototype.getUserRoles = function () {
193
168
  if (this.isMaster || !this.user) {
194
169
  return Promise.resolve([]);
195
170
  }
196
-
197
171
  if (this.fetchedRoles) {
198
172
  return Promise.resolve(this.userRoles);
199
173
  }
200
-
201
174
  if (this.rolePromise) {
202
175
  return this.rolePromise;
203
176
  }
204
-
205
177
  this.rolePromise = this._loadRoles();
206
178
  return this.rolePromise;
207
179
  };
208
-
209
180
  Auth.prototype.getRolesForUser = async function () {
210
181
  //Stack all Parse.Role
211
182
  const results = [];
212
-
213
183
  if (this.config) {
214
184
  const restWhere = {
215
185
  users: {
@@ -218,34 +188,29 @@ Auth.prototype.getRolesForUser = async function () {
218
188
  objectId: this.user.id
219
189
  }
220
190
  };
221
-
222
191
  const RestQuery = require('./RestQuery');
223
-
224
192
  await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result => results.push(result));
225
193
  } else {
226
194
  await new Parse.Query(Parse.Role).equalTo('users', this.user).each(result => results.push(result.toJSON()), {
227
195
  useMasterKey: true
228
196
  });
229
197
  }
230
-
231
198
  return results;
232
- }; // Iterates through the role tree and compiles a user's roles
233
-
199
+ };
234
200
 
201
+ // Iterates through the role tree and compiles a user's roles
235
202
  Auth.prototype._loadRoles = async function () {
236
203
  if (this.cacheController) {
237
204
  const cachedRoles = await this.cacheController.role.get(this.user.id);
238
-
239
205
  if (cachedRoles != null) {
240
206
  this.fetchedRoles = true;
241
207
  this.userRoles = cachedRoles;
242
208
  return cachedRoles;
243
209
  }
244
- } // First get the role ids this user is directly a member of
245
-
210
+ }
246
211
 
212
+ // First get the role ids this user is directly a member of
247
213
  const results = await this.getRolesForUser();
248
-
249
214
  if (!results.length) {
250
215
  this.userRoles = [];
251
216
  this.fetchedRoles = true;
@@ -253,7 +218,6 @@ Auth.prototype._loadRoles = async function () {
253
218
  this.cacheRoles();
254
219
  return this.userRoles;
255
220
  }
256
-
257
221
  const rolesMap = results.reduce((m, r) => {
258
222
  m.names.push(r.name);
259
223
  m.ids.push(r.objectId);
@@ -261,8 +225,9 @@ Auth.prototype._loadRoles = async function () {
261
225
  }, {
262
226
  ids: [],
263
227
  names: []
264
- }); // run the recursive finding
228
+ });
265
229
 
230
+ // run the recursive finding
266
231
  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);
267
232
  this.userRoles = roleNames.map(r => {
268
233
  return 'role:' + r;
@@ -272,29 +237,24 @@ Auth.prototype._loadRoles = async function () {
272
237
  this.cacheRoles();
273
238
  return this.userRoles;
274
239
  };
275
-
276
240
  Auth.prototype.cacheRoles = function () {
277
241
  if (!this.cacheController) {
278
242
  return false;
279
243
  }
280
-
281
244
  this.cacheController.role.put(this.user.id, Array(...this.userRoles));
282
245
  return true;
283
246
  };
284
-
285
247
  Auth.prototype.clearRoleCache = function (sessionToken) {
286
248
  if (!this.cacheController) {
287
249
  return false;
288
250
  }
289
-
290
251
  this.cacheController.role.del(this.user.id);
291
252
  this.cacheController.user.del(sessionToken);
292
253
  return true;
293
254
  };
294
-
295
255
  Auth.prototype.getRolesByIds = async function (ins) {
296
- const results = []; // Build an OR query across all parentRoles
297
-
256
+ const results = [];
257
+ // Build an OR query across all parentRoles
298
258
  if (!this.config) {
299
259
  await new Parse.Query(Parse.Role).containedIn('roles', ins.map(id => {
300
260
  const role = new Parse.Object(Parse.Role);
@@ -316,34 +276,30 @@ Auth.prototype.getRolesByIds = async function (ins) {
316
276
  $in: roles
317
277
  }
318
278
  };
319
-
320
279
  const RestQuery = require('./RestQuery');
321
-
322
280
  await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result => results.push(result));
323
281
  }
324
-
325
282
  return results;
326
- }; // Given a list of roleIds, find all the parent roles, returns a promise with all names
327
-
283
+ };
328
284
 
285
+ // Given a list of roleIds, find all the parent roles, returns a promise with all names
329
286
  Auth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {
330
287
  const ins = roleIDs.filter(roleID => {
331
288
  const wasQueried = queriedRoles[roleID] !== true;
332
289
  queriedRoles[roleID] = true;
333
290
  return wasQueried;
334
- }); // all roles are accounted for, return the names
291
+ });
335
292
 
293
+ // all roles are accounted for, return the names
336
294
  if (ins.length == 0) {
337
295
  return Promise.resolve([...new Set(names)]);
338
296
  }
339
-
340
297
  return this.getRolesByIds(ins).then(results => {
341
298
  // Nothing found
342
299
  if (!results.length) {
343
300
  return Promise.resolve(names);
344
- } // Map the results with all Ids and names
345
-
346
-
301
+ }
302
+ // Map the results with all Ids and names
347
303
  const resultMap = results.reduce((memo, role) => {
348
304
  memo.names.push(role.name);
349
305
  memo.ids.push(role.objectId);
@@ -351,23 +307,21 @@ Auth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], quer
351
307
  }, {
352
308
  ids: [],
353
309
  names: []
354
- }); // store the new found names
355
-
356
- names = names.concat(resultMap.names); // find the next ones, circular roles will be cut
357
-
310
+ });
311
+ // store the new found names
312
+ names = names.concat(resultMap.names);
313
+ // find the next ones, circular roles will be cut
358
314
  return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);
359
315
  }).then(names => {
360
316
  return Promise.resolve([...new Set(names)]);
361
317
  });
362
318
  };
363
-
364
319
  const findUsersWithAuthData = (config, authData) => {
365
320
  const providers = Object.keys(authData);
366
321
  const query = providers.reduce((memo, provider) => {
367
322
  if (!authData[provider] || authData && !authData[provider].id) {
368
323
  return memo;
369
324
  }
370
-
371
325
  const queryKey = `authData.${provider}.id`;
372
326
  const query = {};
373
327
  query[queryKey] = authData[provider].id;
@@ -382,7 +336,6 @@ const findUsersWithAuthData = (config, authData) => {
382
336
  limit: 2
383
337
  }) : Promise.resolve([]);
384
338
  };
385
-
386
339
  const hasMutatedAuthData = (authData, userAuthData) => {
387
340
  if (!userAuthData) return {
388
341
  hasMutatedAuthData: true,
@@ -394,7 +347,6 @@ const hasMutatedAuthData = (authData, userAuthData) => {
394
347
  if (provider === 'anonymous') return;
395
348
  const providerData = authData[provider];
396
349
  const userProviderAuthData = userAuthData[provider];
397
-
398
350
  if (!(0, _util.isDeepStrictEqual)(providerData, userProviderAuthData)) {
399
351
  mutatedAuthData[provider] = providerData;
400
352
  }
@@ -405,20 +357,19 @@ const hasMutatedAuthData = (authData, userAuthData) => {
405
357
  mutatedAuthData
406
358
  };
407
359
  };
408
-
409
360
  const checkIfUserHasProvidedConfiguredProvidersForLogin = (authData = {}, userAuthData = {}, config) => {
410
361
  const savedUserProviders = Object.keys(userAuthData).map(provider => ({
411
362
  name: provider,
412
363
  adapter: config.authDataManager.getValidatorForProvider(provider).adapter
413
364
  }));
414
- const hasProvidedASoloProvider = savedUserProviders.some(provider => provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]); // Solo providers can be considered as safe, so we do not have to check if the user needs
365
+ const hasProvidedASoloProvider = savedUserProviders.some(provider => provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]);
366
+
367
+ // Solo providers can be considered as safe, so we do not have to check if the user needs
415
368
  // to provide an additional provider to login. An auth adapter with "solo" (like webauthn) means
416
369
  // no "additional" auth needs to be provided to login (like OTP, MFA)
417
-
418
370
  if (hasProvidedASoloProvider) {
419
371
  return;
420
372
  }
421
-
422
373
  const additionProvidersNotFound = [];
423
374
  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {
424
375
  if (provider && provider.adapter && provider.adapter.policy === 'additional') {
@@ -430,22 +381,20 @@ const checkIfUserHasProvidedConfiguredProvidersForLogin = (authData = {}, userAu
430
381
  }
431
382
  }
432
383
  });
433
-
434
384
  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {
435
385
  return;
436
386
  }
437
-
438
387
  throw new Parse.Error(Parse.Error.OTHER_CAUSE, `Missing additional authData ${additionProvidersNotFound.join(',')}`);
439
- }; // Validate each authData step-by-step and return the provider responses
440
-
388
+ };
441
389
 
390
+ // Validate each authData step-by-step and return the provider responses
442
391
  const handleAuthDataValidation = async (authData, req, foundUser) => {
443
392
  let user;
444
-
445
393
  if (foundUser) {
446
394
  user = Parse.User.fromJSON(_objectSpread({
447
395
  className: '_User'
448
- }, foundUser)); // Find user by session and current objectId; only pass user if it's the current user or master key is provided
396
+ }, foundUser));
397
+ // Find user by session and current objectId; only pass user if it's the current user or master key is provided
449
398
  } else if (req.auth && req.auth.user && typeof req.getUserId === 'function' && req.getUserId() === req.auth.user.id || req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId()) {
450
399
  user = new Parse.User();
451
400
  user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;
@@ -453,68 +402,56 @@ const handleAuthDataValidation = async (authData, req, foundUser) => {
453
402
  useMasterKey: true
454
403
  });
455
404
  }
456
-
457
405
  const {
458
406
  originalObject,
459
407
  updatedObject
460
408
  } = req.buildParseObjects();
461
- const requestObject = (0, _triggers.getRequestObject)(undefined, req.auth, updatedObject, originalObject || user, req.config); // Perform validation as step-by-step pipeline for better error consistency
409
+ const requestObject = (0, _triggers.getRequestObject)(undefined, req.auth, updatedObject, originalObject || user, req.config);
410
+ // Perform validation as step-by-step pipeline for better error consistency
462
411
  // and also to avoid to trigger a provider (like OTP SMS) if another one fails
463
-
464
412
  const acc = {
465
413
  authData: {},
466
414
  authDataResponse: {}
467
415
  };
468
416
  const authKeys = Object.keys(authData).sort();
469
-
470
417
  for (const provider of authKeys) {
471
418
  let method = '';
472
-
473
419
  try {
474
420
  if (authData[provider] === null) {
475
421
  acc.authData[provider] = null;
476
422
  continue;
477
423
  }
478
-
479
424
  const {
480
425
  validator
481
426
  } = req.config.authDataManager.getValidatorForProvider(provider);
482
427
  const authProvider = (req.config.auth || {})[provider] || {};
483
-
484
428
  if (authProvider.enabled == null) {
485
429
  _Deprecator.default.logRuntimeDeprecation({
486
- usage: `auth.${provider}`,
487
- solution: `auth.${provider}.enabled: true`
430
+ usage: `Using the authentication adapter "${provider}" without explicitly enabling it`,
431
+ solution: `Enable the authentication adapter by setting the Parse Server option "auth.${provider}.enabled: true".`
488
432
  });
489
433
  }
490
-
491
434
  if (!validator || authProvider.enabled === false) {
492
435
  throw new Parse.Error(Parse.Error.UNSUPPORTED_SERVICE, 'This authentication method is unsupported.');
493
436
  }
494
-
495
437
  let validationResult = await validator(authData[provider], req, user, requestObject);
496
438
  method = validationResult && validationResult.method;
497
439
  requestObject.triggerName = method;
498
-
499
440
  if (validationResult && validationResult.validator) {
500
441
  validationResult = await validationResult.validator();
501
442
  }
502
-
503
443
  if (!validationResult) {
504
444
  acc.authData[provider] = authData[provider];
505
445
  continue;
506
446
  }
507
-
508
447
  if (!Object.keys(validationResult).length) {
509
448
  acc.authData[provider] = authData[provider];
510
449
  continue;
511
450
  }
512
-
513
451
  if (validationResult.response) {
514
452
  acc.authDataResponse[provider] = validationResult.response;
515
- } // Some auth providers after initialization will avoid to replace authData already stored
516
-
517
-
453
+ }
454
+ // Some auth providers after initialization will avoid to replace authData already stored
518
455
  if (!validationResult.doNotSave) {
519
456
  acc.authData[provider] = validationResult.save || authData[provider];
520
457
  }
@@ -524,21 +461,17 @@ const handleAuthDataValidation = async (authData, req, foundUser) => {
524
461
  message: 'Auth failed. Unknown error.'
525
462
  });
526
463
  const userString = req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;
527
-
528
464
  _logger.logger.error(`Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` + JSON.stringify(e), {
529
465
  authenticationStep: method,
530
466
  error: e,
531
467
  user: userString,
532
468
  provider
533
469
  });
534
-
535
470
  throw e;
536
471
  }
537
472
  }
538
-
539
473
  return acc;
540
474
  };
541
-
542
475
  module.exports = {
543
476
  Auth,
544
477
  master,
@@ -551,4 +484,4 @@ module.exports = {
551
484
  checkIfUserHasProvidedConfiguredProvidersForLogin,
552
485
  handleAuthDataValidation
553
486
  };
554
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Auth.js"],"names":["Parse","require","Auth","config","cacheController","undefined","isMaster","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","readOnly","nobody","getAuthForSessionToken","sessionToken","userJSON","get","cachedUser","Object","fromJSON","Promise","resolve","results","restOptions","limit","include","RestQuery","query","execute","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","Error","INVALID_SESSION_TOKEN","now","Date","expiresAt","iso","password","put","userObject","getAuthForLegacySessionToken","then","response","className","getUserRoles","_loadRoles","getRolesForUser","restWhere","users","__type","objectId","id","each","result","push","Role","cachedRoles","role","cacheRoles","rolesMap","reduce","m","r","names","name","ids","roleNames","_getAllRolesNamesForRoleIds","Array","clearRoleCache","del","getRolesByIds","ins","containedIn","roles","$in","roleIDs","queriedRoles","filter","roleID","wasQueried","Set","resultMap","memo","concat","findUsersWithAuthData","authData","providers","keys","provider","queryKey","q","database","$or","hasMutatedAuthData","userAuthData","mutatedAuthData","forEach","providerData","userProviderAuthData","checkIfUserHasProvidedConfiguredProvidersForLogin","savedUserProviders","adapter","authDataManager","getValidatorForProvider","hasProvidedASoloProvider","some","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","OTHER_CAUSE","join","handleAuthDataValidation","req","foundUser","User","auth","getUserId","fetch","originalObject","updatedObject","buildParseObjects","requestObject","acc","authDataResponse","authKeys","sort","method","validator","authProvider","enabled","Deprecator","logRuntimeDeprecation","usage","solution","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","e","code","SCRIPT_FAILED","message","userString","data","logger","error","JSON","stringify","authenticationStep","module","exports"],"mappings":"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","sourcesContent":["const Parse = require('parse/node');\nimport { isDeepStrictEqual } from 'util';\nimport { getRequestObject, resolveError } from './triggers';\nimport Deprecator from './Deprecator/Deprecator';\nimport { logger } from './logger';\n\n// An Auth object tells you who is requesting something and whether\n// the master key was used.\n// userObject is a Parse.User and can be null if there's no user.\nfunction Auth({\n  config,\n  cacheController = undefined,\n  isMaster = false,\n  isReadOnly = false,\n  user,\n  installationId,\n}) {\n  this.config = config;\n  this.cacheController = cacheController || (config && config.cacheController);\n  this.installationId = installationId;\n  this.isMaster = isMaster;\n  this.user = user;\n  this.isReadOnly = isReadOnly;\n\n  // Assuming a users roles won't change during a single request, we'll\n  // only load them once.\n  this.userRoles = [];\n  this.fetchedRoles = false;\n  this.rolePromise = null;\n}\n\n// Whether this auth could possibly modify the given user id.\n// It still could be forbidden via ACLs even if this returns true.\nAuth.prototype.isUnauthenticated = function () {\n  if (this.isMaster) {\n    return false;\n  }\n  if (this.user) {\n    return false;\n  }\n  return true;\n};\n\n// A helper to get a master-level Auth object\nfunction master(config) {\n  return new Auth({ config, isMaster: true });\n}\n\n// A helper to get a master-level Auth object\nfunction readOnly(config) {\n  return new Auth({ config, isMaster: true, isReadOnly: true });\n}\n\n// A helper to get a nobody-level Auth object\nfunction nobody(config) {\n  return new Auth({ config, isMaster: false });\n}\n\n// Returns a promise that resolves to an Auth object\nconst getAuthForSessionToken = async function ({\n  config,\n  cacheController,\n  sessionToken,\n  installationId,\n}) {\n  cacheController = cacheController || (config && config.cacheController);\n  if (cacheController) {\n    const userJSON = await cacheController.user.get(sessionToken);\n    if (userJSON) {\n      const cachedUser = Parse.Object.fromJSON(userJSON);\n      return Promise.resolve(\n        new Auth({\n          config,\n          cacheController,\n          isMaster: false,\n          installationId,\n          user: cachedUser,\n        })\n      );\n    }\n  }\n\n  let results;\n  if (config) {\n    const restOptions = {\n      limit: 1,\n      include: 'user',\n    };\n    const RestQuery = require('./RestQuery');\n    const query = new RestQuery(config, master(config), '_Session', { sessionToken }, restOptions);\n    results = (await query.execute()).results;\n  } else {\n    results = (\n      await new Parse.Query(Parse.Session)\n        .limit(1)\n        .include('user')\n        .equalTo('sessionToken', sessionToken)\n        .find({ useMasterKey: true })\n    ).map(obj => obj.toJSON());\n  }\n\n  if (results.length !== 1 || !results[0]['user']) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const now = new Date(),\n    expiresAt = results[0].expiresAt ? new Date(results[0].expiresAt.iso) : undefined;\n  if (expiresAt < now) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n  }\n  const obj = results[0]['user'];\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, obj);\n  }\n  const userObject = Parse.Object.fromJSON(obj);\n  return new Auth({\n    config,\n    cacheController,\n    isMaster: false,\n    installationId,\n    user: userObject,\n  });\n};\n\nvar getAuthForLegacySessionToken = function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  const RestQuery = require('./RestQuery');\n  var query = new RestQuery(config, master(config), '_User', { sessionToken }, restOptions);\n  return query.execute().then(response => {\n    var results = response.results;\n    if (results.length !== 1) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');\n    }\n    const obj = results[0];\n    obj.className = '_User';\n    const userObject = Parse.Object.fromJSON(obj);\n    return new Auth({\n      config,\n      isMaster: false,\n      installationId,\n      user: userObject,\n    });\n  });\n};\n\n// Returns a promise that resolves to an array of role names\nAuth.prototype.getUserRoles = function () {\n  if (this.isMaster || !this.user) {\n    return Promise.resolve([]);\n  }\n  if (this.fetchedRoles) {\n    return Promise.resolve(this.userRoles);\n  }\n  if (this.rolePromise) {\n    return this.rolePromise;\n  }\n  this.rolePromise = this._loadRoles();\n  return this.rolePromise;\n};\n\nAuth.prototype.getRolesForUser = async function () {\n  //Stack all Parse.Role\n  const results = [];\n  if (this.config) {\n    const restWhere = {\n      users: {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: this.user.id,\n      },\n    };\n    const RestQuery = require('./RestQuery');\n    await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result =>\n      results.push(result)\n    );\n  } else {\n    await new Parse.Query(Parse.Role)\n      .equalTo('users', this.user)\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  }\n  return results;\n};\n\n// Iterates through the role tree and compiles a user's roles\nAuth.prototype._loadRoles = async function () {\n  if (this.cacheController) {\n    const cachedRoles = await this.cacheController.role.get(this.user.id);\n    if (cachedRoles != null) {\n      this.fetchedRoles = true;\n      this.userRoles = cachedRoles;\n      return cachedRoles;\n    }\n  }\n\n  // First get the role ids this user is directly a member of\n  const results = await this.getRolesForUser();\n  if (!results.length) {\n    this.userRoles = [];\n    this.fetchedRoles = true;\n    this.rolePromise = null;\n\n    this.cacheRoles();\n    return this.userRoles;\n  }\n\n  const rolesMap = results.reduce(\n    (m, r) => {\n      m.names.push(r.name);\n      m.ids.push(r.objectId);\n      return m;\n    },\n    { ids: [], names: [] }\n  );\n\n  // run the recursive finding\n  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);\n  this.userRoles = roleNames.map(r => {\n    return 'role:' + r;\n  });\n  this.fetchedRoles = true;\n  this.rolePromise = null;\n  this.cacheRoles();\n  return this.userRoles;\n};\n\nAuth.prototype.cacheRoles = function () {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.put(this.user.id, Array(...this.userRoles));\n  return true;\n};\n\nAuth.prototype.clearRoleCache = function (sessionToken) {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.del(this.user.id);\n  this.cacheController.user.del(sessionToken);\n  return true;\n};\n\nAuth.prototype.getRolesByIds = async function (ins) {\n  const results = [];\n  // Build an OR query across all parentRoles\n  if (!this.config) {\n    await new Parse.Query(Parse.Role)\n      .containedIn(\n        'roles',\n        ins.map(id => {\n          const role = new Parse.Object(Parse.Role);\n          role.id = id;\n          return role;\n        })\n      )\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  } else {\n    const roles = ins.map(id => {\n      return {\n        __type: 'Pointer',\n        className: '_Role',\n        objectId: id,\n      };\n    });\n    const restWhere = { roles: { $in: roles } };\n    const RestQuery = require('./RestQuery');\n    await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result =>\n      results.push(result)\n    );\n  }\n  return results;\n};\n\n// Given a list of roleIds, find all the parent roles, returns a promise with all names\nAuth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {\n  const ins = roleIDs.filter(roleID => {\n    const wasQueried = queriedRoles[roleID] !== true;\n    queriedRoles[roleID] = true;\n    return wasQueried;\n  });\n\n  // all roles are accounted for, return the names\n  if (ins.length == 0) {\n    return Promise.resolve([...new Set(names)]);\n  }\n\n  return this.getRolesByIds(ins)\n    .then(results => {\n      // Nothing found\n      if (!results.length) {\n        return Promise.resolve(names);\n      }\n      // Map the results with all Ids and names\n      const resultMap = results.reduce(\n        (memo, role) => {\n          memo.names.push(role.name);\n          memo.ids.push(role.objectId);\n          return memo;\n        },\n        { ids: [], names: [] }\n      );\n      // store the new found names\n      names = names.concat(resultMap.names);\n      // find the next ones, circular roles will be cut\n      return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);\n    })\n    .then(names => {\n      return Promise.resolve([...new Set(names)]);\n    });\n};\n\nconst findUsersWithAuthData = (config, authData) => {\n  const providers = Object.keys(authData);\n  const query = providers\n    .reduce((memo, provider) => {\n      if (!authData[provider] || (authData && !authData[provider].id)) {\n        return memo;\n      }\n      const queryKey = `authData.${provider}.id`;\n      const query = {};\n      query[queryKey] = authData[provider].id;\n      memo.push(query);\n      return memo;\n    }, [])\n    .filter(q => {\n      return typeof q !== 'undefined';\n    });\n\n  return query.length > 0\n    ? config.database.find('_User', { $or: query }, { limit: 2 })\n    : Promise.resolve([]);\n};\n\nconst hasMutatedAuthData = (authData, userAuthData) => {\n  if (!userAuthData) return { hasMutatedAuthData: true, mutatedAuthData: authData };\n  const mutatedAuthData = {};\n  Object.keys(authData).forEach(provider => {\n    // Anonymous provider is not handled this way\n    if (provider === 'anonymous') return;\n    const providerData = authData[provider];\n    const userProviderAuthData = userAuthData[provider];\n    if (!isDeepStrictEqual(providerData, userProviderAuthData)) {\n      mutatedAuthData[provider] = providerData;\n    }\n  });\n  const hasMutatedAuthData = Object.keys(mutatedAuthData).length !== 0;\n  return { hasMutatedAuthData, mutatedAuthData };\n};\n\nconst checkIfUserHasProvidedConfiguredProvidersForLogin = (\n  authData = {},\n  userAuthData = {},\n  config\n) => {\n  const savedUserProviders = Object.keys(userAuthData).map(provider => ({\n    name: provider,\n    adapter: config.authDataManager.getValidatorForProvider(provider).adapter,\n  }));\n\n  const hasProvidedASoloProvider = savedUserProviders.some(\n    provider =>\n      provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]\n  );\n\n  // Solo providers can be considered as safe, so we do not have to check if the user needs\n  // to provide an additional provider to login. An auth adapter with \"solo\" (like webauthn) means\n  // no \"additional\" auth needs to be provided to login (like OTP, MFA)\n  if (hasProvidedASoloProvider) {\n    return;\n  }\n\n  const additionProvidersNotFound = [];\n  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {\n    if (provider && provider.adapter && provider.adapter.policy === 'additional') {\n      if (authData[provider.name]) {\n        return true;\n      } else {\n        // Push missing provider for error message\n        additionProvidersNotFound.push(provider.name);\n      }\n    }\n  });\n  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {\n    return;\n  }\n\n  throw new Parse.Error(\n    Parse.Error.OTHER_CAUSE,\n    `Missing additional authData ${additionProvidersNotFound.join(',')}`\n  );\n};\n\n// Validate each authData step-by-step and return the provider responses\nconst handleAuthDataValidation = async (authData, req, foundUser) => {\n  let user;\n  if (foundUser) {\n    user = Parse.User.fromJSON({ className: '_User', ...foundUser });\n    // Find user by session and current objectId; only pass user if it's the current user or master key is provided\n  } else if (\n    (req.auth &&\n      req.auth.user &&\n      typeof req.getUserId === 'function' &&\n      req.getUserId() === req.auth.user.id) ||\n    (req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId())\n  ) {\n    user = new Parse.User();\n    user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;\n    await user.fetch({ useMasterKey: true });\n  }\n\n  const { originalObject, updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(\n    undefined,\n    req.auth,\n    updatedObject,\n    originalObject || user,\n    req.config\n  );\n  // Perform validation as step-by-step pipeline for better error consistency\n  // and also to avoid to trigger a provider (like OTP SMS) if another one fails\n  const acc = { authData: {}, authDataResponse: {} };\n  const authKeys = Object.keys(authData).sort();\n  for (const provider of authKeys) {\n    let method = '';\n    try {\n      if (authData[provider] === null) {\n        acc.authData[provider] = null;\n        continue;\n      }\n      const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n      const authProvider = (req.config.auth || {})[provider] || {};\n      if (authProvider.enabled == null) {\n        Deprecator.logRuntimeDeprecation({\n          usage: `auth.${provider}`,\n          solution: `auth.${provider}.enabled: true`,\n        });\n      }\n      if (!validator || authProvider.enabled === false) {\n        throw new Parse.Error(\n          Parse.Error.UNSUPPORTED_SERVICE,\n          'This authentication method is unsupported.'\n        );\n      }\n      let validationResult = await validator(authData[provider], req, user, requestObject);\n      method = validationResult && validationResult.method;\n      requestObject.triggerName = method;\n      if (validationResult && validationResult.validator) {\n        validationResult = await validationResult.validator();\n      }\n      if (!validationResult) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n      if (!Object.keys(validationResult).length) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n\n      if (validationResult.response) {\n        acc.authDataResponse[provider] = validationResult.response;\n      }\n      // Some auth providers after initialization will avoid to replace authData already stored\n      if (!validationResult.doNotSave) {\n        acc.authData[provider] = validationResult.save || authData[provider];\n      }\n    } catch (err) {\n      const e = resolveError(err, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: 'Auth failed. Unknown error.',\n      });\n      const userString =\n        req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;\n      logger.error(\n        `Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` +\n          JSON.stringify(e),\n        {\n          authenticationStep: method,\n          error: e,\n          user: userString,\n          provider,\n        }\n      );\n      throw e;\n    }\n  }\n  return acc;\n};\n\nmodule.exports = {\n  Auth,\n  master,\n  nobody,\n  readOnly,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"]}
487
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","Auth","config","cacheController","undefined","isMaster","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","readOnly","nobody","getAuthForSessionToken","sessionToken","userJSON","get","cachedUser","Object","fromJSON","Promise","resolve","results","restOptions","limit","include","RestQuery","query","execute","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","Error","INVALID_SESSION_TOKEN","now","Date","expiresAt","iso","password","put","userObject","getAuthForLegacySessionToken","then","response","className","getUserRoles","_loadRoles","getRolesForUser","restWhere","users","__type","objectId","id","each","result","push","Role","cachedRoles","role","cacheRoles","rolesMap","reduce","m","r","names","name","ids","roleNames","_getAllRolesNamesForRoleIds","Array","clearRoleCache","del","getRolesByIds","ins","containedIn","roles","$in","roleIDs","queriedRoles","filter","roleID","wasQueried","Set","resultMap","memo","concat","findUsersWithAuthData","authData","providers","keys","provider","queryKey","q","database","$or","hasMutatedAuthData","userAuthData","mutatedAuthData","forEach","providerData","userProviderAuthData","isDeepStrictEqual","checkIfUserHasProvidedConfiguredProvidersForLogin","savedUserProviders","adapter","authDataManager","getValidatorForProvider","hasProvidedASoloProvider","some","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","OTHER_CAUSE","join","handleAuthDataValidation","req","foundUser","User","auth","getUserId","fetch","originalObject","updatedObject","buildParseObjects","requestObject","getRequestObject","acc","authDataResponse","authKeys","sort","method","validator","authProvider","enabled","Deprecator","logRuntimeDeprecation","usage","solution","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","e","resolveError","code","SCRIPT_FAILED","message","userString","data","logger","error","JSON","stringify","authenticationStep","module","exports"],"sources":["../src/Auth.js"],"sourcesContent":["const Parse = require('parse/node');\nimport { isDeepStrictEqual } from 'util';\nimport { getRequestObject, resolveError } from './triggers';\nimport Deprecator from './Deprecator/Deprecator';\nimport { logger } from './logger';\n\n// An Auth object tells you who is requesting something and whether\n// the master key was used.\n// userObject is a Parse.User and can be null if there's no user.\nfunction Auth({\n  config,\n  cacheController = undefined,\n  isMaster = false,\n  isReadOnly = false,\n  user,\n  installationId,\n}) {\n  this.config = config;\n  this.cacheController = cacheController || (config && config.cacheController);\n  this.installationId = installationId;\n  this.isMaster = isMaster;\n  this.user = user;\n  this.isReadOnly = isReadOnly;\n\n  // Assuming a users roles won't change during a single request, we'll\n  // only load them once.\n  this.userRoles = [];\n  this.fetchedRoles = false;\n  this.rolePromise = null;\n}\n\n// Whether this auth could possibly modify the given user id.\n// It still could be forbidden via ACLs even if this returns true.\nAuth.prototype.isUnauthenticated = function () {\n  if (this.isMaster) {\n    return false;\n  }\n  if (this.user) {\n    return false;\n  }\n  return true;\n};\n\n// A helper to get a master-level Auth object\nfunction master(config) {\n  return new Auth({ config, isMaster: true });\n}\n\n// A helper to get a master-level Auth object\nfunction readOnly(config) {\n  return new Auth({ config, isMaster: true, isReadOnly: true });\n}\n\n// A helper to get a nobody-level Auth object\nfunction nobody(config) {\n  return new Auth({ config, isMaster: false });\n}\n\n// Returns a promise that resolves to an Auth object\nconst getAuthForSessionToken = async function ({\n  config,\n  cacheController,\n  sessionToken,\n  installationId,\n}) {\n  cacheController = cacheController || (config && config.cacheController);\n  if (cacheController) {\n    const userJSON = await cacheController.user.get(sessionToken);\n    if (userJSON) {\n      const cachedUser = Parse.Object.fromJSON(userJSON);\n      return Promise.resolve(\n        new Auth({\n          config,\n          cacheController,\n          isMaster: false,\n          installationId,\n          user: cachedUser,\n        })\n      );\n    }\n  }\n\n  let results;\n  if (config) {\n    const restOptions = {\n      limit: 1,\n      include: 'user',\n    };\n    const RestQuery = require('./RestQuery');\n    const query = new RestQuery(config, master(config), '_Session', { sessionToken }, restOptions);\n    results = (await query.execute()).results;\n  } else {\n    results = (\n      await new Parse.Query(Parse.Session)\n        .limit(1)\n        .include('user')\n        .equalTo('sessionToken', sessionToken)\n        .find({ useMasterKey: true })\n    ).map(obj => obj.toJSON());\n  }\n\n  if (results.length !== 1 || !results[0]['user']) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const now = new Date(),\n    expiresAt = results[0].expiresAt ? new Date(results[0].expiresAt.iso) : undefined;\n  if (expiresAt < now) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n  }\n  const obj = results[0]['user'];\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, obj);\n  }\n  const userObject = Parse.Object.fromJSON(obj);\n  return new Auth({\n    config,\n    cacheController,\n    isMaster: false,\n    installationId,\n    user: userObject,\n  });\n};\n\nvar getAuthForLegacySessionToken = function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  const RestQuery = require('./RestQuery');\n  var query = new RestQuery(config, master(config), '_User', { sessionToken }, restOptions);\n  return query.execute().then(response => {\n    var results = response.results;\n    if (results.length !== 1) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');\n    }\n    const obj = results[0];\n    obj.className = '_User';\n    const userObject = Parse.Object.fromJSON(obj);\n    return new Auth({\n      config,\n      isMaster: false,\n      installationId,\n      user: userObject,\n    });\n  });\n};\n\n// Returns a promise that resolves to an array of role names\nAuth.prototype.getUserRoles = function () {\n  if (this.isMaster || !this.user) {\n    return Promise.resolve([]);\n  }\n  if (this.fetchedRoles) {\n    return Promise.resolve(this.userRoles);\n  }\n  if (this.rolePromise) {\n    return this.rolePromise;\n  }\n  this.rolePromise = this._loadRoles();\n  return this.rolePromise;\n};\n\nAuth.prototype.getRolesForUser = async function () {\n  //Stack all Parse.Role\n  const results = [];\n  if (this.config) {\n    const restWhere = {\n      users: {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: this.user.id,\n      },\n    };\n    const RestQuery = require('./RestQuery');\n    await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result =>\n      results.push(result)\n    );\n  } else {\n    await new Parse.Query(Parse.Role)\n      .equalTo('users', this.user)\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  }\n  return results;\n};\n\n// Iterates through the role tree and compiles a user's roles\nAuth.prototype._loadRoles = async function () {\n  if (this.cacheController) {\n    const cachedRoles = await this.cacheController.role.get(this.user.id);\n    if (cachedRoles != null) {\n      this.fetchedRoles = true;\n      this.userRoles = cachedRoles;\n      return cachedRoles;\n    }\n  }\n\n  // First get the role ids this user is directly a member of\n  const results = await this.getRolesForUser();\n  if (!results.length) {\n    this.userRoles = [];\n    this.fetchedRoles = true;\n    this.rolePromise = null;\n\n    this.cacheRoles();\n    return this.userRoles;\n  }\n\n  const rolesMap = results.reduce(\n    (m, r) => {\n      m.names.push(r.name);\n      m.ids.push(r.objectId);\n      return m;\n    },\n    { ids: [], names: [] }\n  );\n\n  // run the recursive finding\n  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);\n  this.userRoles = roleNames.map(r => {\n    return 'role:' + r;\n  });\n  this.fetchedRoles = true;\n  this.rolePromise = null;\n  this.cacheRoles();\n  return this.userRoles;\n};\n\nAuth.prototype.cacheRoles = function () {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.put(this.user.id, Array(...this.userRoles));\n  return true;\n};\n\nAuth.prototype.clearRoleCache = function (sessionToken) {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.del(this.user.id);\n  this.cacheController.user.del(sessionToken);\n  return true;\n};\n\nAuth.prototype.getRolesByIds = async function (ins) {\n  const results = [];\n  // Build an OR query across all parentRoles\n  if (!this.config) {\n    await new Parse.Query(Parse.Role)\n      .containedIn(\n        'roles',\n        ins.map(id => {\n          const role = new Parse.Object(Parse.Role);\n          role.id = id;\n          return role;\n        })\n      )\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  } else {\n    const roles = ins.map(id => {\n      return {\n        __type: 'Pointer',\n        className: '_Role',\n        objectId: id,\n      };\n    });\n    const restWhere = { roles: { $in: roles } };\n    const RestQuery = require('./RestQuery');\n    await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result =>\n      results.push(result)\n    );\n  }\n  return results;\n};\n\n// Given a list of roleIds, find all the parent roles, returns a promise with all names\nAuth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {\n  const ins = roleIDs.filter(roleID => {\n    const wasQueried = queriedRoles[roleID] !== true;\n    queriedRoles[roleID] = true;\n    return wasQueried;\n  });\n\n  // all roles are accounted for, return the names\n  if (ins.length == 0) {\n    return Promise.resolve([...new Set(names)]);\n  }\n\n  return this.getRolesByIds(ins)\n    .then(results => {\n      // Nothing found\n      if (!results.length) {\n        return Promise.resolve(names);\n      }\n      // Map the results with all Ids and names\n      const resultMap = results.reduce(\n        (memo, role) => {\n          memo.names.push(role.name);\n          memo.ids.push(role.objectId);\n          return memo;\n        },\n        { ids: [], names: [] }\n      );\n      // store the new found names\n      names = names.concat(resultMap.names);\n      // find the next ones, circular roles will be cut\n      return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);\n    })\n    .then(names => {\n      return Promise.resolve([...new Set(names)]);\n    });\n};\n\nconst findUsersWithAuthData = (config, authData) => {\n  const providers = Object.keys(authData);\n  const query = providers\n    .reduce((memo, provider) => {\n      if (!authData[provider] || (authData && !authData[provider].id)) {\n        return memo;\n      }\n      const queryKey = `authData.${provider}.id`;\n      const query = {};\n      query[queryKey] = authData[provider].id;\n      memo.push(query);\n      return memo;\n    }, [])\n    .filter(q => {\n      return typeof q !== 'undefined';\n    });\n\n  return query.length > 0\n    ? config.database.find('_User', { $or: query }, { limit: 2 })\n    : Promise.resolve([]);\n};\n\nconst hasMutatedAuthData = (authData, userAuthData) => {\n  if (!userAuthData) return { hasMutatedAuthData: true, mutatedAuthData: authData };\n  const mutatedAuthData = {};\n  Object.keys(authData).forEach(provider => {\n    // Anonymous provider is not handled this way\n    if (provider === 'anonymous') return;\n    const providerData = authData[provider];\n    const userProviderAuthData = userAuthData[provider];\n    if (!isDeepStrictEqual(providerData, userProviderAuthData)) {\n      mutatedAuthData[provider] = providerData;\n    }\n  });\n  const hasMutatedAuthData = Object.keys(mutatedAuthData).length !== 0;\n  return { hasMutatedAuthData, mutatedAuthData };\n};\n\nconst checkIfUserHasProvidedConfiguredProvidersForLogin = (\n  authData = {},\n  userAuthData = {},\n  config\n) => {\n  const savedUserProviders = Object.keys(userAuthData).map(provider => ({\n    name: provider,\n    adapter: config.authDataManager.getValidatorForProvider(provider).adapter,\n  }));\n\n  const hasProvidedASoloProvider = savedUserProviders.some(\n    provider =>\n      provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]\n  );\n\n  // Solo providers can be considered as safe, so we do not have to check if the user needs\n  // to provide an additional provider to login. An auth adapter with \"solo\" (like webauthn) means\n  // no \"additional\" auth needs to be provided to login (like OTP, MFA)\n  if (hasProvidedASoloProvider) {\n    return;\n  }\n\n  const additionProvidersNotFound = [];\n  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {\n    if (provider && provider.adapter && provider.adapter.policy === 'additional') {\n      if (authData[provider.name]) {\n        return true;\n      } else {\n        // Push missing provider for error message\n        additionProvidersNotFound.push(provider.name);\n      }\n    }\n  });\n  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {\n    return;\n  }\n\n  throw new Parse.Error(\n    Parse.Error.OTHER_CAUSE,\n    `Missing additional authData ${additionProvidersNotFound.join(',')}`\n  );\n};\n\n// Validate each authData step-by-step and return the provider responses\nconst handleAuthDataValidation = async (authData, req, foundUser) => {\n  let user;\n  if (foundUser) {\n    user = Parse.User.fromJSON({ className: '_User', ...foundUser });\n    // Find user by session and current objectId; only pass user if it's the current user or master key is provided\n  } else if (\n    (req.auth &&\n      req.auth.user &&\n      typeof req.getUserId === 'function' &&\n      req.getUserId() === req.auth.user.id) ||\n    (req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId())\n  ) {\n    user = new Parse.User();\n    user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;\n    await user.fetch({ useMasterKey: true });\n  }\n\n  const { originalObject, updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(\n    undefined,\n    req.auth,\n    updatedObject,\n    originalObject || user,\n    req.config\n  );\n  // Perform validation as step-by-step pipeline for better error consistency\n  // and also to avoid to trigger a provider (like OTP SMS) if another one fails\n  const acc = { authData: {}, authDataResponse: {} };\n  const authKeys = Object.keys(authData).sort();\n  for (const provider of authKeys) {\n    let method = '';\n    try {\n      if (authData[provider] === null) {\n        acc.authData[provider] = null;\n        continue;\n      }\n      const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n      const authProvider = (req.config.auth || {})[provider] || {};\n      if (authProvider.enabled == null) {\n        Deprecator.logRuntimeDeprecation({\n          usage: `Using the authentication adapter \"${provider}\" without explicitly enabling it`,\n          solution: `Enable the authentication adapter by setting the Parse Server option \"auth.${provider}.enabled: true\".`,\n        });\n      }\n      if (!validator || authProvider.enabled === false) {\n        throw new Parse.Error(\n          Parse.Error.UNSUPPORTED_SERVICE,\n          'This authentication method is unsupported.'\n        );\n      }\n      let validationResult = await validator(authData[provider], req, user, requestObject);\n      method = validationResult && validationResult.method;\n      requestObject.triggerName = method;\n      if (validationResult && validationResult.validator) {\n        validationResult = await validationResult.validator();\n      }\n      if (!validationResult) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n      if (!Object.keys(validationResult).length) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n\n      if (validationResult.response) {\n        acc.authDataResponse[provider] = validationResult.response;\n      }\n      // Some auth providers after initialization will avoid to replace authData already stored\n      if (!validationResult.doNotSave) {\n        acc.authData[provider] = validationResult.save || authData[provider];\n      }\n    } catch (err) {\n      const e = resolveError(err, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: 'Auth failed. Unknown error.',\n      });\n      const userString =\n        req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;\n      logger.error(\n        `Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` +\n          JSON.stringify(e),\n        {\n          authenticationStep: method,\n          error: e,\n          user: userString,\n          provider,\n        }\n      );\n      throw e;\n    }\n  }\n  return acc;\n};\n\nmodule.exports = {\n  Auth,\n  master,\n  nobody,\n  readOnly,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"],"mappings":";;AACA;AACA;AACA;AACA;AAAkC;AAAA;AAAA;AAAA;AAAA;AAAA;AAJlC,MAAMA,KAAK,GAAGC,OAAO,CAAC,YAAY,CAAC;AAMnC;AACA;AACA;AACA,SAASC,IAAI,CAAC;EACZC,MAAM;EACNC,eAAe,GAAGC,SAAS;EAC3BC,QAAQ,GAAG,KAAK;EAChBC,UAAU,GAAG,KAAK;EAClBC,IAAI;EACJC;AACF,CAAC,EAAE;EACD,IAAI,CAACN,MAAM,GAAGA,MAAM;EACpB,IAAI,CAACC,eAAe,GAAGA,eAAe,IAAKD,MAAM,IAAIA,MAAM,CAACC,eAAgB;EAC5E,IAAI,CAACK,cAAc,GAAGA,cAAc;EACpC,IAAI,CAACH,QAAQ,GAAGA,QAAQ;EACxB,IAAI,CAACE,IAAI,GAAGA,IAAI;EAChB,IAAI,CAACD,UAAU,GAAGA,UAAU;;EAE5B;EACA;EACA,IAAI,CAACG,SAAS,GAAG,EAAE;EACnB,IAAI,CAACC,YAAY,GAAG,KAAK;EACzB,IAAI,CAACC,WAAW,GAAG,IAAI;AACzB;;AAEA;AACA;AACAV,IAAI,CAACW,SAAS,CAACC,iBAAiB,GAAG,YAAY;EAC7C,IAAI,IAAI,CAACR,QAAQ,EAAE;IACjB,OAAO,KAAK;EACd;EACA,IAAI,IAAI,CAACE,IAAI,EAAE;IACb,OAAO,KAAK;EACd;EACA,OAAO,IAAI;AACb,CAAC;;AAED;AACA,SAASO,MAAM,CAACZ,MAAM,EAAE;EACtB,OAAO,IAAID,IAAI,CAAC;IAAEC,MAAM;IAAEG,QAAQ,EAAE;EAAK,CAAC,CAAC;AAC7C;;AAEA;AACA,SAASU,QAAQ,CAACb,MAAM,EAAE;EACxB,OAAO,IAAID,IAAI,CAAC;IAAEC,MAAM;IAAEG,QAAQ,EAAE,IAAI;IAAEC,UAAU,EAAE;EAAK,CAAC,CAAC;AAC/D;;AAEA;AACA,SAASU,MAAM,CAACd,MAAM,EAAE;EACtB,OAAO,IAAID,IAAI,CAAC;IAAEC,MAAM;IAAEG,QAAQ,EAAE;EAAM,CAAC,CAAC;AAC9C;;AAEA;AACA,MAAMY,sBAAsB,GAAG,gBAAgB;EAC7Cf,MAAM;EACNC,eAAe;EACfe,YAAY;EACZV;AACF,CAAC,EAAE;EACDL,eAAe,GAAGA,eAAe,IAAKD,MAAM,IAAIA,MAAM,CAACC,eAAgB;EACvE,IAAIA,eAAe,EAAE;IACnB,MAAMgB,QAAQ,GAAG,MAAMhB,eAAe,CAACI,IAAI,CAACa,GAAG,CAACF,YAAY,CAAC;IAC7D,IAAIC,QAAQ,EAAE;MACZ,MAAME,UAAU,GAAGtB,KAAK,CAACuB,MAAM,CAACC,QAAQ,CAACJ,QAAQ,CAAC;MAClD,OAAOK,OAAO,CAACC,OAAO,CACpB,IAAIxB,IAAI,CAAC;QACPC,MAAM;QACNC,eAAe;QACfE,QAAQ,EAAE,KAAK;QACfG,cAAc;QACdD,IAAI,EAAEc;MACR,CAAC,CAAC,CACH;IACH;EACF;EAEA,IAAIK,OAAO;EACX,IAAIxB,MAAM,EAAE;IACV,MAAMyB,WAAW,GAAG;MAClBC,KAAK,EAAE,CAAC;MACRC,OAAO,EAAE;IACX,CAAC;IACD,MAAMC,SAAS,GAAG9B,OAAO,CAAC,aAAa,CAAC;IACxC,MAAM+B,KAAK,GAAG,IAAID,SAAS,CAAC5B,MAAM,EAAEY,MAAM,CAACZ,MAAM,CAAC,EAAE,UAAU,EAAE;MAAEgB;IAAa,CAAC,EAAES,WAAW,CAAC;IAC9FD,OAAO,GAAG,CAAC,MAAMK,KAAK,CAACC,OAAO,EAAE,EAAEN,OAAO;EAC3C,CAAC,MAAM;IACLA,OAAO,GAAG,CACR,MAAM,IAAI3B,KAAK,CAACkC,KAAK,CAAClC,KAAK,CAACmC,OAAO,CAAC,CACjCN,KAAK,CAAC,CAAC,CAAC,CACRC,OAAO,CAAC,MAAM,CAAC,CACfM,OAAO,CAAC,cAAc,EAAEjB,YAAY,CAAC,CACrCkB,IAAI,CAAC;MAAEC,YAAY,EAAE;IAAK,CAAC,CAAC,EAC/BC,GAAG,CAACC,GAAG,IAAIA,GAAG,CAACC,MAAM,EAAE,CAAC;EAC5B;EAEA,IAAId,OAAO,CAACe,MAAM,KAAK,CAAC,IAAI,CAACf,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE;IAC/C,MAAM,IAAI3B,KAAK,CAAC2C,KAAK,CAAC3C,KAAK,CAAC2C,KAAK,CAACC,qBAAqB,EAAE,uBAAuB,CAAC;EACnF;EACA,MAAMC,GAAG,GAAG,IAAIC,IAAI,EAAE;IACpBC,SAAS,GAAGpB,OAAO,CAAC,CAAC,CAAC,CAACoB,SAAS,GAAG,IAAID,IAAI,CAACnB,OAAO,CAAC,CAAC,CAAC,CAACoB,SAAS,CAACC,GAAG,CAAC,GAAG3C,SAAS;EACnF,IAAI0C,SAAS,GAAGF,GAAG,EAAE;IACnB,MAAM,IAAI7C,KAAK,CAAC2C,KAAK,CAAC3C,KAAK,CAAC2C,KAAK,CAACC,qBAAqB,EAAE,2BAA2B,CAAC;EACvF;EACA,MAAMJ,GAAG,GAAGb,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;EAC9B,OAAOa,GAAG,CAACS,QAAQ;EACnBT,GAAG,CAAC,WAAW,CAAC,GAAG,OAAO;EAC1BA,GAAG,CAAC,cAAc,CAAC,GAAGrB,YAAY;EAClC,IAAIf,eAAe,EAAE;IACnBA,eAAe,CAACI,IAAI,CAAC0C,GAAG,CAAC/B,YAAY,EAAEqB,GAAG,CAAC;EAC7C;EACA,MAAMW,UAAU,GAAGnD,KAAK,CAACuB,MAAM,CAACC,QAAQ,CAACgB,GAAG,CAAC;EAC7C,OAAO,IAAItC,IAAI,CAAC;IACdC,MAAM;IACNC,eAAe;IACfE,QAAQ,EAAE,KAAK;IACfG,cAAc;IACdD,IAAI,EAAE2C;EACR,CAAC,CAAC;AACJ,CAAC;AAED,IAAIC,4BAA4B,GAAG,UAAU;EAAEjD,MAAM;EAAEgB,YAAY;EAAEV;AAAe,CAAC,EAAE;EACrF,IAAImB,WAAW,GAAG;IAChBC,KAAK,EAAE;EACT,CAAC;EACD,MAAME,SAAS,GAAG9B,OAAO,CAAC,aAAa,CAAC;EACxC,IAAI+B,KAAK,GAAG,IAAID,SAAS,CAAC5B,MAAM,EAAEY,MAAM,CAACZ,MAAM,CAAC,EAAE,OAAO,EAAE;IAAEgB;EAAa,CAAC,EAAES,WAAW,CAAC;EACzF,OAAOI,KAAK,CAACC,OAAO,EAAE,CAACoB,IAAI,CAACC,QAAQ,IAAI;IACtC,IAAI3B,OAAO,GAAG2B,QAAQ,CAAC3B,OAAO;IAC9B,IAAIA,OAAO,CAACe,MAAM,KAAK,CAAC,EAAE;MACxB,MAAM,IAAI1C,KAAK,CAAC2C,KAAK,CAAC3C,KAAK,CAAC2C,KAAK,CAACC,qBAAqB,EAAE,8BAA8B,CAAC;IAC1F;IACA,MAAMJ,GAAG,GAAGb,OAAO,CAAC,CAAC,CAAC;IACtBa,GAAG,CAACe,SAAS,GAAG,OAAO;IACvB,MAAMJ,UAAU,GAAGnD,KAAK,CAACuB,MAAM,CAACC,QAAQ,CAACgB,GAAG,CAAC;IAC7C,OAAO,IAAItC,IAAI,CAAC;MACdC,MAAM;MACNG,QAAQ,EAAE,KAAK;MACfG,cAAc;MACdD,IAAI,EAAE2C;IACR,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC;;AAED;AACAjD,IAAI,CAACW,SAAS,CAAC2C,YAAY,GAAG,YAAY;EACxC,IAAI,IAAI,CAAClD,QAAQ,IAAI,CAAC,IAAI,CAACE,IAAI,EAAE;IAC/B,OAAOiB,OAAO,CAACC,OAAO,CAAC,EAAE,CAAC;EAC5B;EACA,IAAI,IAAI,CAACf,YAAY,EAAE;IACrB,OAAOc,OAAO,CAACC,OAAO,CAAC,IAAI,CAAChB,SAAS,CAAC;EACxC;EACA,IAAI,IAAI,CAACE,WAAW,EAAE;IACpB,OAAO,IAAI,CAACA,WAAW;EACzB;EACA,IAAI,CAACA,WAAW,GAAG,IAAI,CAAC6C,UAAU,EAAE;EACpC,OAAO,IAAI,CAAC7C,WAAW;AACzB,CAAC;AAEDV,IAAI,CAACW,SAAS,CAAC6C,eAAe,GAAG,kBAAkB;EACjD;EACA,MAAM/B,OAAO,GAAG,EAAE;EAClB,IAAI,IAAI,CAACxB,MAAM,EAAE;IACf,MAAMwD,SAAS,GAAG;MAChBC,KAAK,EAAE;QACLC,MAAM,EAAE,SAAS;QACjBN,SAAS,EAAE,OAAO;QAClBO,QAAQ,EAAE,IAAI,CAACtD,IAAI,CAACuD;MACtB;IACF,CAAC;IACD,MAAMhC,SAAS,GAAG9B,OAAO,CAAC,aAAa,CAAC;IACxC,MAAM,IAAI8B,SAAS,CAAC,IAAI,CAAC5B,MAAM,EAAEY,MAAM,CAAC,IAAI,CAACZ,MAAM,CAAC,EAAE,OAAO,EAAEwD,SAAS,EAAE,CAAC,CAAC,CAAC,CAACK,IAAI,CAACC,MAAM,IACvFtC,OAAO,CAACuC,IAAI,CAACD,MAAM,CAAC,CACrB;EACH,CAAC,MAAM;IACL,MAAM,IAAIjE,KAAK,CAACkC,KAAK,CAAClC,KAAK,CAACmE,IAAI,CAAC,CAC9B/B,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC5B,IAAI,CAAC,CAC3BwD,IAAI,CAACC,MAAM,IAAItC,OAAO,CAACuC,IAAI,CAACD,MAAM,CAACxB,MAAM,EAAE,CAAC,EAAE;MAAEH,YAAY,EAAE;IAAK,CAAC,CAAC;EAC1E;EACA,OAAOX,OAAO;AAChB,CAAC;;AAED;AACAzB,IAAI,CAACW,SAAS,CAAC4C,UAAU,GAAG,kBAAkB;EAC5C,IAAI,IAAI,CAACrD,eAAe,EAAE;IACxB,MAAMgE,WAAW,GAAG,MAAM,IAAI,CAAChE,eAAe,CAACiE,IAAI,CAAChD,GAAG,CAAC,IAAI,CAACb,IAAI,CAACuD,EAAE,CAAC;IACrE,IAAIK,WAAW,IAAI,IAAI,EAAE;MACvB,IAAI,CAACzD,YAAY,GAAG,IAAI;MACxB,IAAI,CAACD,SAAS,GAAG0D,WAAW;MAC5B,OAAOA,WAAW;IACpB;EACF;;EAEA;EACA,MAAMzC,OAAO,GAAG,MAAM,IAAI,CAAC+B,eAAe,EAAE;EAC5C,IAAI,CAAC/B,OAAO,CAACe,MAAM,EAAE;IACnB,IAAI,CAAChC,SAAS,GAAG,EAAE;IACnB,IAAI,CAACC,YAAY,GAAG,IAAI;IACxB,IAAI,CAACC,WAAW,GAAG,IAAI;IAEvB,IAAI,CAAC0D,UAAU,EAAE;IACjB,OAAO,IAAI,CAAC5D,SAAS;EACvB;EAEA,MAAM6D,QAAQ,GAAG5C,OAAO,CAAC6C,MAAM,CAC7B,CAACC,CAAC,EAAEC,CAAC,KAAK;IACRD,CAAC,CAACE,KAAK,CAACT,IAAI,CAACQ,CAAC,CAACE,IAAI,CAAC;IACpBH,CAAC,CAACI,GAAG,CAACX,IAAI,CAACQ,CAAC,CAACZ,QAAQ,CAAC;IACtB,OAAOW,CAAC;EACV,CAAC,EACD;IAAEI,GAAG,EAAE,EAAE;IAAEF,KAAK,EAAE;EAAG,CAAC,CACvB;;EAED;EACA,MAAMG,SAAS,GAAG,MAAM,IAAI,CAACC,2BAA2B,CAACR,QAAQ,CAACM,GAAG,EAAEN,QAAQ,CAACI,KAAK,CAAC;EACtF,IAAI,CAACjE,SAAS,GAAGoE,SAAS,CAACvC,GAAG,CAACmC,CAAC,IAAI;IAClC,OAAO,OAAO,GAAGA,CAAC;EACpB,CAAC,CAAC;EACF,IAAI,CAAC/D,YAAY,GAAG,IAAI;EACxB,IAAI,CAACC,WAAW,GAAG,IAAI;EACvB,IAAI,CAAC0D,UAAU,EAAE;EACjB,OAAO,IAAI,CAAC5D,SAAS;AACvB,CAAC;AAEDR,IAAI,CAACW,SAAS,CAACyD,UAAU,GAAG,YAAY;EACtC,IAAI,CAAC,IAAI,CAAClE,eAAe,EAAE;IACzB,OAAO,KAAK;EACd;EACA,IAAI,CAACA,eAAe,CAACiE,IAAI,CAACnB,GAAG,CAAC,IAAI,CAAC1C,IAAI,CAACuD,EAAE,EAAEiB,KAAK,CAAC,GAAG,IAAI,CAACtE,SAAS,CAAC,CAAC;EACrE,OAAO,IAAI;AACb,CAAC;AAEDR,IAAI,CAACW,SAAS,CAACoE,cAAc,GAAG,UAAU9D,YAAY,EAAE;EACtD,IAAI,CAAC,IAAI,CAACf,eAAe,EAAE;IACzB,OAAO,KAAK;EACd;EACA,IAAI,CAACA,eAAe,CAACiE,IAAI,CAACa,GAAG,CAAC,IAAI,CAAC1E,IAAI,CAACuD,EAAE,CAAC;EAC3C,IAAI,CAAC3D,eAAe,CAACI,IAAI,CAAC0E,GAAG,CAAC/D,YAAY,CAAC;EAC3C,OAAO,IAAI;AACb,CAAC;AAEDjB,IAAI,CAACW,SAAS,CAACsE,aAAa,GAAG,gBAAgBC,GAAG,EAAE;EAClD,MAAMzD,OAAO,GAAG,EAAE;EAClB;EACA,IAAI,CAAC,IAAI,CAACxB,MAAM,EAAE;IAChB,MAAM,IAAIH,KAAK,CAACkC,KAAK,CAAClC,KAAK,CAACmE,IAAI,CAAC,CAC9BkB,WAAW,CACV,OAAO,EACPD,GAAG,CAAC7C,GAAG,CAACwB,EAAE,IAAI;MACZ,MAAMM,IAAI,GAAG,IAAIrE,KAAK,CAACuB,MAAM,CAACvB,KAAK,CAACmE,IAAI,CAAC;MACzCE,IAAI,CAACN,EAAE,GAAGA,EAAE;MACZ,OAAOM,IAAI;IACb,CAAC,CAAC,CACH,CACAL,IAAI,CAACC,MAAM,IAAItC,OAAO,CAACuC,IAAI,CAACD,MAAM,CAACxB,MAAM,EAAE,CAAC,EAAE;MAAEH,YAAY,EAAE;IAAK,CAAC,CAAC;EAC1E,CAAC,MAAM;IACL,MAAMgD,KAAK,GAAGF,GAAG,CAAC7C,GAAG,CAACwB,EAAE,IAAI;MAC1B,OAAO;QACLF,MAAM,EAAE,SAAS;QACjBN,SAAS,EAAE,OAAO;QAClBO,QAAQ,EAAEC;MACZ,CAAC;IACH,CAAC,CAAC;IACF,MAAMJ,SAAS,GAAG;MAAE2B,KAAK,EAAE;QAAEC,GAAG,EAAED;MAAM;IAAE,CAAC;IAC3C,MAAMvD,SAAS,GAAG9B,OAAO,CAAC,aAAa,CAAC;IACxC,MAAM,IAAI8B,SAAS,CAAC,IAAI,CAAC5B,MAAM,EAAEY,MAAM,CAAC,IAAI,CAACZ,MAAM,CAAC,EAAE,OAAO,EAAEwD,SAAS,EAAE,CAAC,CAAC,CAAC,CAACK,IAAI,CAACC,MAAM,IACvFtC,OAAO,CAACuC,IAAI,CAACD,MAAM,CAAC,CACrB;EACH;EACA,OAAOtC,OAAO;AAChB,CAAC;;AAED;AACAzB,IAAI,CAACW,SAAS,CAACkE,2BAA2B,GAAG,UAAUS,OAAO,EAAEb,KAAK,GAAG,EAAE,EAAEc,YAAY,GAAG,CAAC,CAAC,EAAE;EAC7F,MAAML,GAAG,GAAGI,OAAO,CAACE,MAAM,CAACC,MAAM,IAAI;IACnC,MAAMC,UAAU,GAAGH,YAAY,CAACE,MAAM,CAAC,KAAK,IAAI;IAChDF,YAAY,CAACE,MAAM,CAAC,GAAG,IAAI;IAC3B,OAAOC,UAAU;EACnB,CAAC,CAAC;;EAEF;EACA,IAAIR,GAAG,CAAC1C,MAAM,IAAI,CAAC,EAAE;IACnB,OAAOjB,OAAO,CAACC,OAAO,CAAC,CAAC,GAAG,IAAImE,GAAG,CAAClB,KAAK,CAAC,CAAC,CAAC;EAC7C;EAEA,OAAO,IAAI,CAACQ,aAAa,CAACC,GAAG,CAAC,CAC3B/B,IAAI,CAAC1B,OAAO,IAAI;IACf;IACA,IAAI,CAACA,OAAO,CAACe,MAAM,EAAE;MACnB,OAAOjB,OAAO,CAACC,OAAO,CAACiD,KAAK,CAAC;IAC/B;IACA;IACA,MAAMmB,SAAS,GAAGnE,OAAO,CAAC6C,MAAM,CAC9B,CAACuB,IAAI,EAAE1B,IAAI,KAAK;MACd0B,IAAI,CAACpB,KAAK,CAACT,IAAI,CAACG,IAAI,CAACO,IAAI,CAAC;MAC1BmB,IAAI,CAAClB,GAAG,CAACX,IAAI,CAACG,IAAI,CAACP,QAAQ,CAAC;MAC5B,OAAOiC,IAAI;IACb,CAAC,EACD;MAAElB,GAAG,EAAE,EAAE;MAAEF,KAAK,EAAE;IAAG,CAAC,CACvB;IACD;IACAA,KAAK,GAAGA,KAAK,CAACqB,MAAM,CAACF,SAAS,CAACnB,KAAK,CAAC;IACrC;IACA,OAAO,IAAI,CAACI,2BAA2B,CAACe,SAAS,CAACjB,GAAG,EAAEF,KAAK,EAAEc,YAAY,CAAC;EAC7E,CAAC,CAAC,CACDpC,IAAI,CAACsB,KAAK,IAAI;IACb,OAAOlD,OAAO,CAACC,OAAO,CAAC,CAAC,GAAG,IAAImE,GAAG,CAAClB,KAAK,CAAC,CAAC,CAAC;EAC7C,CAAC,CAAC;AACN,CAAC;AAED,MAAMsB,qBAAqB,GAAG,CAAC9F,MAAM,EAAE+F,QAAQ,KAAK;EAClD,MAAMC,SAAS,GAAG5E,MAAM,CAAC6E,IAAI,CAACF,QAAQ,CAAC;EACvC,MAAMlE,KAAK,GAAGmE,SAAS,CACpB3B,MAAM,CAAC,CAACuB,IAAI,EAAEM,QAAQ,KAAK;IAC1B,IAAI,CAACH,QAAQ,CAACG,QAAQ,CAAC,IAAKH,QAAQ,IAAI,CAACA,QAAQ,CAACG,QAAQ,CAAC,CAACtC,EAAG,EAAE;MAC/D,OAAOgC,IAAI;IACb;IACA,MAAMO,QAAQ,GAAI,YAAWD,QAAS,KAAI;IAC1C,MAAMrE,KAAK,GAAG,CAAC,CAAC;IAChBA,KAAK,CAACsE,QAAQ,CAAC,GAAGJ,QAAQ,CAACG,QAAQ,CAAC,CAACtC,EAAE;IACvCgC,IAAI,CAAC7B,IAAI,CAAClC,KAAK,CAAC;IAChB,OAAO+D,IAAI;EACb,CAAC,EAAE,EAAE,CAAC,CACLL,MAAM,CAACa,CAAC,IAAI;IACX,OAAO,OAAOA,CAAC,KAAK,WAAW;EACjC,CAAC,CAAC;EAEJ,OAAOvE,KAAK,CAACU,MAAM,GAAG,CAAC,GACnBvC,MAAM,CAACqG,QAAQ,CAACnE,IAAI,CAAC,OAAO,EAAE;IAAEoE,GAAG,EAAEzE;EAAM,CAAC,EAAE;IAAEH,KAAK,EAAE;EAAE,CAAC,CAAC,GAC3DJ,OAAO,CAACC,OAAO,CAAC,EAAE,CAAC;AACzB,CAAC;AAED,MAAMgF,kBAAkB,GAAG,CAACR,QAAQ,EAAES,YAAY,KAAK;EACrD,IAAI,CAACA,YAAY,EAAE,OAAO;IAAED,kBAAkB,EAAE,IAAI;IAAEE,eAAe,EAAEV;EAAS,CAAC;EACjF,MAAMU,eAAe,GAAG,CAAC,CAAC;EAC1BrF,MAAM,CAAC6E,IAAI,CAACF,QAAQ,CAAC,CAACW,OAAO,CAACR,QAAQ,IAAI;IACxC;IACA,IAAIA,QAAQ,KAAK,WAAW,EAAE;IAC9B,MAAMS,YAAY,GAAGZ,QAAQ,CAACG,QAAQ,CAAC;IACvC,MAAMU,oBAAoB,GAAGJ,YAAY,CAACN,QAAQ,CAAC;IACnD,IAAI,CAAC,IAAAW,uBAAiB,EAACF,YAAY,EAAEC,oBAAoB,CAAC,EAAE;MAC1DH,eAAe,CAACP,QAAQ,CAAC,GAAGS,YAAY;IAC1C;EACF,CAAC,CAAC;EACF,MAAMJ,kBAAkB,GAAGnF,MAAM,CAAC6E,IAAI,CAACQ,eAAe,CAAC,CAAClE,MAAM,KAAK,CAAC;EACpE,OAAO;IAAEgE,kBAAkB;IAAEE;EAAgB,CAAC;AAChD,CAAC;AAED,MAAMK,iDAAiD,GAAG,CACxDf,QAAQ,GAAG,CAAC,CAAC,EACbS,YAAY,GAAG,CAAC,CAAC,EACjBxG,MAAM,KACH;EACH,MAAM+G,kBAAkB,GAAG3F,MAAM,CAAC6E,IAAI,CAACO,YAAY,CAAC,CAACpE,GAAG,CAAC8D,QAAQ,KAAK;IACpEzB,IAAI,EAAEyB,QAAQ;IACdc,OAAO,EAAEhH,MAAM,CAACiH,eAAe,CAACC,uBAAuB,CAAChB,QAAQ,CAAC,CAACc;EACpE,CAAC,CAAC,CAAC;EAEH,MAAMG,wBAAwB,GAAGJ,kBAAkB,CAACK,IAAI,CACtDlB,QAAQ,IACNA,QAAQ,IAAIA,QAAQ,CAACc,OAAO,IAAId,QAAQ,CAACc,OAAO,CAACK,MAAM,KAAK,MAAM,IAAItB,QAAQ,CAACG,QAAQ,CAACzB,IAAI,CAAC,CAChG;;EAED;EACA;EACA;EACA,IAAI0C,wBAAwB,EAAE;IAC5B;EACF;EAEA,MAAMG,yBAAyB,GAAG,EAAE;EACpC,MAAMC,uCAAuC,GAAGR,kBAAkB,CAACK,IAAI,CAAClB,QAAQ,IAAI;IAClF,IAAIA,QAAQ,IAAIA,QAAQ,CAACc,OAAO,IAAId,QAAQ,CAACc,OAAO,CAACK,MAAM,KAAK,YAAY,EAAE;MAC5E,IAAItB,QAAQ,CAACG,QAAQ,CAACzB,IAAI,CAAC,EAAE;QAC3B,OAAO,IAAI;MACb,CAAC,MAAM;QACL;QACA6C,yBAAyB,CAACvD,IAAI,CAACmC,QAAQ,CAACzB,IAAI,CAAC;MAC/C;IACF;EACF,CAAC,CAAC;EACF,IAAI8C,uCAAuC,IAAI,CAACD,yBAAyB,CAAC/E,MAAM,EAAE;IAChF;EACF;EAEA,MAAM,IAAI1C,KAAK,CAAC2C,KAAK,CACnB3C,KAAK,CAAC2C,KAAK,CAACgF,WAAW,EACtB,+BAA8BF,yBAAyB,CAACG,IAAI,CAAC,GAAG,CAAE,EAAC,CACrE;AACH,CAAC;;AAED;AACA,MAAMC,wBAAwB,GAAG,OAAO3B,QAAQ,EAAE4B,GAAG,EAAEC,SAAS,KAAK;EACnE,IAAIvH,IAAI;EACR,IAAIuH,SAAS,EAAE;IACbvH,IAAI,GAAGR,KAAK,CAACgI,IAAI,CAACxG,QAAQ;MAAG+B,SAAS,EAAE;IAAO,GAAKwE,SAAS,EAAG;IAChE;EACF,CAAC,MAAM,IACJD,GAAG,CAACG,IAAI,IACPH,GAAG,CAACG,IAAI,CAACzH,IAAI,IACb,OAAOsH,GAAG,CAACI,SAAS,KAAK,UAAU,IACnCJ,GAAG,CAACI,SAAS,EAAE,KAAKJ,GAAG,CAACG,IAAI,CAACzH,IAAI,CAACuD,EAAE,IACrC+D,GAAG,CAACG,IAAI,IAAIH,GAAG,CAACG,IAAI,CAAC3H,QAAQ,IAAI,OAAOwH,GAAG,CAACI,SAAS,KAAK,UAAU,IAAIJ,GAAG,CAACI,SAAS,EAAG,EACzF;IACA1H,IAAI,GAAG,IAAIR,KAAK,CAACgI,IAAI,EAAE;IACvBxH,IAAI,CAACuD,EAAE,GAAG+D,GAAG,CAACG,IAAI,CAAC3H,QAAQ,GAAGwH,GAAG,CAACI,SAAS,EAAE,GAAGJ,GAAG,CAACG,IAAI,CAACzH,IAAI,CAACuD,EAAE;IAChE,MAAMvD,IAAI,CAAC2H,KAAK,CAAC;MAAE7F,YAAY,EAAE;IAAK,CAAC,CAAC;EAC1C;EAEA,MAAM;IAAE8F,cAAc;IAAEC;EAAc,CAAC,GAAGP,GAAG,CAACQ,iBAAiB,EAAE;EACjE,MAAMC,aAAa,GAAG,IAAAC,0BAAgB,EACpCnI,SAAS,EACTyH,GAAG,CAACG,IAAI,EACRI,aAAa,EACbD,cAAc,IAAI5H,IAAI,EACtBsH,GAAG,CAAC3H,MAAM,CACX;EACD;EACA;EACA,MAAMsI,GAAG,GAAG;IAAEvC,QAAQ,EAAE,CAAC,CAAC;IAAEwC,gBAAgB,EAAE,CAAC;EAAE,CAAC;EAClD,MAAMC,QAAQ,GAAGpH,MAAM,CAAC6E,IAAI,CAACF,QAAQ,CAAC,CAAC0C,IAAI,EAAE;EAC7C,KAAK,MAAMvC,QAAQ,IAAIsC,QAAQ,EAAE;IAC/B,IAAIE,MAAM,GAAG,EAAE;IACf,IAAI;MACF,IAAI3C,QAAQ,CAACG,QAAQ,CAAC,KAAK,IAAI,EAAE;QAC/BoC,GAAG,CAACvC,QAAQ,CAACG,QAAQ,CAAC,GAAG,IAAI;QAC7B;MACF;MACA,MAAM;QAAEyC;MAAU,CAAC,GAAGhB,GAAG,CAAC3H,MAAM,CAACiH,eAAe,CAACC,uBAAuB,CAAChB,QAAQ,CAAC;MAClF,MAAM0C,YAAY,GAAG,CAACjB,GAAG,CAAC3H,MAAM,CAAC8H,IAAI,IAAI,CAAC,CAAC,EAAE5B,QAAQ,CAAC,IAAI,CAAC,CAAC;MAC5D,IAAI0C,YAAY,CAACC,OAAO,IAAI,IAAI,EAAE;QAChCC,mBAAU,CAACC,qBAAqB,CAAC;UAC/BC,KAAK,EAAG,qCAAoC9C,QAAS,kCAAiC;UACtF+C,QAAQ,EAAG,8EAA6E/C,QAAS;QACnG,CAAC,CAAC;MACJ;MACA,IAAI,CAACyC,SAAS,IAAIC,YAAY,CAACC,OAAO,KAAK,KAAK,EAAE;QAChD,MAAM,IAAIhJ,KAAK,CAAC2C,KAAK,CACnB3C,KAAK,CAAC2C,KAAK,CAAC0G,mBAAmB,EAC/B,4CAA4C,CAC7C;MACH;MACA,IAAIC,gBAAgB,GAAG,MAAMR,SAAS,CAAC5C,QAAQ,CAACG,QAAQ,CAAC,EAAEyB,GAAG,EAAEtH,IAAI,EAAE+H,aAAa,CAAC;MACpFM,MAAM,GAAGS,gBAAgB,IAAIA,gBAAgB,CAACT,MAAM;MACpDN,aAAa,CAACgB,WAAW,GAAGV,MAAM;MAClC,IAAIS,gBAAgB,IAAIA,gBAAgB,CAACR,SAAS,EAAE;QAClDQ,gBAAgB,GAAG,MAAMA,gBAAgB,CAACR,SAAS,EAAE;MACvD;MACA,IAAI,CAACQ,gBAAgB,EAAE;QACrBb,GAAG,CAACvC,QAAQ,CAACG,QAAQ,CAAC,GAAGH,QAAQ,CAACG,QAAQ,CAAC;QAC3C;MACF;MACA,IAAI,CAAC9E,MAAM,CAAC6E,IAAI,CAACkD,gBAAgB,CAAC,CAAC5G,MAAM,EAAE;QACzC+F,GAAG,CAACvC,QAAQ,CAACG,QAAQ,CAAC,GAAGH,QAAQ,CAACG,QAAQ,CAAC;QAC3C;MACF;MAEA,IAAIiD,gBAAgB,CAAChG,QAAQ,EAAE;QAC7BmF,GAAG,CAACC,gBAAgB,CAACrC,QAAQ,CAAC,GAAGiD,gBAAgB,CAAChG,QAAQ;MAC5D;MACA;MACA,IAAI,CAACgG,gBAAgB,CAACE,SAAS,EAAE;QAC/Bf,GAAG,CAACvC,QAAQ,CAACG,QAAQ,CAAC,GAAGiD,gBAAgB,CAACG,IAAI,IAAIvD,QAAQ,CAACG,QAAQ,CAAC;MACtE;IACF,CAAC,CAAC,OAAOqD,GAAG,EAAE;MACZ,MAAMC,CAAC,GAAG,IAAAC,sBAAY,EAACF,GAAG,EAAE;QAC1BG,IAAI,EAAE7J,KAAK,CAAC2C,KAAK,CAACmH,aAAa;QAC/BC,OAAO,EAAE;MACX,CAAC,CAAC;MACF,MAAMC,UAAU,GACdlC,GAAG,CAACG,IAAI,IAAIH,GAAG,CAACG,IAAI,CAACzH,IAAI,GAAGsH,GAAG,CAACG,IAAI,CAACzH,IAAI,CAACuD,EAAE,GAAG+D,GAAG,CAACmC,IAAI,CAACnG,QAAQ,IAAIzD,SAAS;MAC/E6J,cAAM,CAACC,KAAK,CACT,4BAA2BtB,MAAO,QAAOxC,QAAS,aAAY2D,UAAW,eAAc,GACtFI,IAAI,CAACC,SAAS,CAACV,CAAC,CAAC,EACnB;QACEW,kBAAkB,EAAEzB,MAAM;QAC1BsB,KAAK,EAAER,CAAC;QACRnJ,IAAI,EAAEwJ,UAAU;QAChB3D;MACF,CAAC,CACF;MACD,MAAMsD,CAAC;IACT;EACF;EACA,OAAOlB,GAAG;AACZ,CAAC;AAED8B,MAAM,CAACC,OAAO,GAAG;EACftK,IAAI;EACJa,MAAM;EACNE,MAAM;EACND,QAAQ;EACRE,sBAAsB;EACtBkC,4BAA4B;EAC5B6C,qBAAqB;EACrBS,kBAAkB;EAClBO,iDAAiD;EACjDY;AACF,CAAC"}