parse-server 6.0.0-alpha.3 → 6.0.0-alpha.31

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 (192) hide show
  1. package/LICENSE +167 -25
  2. package/NOTICE +10 -0
  3. package/README.md +58 -34
  4. package/lib/AccountLockout.js +11 -26
  5. package/lib/Adapters/AdapterLoader.js +8 -14
  6. package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
  7. package/lib/Adapters/Auth/AuthAdapter.js +7 -16
  8. package/lib/Adapters/Auth/OAuth1Client.js +32 -57
  9. package/lib/Adapters/Auth/apple.js +6 -22
  10. package/lib/Adapters/Auth/facebook.js +7 -37
  11. package/lib/Adapters/Auth/gcenter.js +8 -37
  12. package/lib/Adapters/Auth/github.js +7 -10
  13. package/lib/Adapters/Auth/google.js +11 -34
  14. package/lib/Adapters/Auth/gpgames.js +5 -8
  15. package/lib/Adapters/Auth/httpsRequest.js +1 -7
  16. package/lib/Adapters/Auth/index.js +20 -65
  17. package/lib/Adapters/Auth/instagram.js +5 -9
  18. package/lib/Adapters/Auth/janraincapture.js +8 -12
  19. package/lib/Adapters/Auth/janrainengage.js +7 -11
  20. package/lib/Adapters/Auth/keycloak.js +5 -19
  21. package/lib/Adapters/Auth/ldap.js +1 -15
  22. package/lib/Adapters/Auth/line.js +7 -10
  23. package/lib/Adapters/Auth/linkedin.js +7 -12
  24. package/lib/Adapters/Auth/meetup.js +7 -10
  25. package/lib/Adapters/Auth/microsoft.js +7 -10
  26. package/lib/Adapters/Auth/oauth2.js +6 -18
  27. package/lib/Adapters/Auth/phantauth.js +8 -10
  28. package/lib/Adapters/Auth/qq.js +7 -13
  29. package/lib/Adapters/Auth/spotify.js +7 -14
  30. package/lib/Adapters/Auth/twitter.js +5 -15
  31. package/lib/Adapters/Auth/vkontakte.js +9 -15
  32. package/lib/Adapters/Auth/wechat.js +7 -10
  33. package/lib/Adapters/Auth/weibo.js +7 -11
  34. package/lib/Adapters/Cache/CacheAdapter.js +4 -12
  35. package/lib/Adapters/Cache/InMemoryCache.js +5 -19
  36. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
  37. package/lib/Adapters/Cache/LRUCache.js +1 -11
  38. package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
  39. package/lib/Adapters/Cache/RedisCacheAdapter.js +46 -87
  40. package/lib/Adapters/Cache/SchemaCache.js +1 -6
  41. package/lib/Adapters/Email/MailAdapter.js +2 -7
  42. package/lib/Adapters/Files/FilesAdapter.js +7 -21
  43. package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
  44. package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
  45. package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
  46. package/lib/Adapters/Logger/WinstonLogger.js +3 -30
  47. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
  48. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
  49. package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
  50. package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
  51. package/lib/Adapters/PubSub/RedisPubSub.js +13 -10
  52. package/lib/Adapters/Push/PushAdapter.js +2 -8
  53. package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
  54. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
  55. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
  56. package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
  57. package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
  58. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
  59. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
  60. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
  61. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  62. package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
  63. package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
  64. package/lib/Auth.js +68 -121
  65. package/lib/ClientSDK.js +3 -11
  66. package/lib/Config.js +77 -115
  67. package/lib/Controllers/AdaptableController.js +6 -18
  68. package/lib/Controllers/AnalyticsController.js +1 -9
  69. package/lib/Controllers/CacheController.js +3 -23
  70. package/lib/Controllers/DatabaseController.js +171 -364
  71. package/lib/Controllers/FilesController.js +5 -34
  72. package/lib/Controllers/HooksController.js +1 -51
  73. package/lib/Controllers/LiveQueryController.js +4 -23
  74. package/lib/Controllers/LoggerController.js +15 -54
  75. package/lib/Controllers/ParseGraphQLController.js +49 -104
  76. package/lib/Controllers/PushController.js +20 -59
  77. package/lib/Controllers/SchemaController.js +162 -348
  78. package/lib/Controllers/UserController.js +17 -78
  79. package/lib/Controllers/index.js +19 -68
  80. package/lib/Controllers/types.js +1 -1
  81. package/lib/Deprecator/Deprecations.js +1 -8
  82. package/lib/Deprecator/Deprecator.js +9 -18
  83. package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
  84. package/lib/GraphQL/ParseGraphQLServer.js +2 -29
  85. package/lib/GraphQL/helpers/objectsMutations.js +2 -12
  86. package/lib/GraphQL/helpers/objectsQueries.js +18 -76
  87. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
  88. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
  89. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
  90. package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
  91. package/lib/GraphQL/loaders/filesMutations.js +2 -19
  92. package/lib/GraphQL/loaders/functionsMutations.js +6 -17
  93. package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
  94. package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
  95. package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
  96. package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
  97. package/lib/GraphQL/loaders/schemaMutations.js +1 -20
  98. package/lib/GraphQL/loaders/schemaQueries.js +1 -14
  99. package/lib/GraphQL/loaders/schemaTypes.js +2 -6
  100. package/lib/GraphQL/loaders/usersMutations.js +6 -28
  101. package/lib/GraphQL/loaders/usersQueries.js +4 -26
  102. package/lib/GraphQL/parseGraphQLUtils.js +6 -19
  103. package/lib/GraphQL/transformers/className.js +1 -4
  104. package/lib/GraphQL/transformers/constraintType.js +1 -20
  105. package/lib/GraphQL/transformers/inputType.js +1 -20
  106. package/lib/GraphQL/transformers/mutation.js +6 -51
  107. package/lib/GraphQL/transformers/outputType.js +1 -20
  108. package/lib/GraphQL/transformers/query.js +6 -42
  109. package/lib/GraphQL/transformers/schemaFields.js +7 -34
  110. package/lib/KeyPromiseQueue.js +1 -12
  111. package/lib/LiveQuery/Client.js +1 -25
  112. package/lib/LiveQuery/Id.js +1 -7
  113. package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
  114. package/lib/LiveQuery/ParseLiveQueryServer.js +111 -307
  115. package/lib/LiveQuery/ParsePubSub.js +1 -12
  116. package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
  117. package/lib/LiveQuery/QueryTools.js +14 -116
  118. package/lib/LiveQuery/RequestSchema.js +1 -1
  119. package/lib/LiveQuery/SessionTokenCache.js +1 -17
  120. package/lib/LiveQuery/Subscription.js +4 -18
  121. package/lib/LiveQuery/equalObjects.js +2 -14
  122. package/lib/Options/Definitions.js +90 -10
  123. package/lib/Options/docs.js +25 -3
  124. package/lib/Options/index.js +4 -12
  125. package/lib/Options/parsers.js +1 -18
  126. package/lib/Page.js +1 -9
  127. package/lib/ParseMessageQueue.js +1 -10
  128. package/lib/ParseServer.js +178 -202
  129. package/lib/ParseServerRESTController.js +6 -33
  130. package/lib/PromiseRouter.js +16 -50
  131. package/lib/Push/PushQueue.js +3 -15
  132. package/lib/Push/PushWorker.js +7 -32
  133. package/lib/Push/utils.js +9 -38
  134. package/lib/RestQuery.js +105 -242
  135. package/lib/RestWrite.js +224 -389
  136. package/lib/Routers/AggregateRouter.js +14 -51
  137. package/lib/Routers/AnalyticsRouter.js +2 -8
  138. package/lib/Routers/AudiencesRouter.js +1 -15
  139. package/lib/Routers/ClassesRouter.js +3 -53
  140. package/lib/Routers/CloudCodeRouter.js +1 -19
  141. package/lib/Routers/FeaturesRouter.js +1 -10
  142. package/lib/Routers/FilesRouter.js +29 -76
  143. package/lib/Routers/FunctionsRouter.js +5 -28
  144. package/lib/Routers/GlobalConfigRouter.js +4 -18
  145. package/lib/Routers/GraphQLRouter.js +1 -14
  146. package/lib/Routers/HooksRouter.js +1 -29
  147. package/lib/Routers/IAPValidationRouter.js +6 -29
  148. package/lib/Routers/InstallationsRouter.js +2 -12
  149. package/lib/Routers/LogsRouter.js +4 -16
  150. package/lib/Routers/PagesRouter.js +69 -129
  151. package/lib/Routers/PublicAPIRouter.js +3 -62
  152. package/lib/Routers/PurgeRouter.js +1 -15
  153. package/lib/Routers/PushRouter.js +2 -18
  154. package/lib/Routers/RolesRouter.js +1 -7
  155. package/lib/Routers/SchemasRouter.js +4 -34
  156. package/lib/Routers/SecurityRouter.js +1 -12
  157. package/lib/Routers/SessionsRouter.js +3 -19
  158. package/lib/Routers/UsersRouter.js +59 -156
  159. package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
  160. package/lib/SchemaMigrations/Migrations.js +2 -8
  161. package/lib/Security/Check.js +8 -16
  162. package/lib/Security/CheckGroup.js +4 -11
  163. package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
  164. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
  165. package/lib/Security/CheckGroups/CheckGroups.js +1 -4
  166. package/lib/Security/CheckRunner.js +22 -41
  167. package/lib/StatusHandler.js +12 -69
  168. package/lib/TestUtils.js +1 -6
  169. package/lib/Utils.js +27 -66
  170. package/lib/batch.js +17 -28
  171. package/lib/cache.js +1 -3
  172. package/lib/cli/definitions/parse-live-query-server.js +1 -3
  173. package/lib/cli/definitions/parse-server.js +1 -3
  174. package/lib/cli/parse-live-query-server.js +1 -6
  175. package/lib/cli/parse-server.js +11 -21
  176. package/lib/cli/utils/commander.js +13 -51
  177. package/lib/cli/utils/runner.js +1 -14
  178. package/lib/cloud-code/Parse.Cloud.js +71 -81
  179. package/lib/cryptoUtils.js +11 -19
  180. package/lib/defaults.js +2 -14
  181. package/lib/deprecated.js +1 -2
  182. package/lib/index.js +16 -34
  183. package/lib/logger.js +6 -13
  184. package/lib/middlewares.js +170 -151
  185. package/lib/password.js +6 -10
  186. package/lib/request.js +8 -42
  187. package/lib/requiredParameter.js +1 -3
  188. package/lib/rest.js +25 -47
  189. package/lib/triggers.js +54 -252
  190. package/lib/vendor/mongodbUrl.js +129 -310
  191. package/package.json +25 -22
  192. package/PATENTS +0 -37
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.
@@ -25,6 +18,7 @@ function Auth({
25
18
  config,
26
19
  cacheController = undefined,
27
20
  isMaster = false,
21
+ isMaintenance = false,
28
22
  isReadOnly = false,
29
23
  user,
30
24
  installationId
@@ -33,55 +27,66 @@ function Auth({
33
27
  this.cacheController = cacheController || config && config.cacheController;
34
28
  this.installationId = installationId;
35
29
  this.isMaster = isMaster;
30
+ this.isMaintenance = isMaintenance;
36
31
  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.
32
+ this.isReadOnly = isReadOnly;
39
33
 
34
+ // Assuming a users roles won't change during a single request, we'll
35
+ // only load them once.
40
36
  this.userRoles = [];
41
37
  this.fetchedRoles = false;
42
38
  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
-
39
+ }
46
40
 
41
+ // Whether this auth could possibly modify the given user id.
42
+ // It still could be forbidden via ACLs even if this returns true.
47
43
  Auth.prototype.isUnauthenticated = function () {
48
44
  if (this.isMaster) {
49
45
  return false;
50
46
  }
51
-
47
+ if (this.isMaintenance) {
48
+ return false;
49
+ }
52
50
  if (this.user) {
53
51
  return false;
54
52
  }
55
-
56
53
  return true;
57
- }; // A helper to get a master-level Auth object
58
-
54
+ };
59
55
 
56
+ // A helper to get a master-level Auth object
60
57
  function master(config) {
61
58
  return new Auth({
62
59
  config,
63
60
  isMaster: true
64
61
  });
65
- } // A helper to get a master-level Auth object
62
+ }
66
63
 
64
+ // A helper to get a maintenance-level Auth object
65
+ function maintenance(config) {
66
+ return new Auth({
67
+ config,
68
+ isMaintenance: true
69
+ });
70
+ }
67
71
 
72
+ // A helper to get a master-level Auth object
68
73
  function readOnly(config) {
69
74
  return new Auth({
70
75
  config,
71
76
  isMaster: true,
72
77
  isReadOnly: true
73
78
  });
74
- } // A helper to get a nobody-level Auth object
75
-
79
+ }
76
80
 
81
+ // A helper to get a nobody-level Auth object
77
82
  function nobody(config) {
78
83
  return new Auth({
79
84
  config,
80
85
  isMaster: false
81
86
  });
82
- } // Returns a promise that resolves to an Auth object
83
-
87
+ }
84
88
 
89
+ // Returns a promise that resolves to an Auth object
85
90
  const getAuthForSessionToken = async function ({
86
91
  config,
87
92
  cacheController,
@@ -89,10 +94,8 @@ const getAuthForSessionToken = async function ({
89
94
  installationId
90
95
  }) {
91
96
  cacheController = cacheController || config && config.cacheController;
92
-
93
97
  if (cacheController) {
94
98
  const userJSON = await cacheController.user.get(sessionToken);
95
-
96
99
  if (userJSON) {
97
100
  const cachedUser = Parse.Object.fromJSON(userJSON);
98
101
  return Promise.resolve(new Auth({
@@ -104,17 +107,13 @@ const getAuthForSessionToken = async function ({
104
107
  }));
105
108
  }
106
109
  }
107
-
108
110
  let results;
109
-
110
111
  if (config) {
111
112
  const restOptions = {
112
113
  limit: 1,
113
114
  include: 'user'
114
115
  };
115
-
116
116
  const RestQuery = require('./RestQuery');
117
-
118
117
  const query = new RestQuery(config, master(config), '_Session', {
119
118
  sessionToken
120
119
  }, restOptions);
@@ -124,27 +123,21 @@ const getAuthForSessionToken = async function ({
124
123
  useMasterKey: true
125
124
  })).map(obj => obj.toJSON());
126
125
  }
127
-
128
126
  if (results.length !== 1 || !results[0]['user']) {
129
127
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
130
128
  }
131
-
132
129
  const now = new Date(),
133
- expiresAt = results[0].expiresAt ? new Date(results[0].expiresAt.iso) : undefined;
134
-
130
+ expiresAt = results[0].expiresAt ? new Date(results[0].expiresAt.iso) : undefined;
135
131
  if (expiresAt < now) {
136
132
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');
137
133
  }
138
-
139
134
  const obj = results[0]['user'];
140
135
  delete obj.password;
141
136
  obj['className'] = '_User';
142
137
  obj['sessionToken'] = sessionToken;
143
-
144
138
  if (cacheController) {
145
139
  cacheController.user.put(sessionToken, obj);
146
140
  }
147
-
148
141
  const userObject = Parse.Object.fromJSON(obj);
149
142
  return new Auth({
150
143
  config,
@@ -154,7 +147,6 @@ const getAuthForSessionToken = async function ({
154
147
  user: userObject
155
148
  });
156
149
  };
157
-
158
150
  var getAuthForLegacySessionToken = function ({
159
151
  config,
160
152
  sessionToken,
@@ -163,19 +155,15 @@ var getAuthForLegacySessionToken = function ({
163
155
  var restOptions = {
164
156
  limit: 1
165
157
  };
166
-
167
158
  const RestQuery = require('./RestQuery');
168
-
169
159
  var query = new RestQuery(config, master(config), '_User', {
170
160
  sessionToken
171
161
  }, restOptions);
172
162
  return query.execute().then(response => {
173
163
  var results = response.results;
174
-
175
164
  if (results.length !== 1) {
176
165
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');
177
166
  }
178
-
179
167
  const obj = results[0];
180
168
  obj.className = '_User';
181
169
  const userObject = Parse.Object.fromJSON(obj);
@@ -186,30 +174,25 @@ var getAuthForLegacySessionToken = function ({
186
174
  user: userObject
187
175
  });
188
176
  });
189
- }; // Returns a promise that resolves to an array of role names
190
-
177
+ };
191
178
 
179
+ // Returns a promise that resolves to an array of role names
192
180
  Auth.prototype.getUserRoles = function () {
193
- if (this.isMaster || !this.user) {
181
+ if (this.isMaster || this.isMaintenance || !this.user) {
194
182
  return Promise.resolve([]);
195
183
  }
196
-
197
184
  if (this.fetchedRoles) {
198
185
  return Promise.resolve(this.userRoles);
199
186
  }
200
-
201
187
  if (this.rolePromise) {
202
188
  return this.rolePromise;
203
189
  }
204
-
205
190
  this.rolePromise = this._loadRoles();
206
191
  return this.rolePromise;
207
192
  };
208
-
209
193
  Auth.prototype.getRolesForUser = async function () {
210
194
  //Stack all Parse.Role
211
195
  const results = [];
212
-
213
196
  if (this.config) {
214
197
  const restWhere = {
215
198
  users: {
@@ -218,34 +201,29 @@ Auth.prototype.getRolesForUser = async function () {
218
201
  objectId: this.user.id
219
202
  }
220
203
  };
221
-
222
204
  const RestQuery = require('./RestQuery');
223
-
224
205
  await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result => results.push(result));
225
206
  } else {
226
207
  await new Parse.Query(Parse.Role).equalTo('users', this.user).each(result => results.push(result.toJSON()), {
227
208
  useMasterKey: true
228
209
  });
229
210
  }
230
-
231
211
  return results;
232
- }; // Iterates through the role tree and compiles a user's roles
233
-
212
+ };
234
213
 
214
+ // Iterates through the role tree and compiles a user's roles
235
215
  Auth.prototype._loadRoles = async function () {
236
216
  if (this.cacheController) {
237
217
  const cachedRoles = await this.cacheController.role.get(this.user.id);
238
-
239
218
  if (cachedRoles != null) {
240
219
  this.fetchedRoles = true;
241
220
  this.userRoles = cachedRoles;
242
221
  return cachedRoles;
243
222
  }
244
- } // First get the role ids this user is directly a member of
245
-
223
+ }
246
224
 
225
+ // First get the role ids this user is directly a member of
247
226
  const results = await this.getRolesForUser();
248
-
249
227
  if (!results.length) {
250
228
  this.userRoles = [];
251
229
  this.fetchedRoles = true;
@@ -253,7 +231,6 @@ Auth.prototype._loadRoles = async function () {
253
231
  this.cacheRoles();
254
232
  return this.userRoles;
255
233
  }
256
-
257
234
  const rolesMap = results.reduce((m, r) => {
258
235
  m.names.push(r.name);
259
236
  m.ids.push(r.objectId);
@@ -261,8 +238,9 @@ Auth.prototype._loadRoles = async function () {
261
238
  }, {
262
239
  ids: [],
263
240
  names: []
264
- }); // run the recursive finding
241
+ });
265
242
 
243
+ // run the recursive finding
266
244
  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);
267
245
  this.userRoles = roleNames.map(r => {
268
246
  return 'role:' + r;
@@ -272,29 +250,24 @@ Auth.prototype._loadRoles = async function () {
272
250
  this.cacheRoles();
273
251
  return this.userRoles;
274
252
  };
275
-
276
253
  Auth.prototype.cacheRoles = function () {
277
254
  if (!this.cacheController) {
278
255
  return false;
279
256
  }
280
-
281
257
  this.cacheController.role.put(this.user.id, Array(...this.userRoles));
282
258
  return true;
283
259
  };
284
-
285
260
  Auth.prototype.clearRoleCache = function (sessionToken) {
286
261
  if (!this.cacheController) {
287
262
  return false;
288
263
  }
289
-
290
264
  this.cacheController.role.del(this.user.id);
291
265
  this.cacheController.user.del(sessionToken);
292
266
  return true;
293
267
  };
294
-
295
268
  Auth.prototype.getRolesByIds = async function (ins) {
296
- const results = []; // Build an OR query across all parentRoles
297
-
269
+ const results = [];
270
+ // Build an OR query across all parentRoles
298
271
  if (!this.config) {
299
272
  await new Parse.Query(Parse.Role).containedIn('roles', ins.map(id => {
300
273
  const role = new Parse.Object(Parse.Role);
@@ -316,34 +289,30 @@ Auth.prototype.getRolesByIds = async function (ins) {
316
289
  $in: roles
317
290
  }
318
291
  };
319
-
320
292
  const RestQuery = require('./RestQuery');
321
-
322
293
  await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result => results.push(result));
323
294
  }
324
-
325
295
  return results;
326
- }; // Given a list of roleIds, find all the parent roles, returns a promise with all names
327
-
296
+ };
328
297
 
298
+ // Given a list of roleIds, find all the parent roles, returns a promise with all names
329
299
  Auth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {
330
300
  const ins = roleIDs.filter(roleID => {
331
301
  const wasQueried = queriedRoles[roleID] !== true;
332
302
  queriedRoles[roleID] = true;
333
303
  return wasQueried;
334
- }); // all roles are accounted for, return the names
304
+ });
335
305
 
306
+ // all roles are accounted for, return the names
336
307
  if (ins.length == 0) {
337
308
  return Promise.resolve([...new Set(names)]);
338
309
  }
339
-
340
310
  return this.getRolesByIds(ins).then(results => {
341
311
  // Nothing found
342
312
  if (!results.length) {
343
313
  return Promise.resolve(names);
344
- } // Map the results with all Ids and names
345
-
346
-
314
+ }
315
+ // Map the results with all Ids and names
347
316
  const resultMap = results.reduce((memo, role) => {
348
317
  memo.names.push(role.name);
349
318
  memo.ids.push(role.objectId);
@@ -351,23 +320,21 @@ Auth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], quer
351
320
  }, {
352
321
  ids: [],
353
322
  names: []
354
- }); // store the new found names
355
-
356
- names = names.concat(resultMap.names); // find the next ones, circular roles will be cut
357
-
323
+ });
324
+ // store the new found names
325
+ names = names.concat(resultMap.names);
326
+ // find the next ones, circular roles will be cut
358
327
  return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);
359
328
  }).then(names => {
360
329
  return Promise.resolve([...new Set(names)]);
361
330
  });
362
331
  };
363
-
364
332
  const findUsersWithAuthData = (config, authData) => {
365
333
  const providers = Object.keys(authData);
366
334
  const query = providers.reduce((memo, provider) => {
367
335
  if (!authData[provider] || authData && !authData[provider].id) {
368
336
  return memo;
369
337
  }
370
-
371
338
  const queryKey = `authData.${provider}.id`;
372
339
  const query = {};
373
340
  query[queryKey] = authData[provider].id;
@@ -382,7 +349,6 @@ const findUsersWithAuthData = (config, authData) => {
382
349
  limit: 2
383
350
  }) : Promise.resolve([]);
384
351
  };
385
-
386
352
  const hasMutatedAuthData = (authData, userAuthData) => {
387
353
  if (!userAuthData) return {
388
354
  hasMutatedAuthData: true,
@@ -394,7 +360,6 @@ const hasMutatedAuthData = (authData, userAuthData) => {
394
360
  if (provider === 'anonymous') return;
395
361
  const providerData = authData[provider];
396
362
  const userProviderAuthData = userAuthData[provider];
397
-
398
363
  if (!(0, _util.isDeepStrictEqual)(providerData, userProviderAuthData)) {
399
364
  mutatedAuthData[provider] = providerData;
400
365
  }
@@ -405,20 +370,19 @@ const hasMutatedAuthData = (authData, userAuthData) => {
405
370
  mutatedAuthData
406
371
  };
407
372
  };
408
-
409
373
  const checkIfUserHasProvidedConfiguredProvidersForLogin = (authData = {}, userAuthData = {}, config) => {
410
374
  const savedUserProviders = Object.keys(userAuthData).map(provider => ({
411
375
  name: provider,
412
376
  adapter: config.authDataManager.getValidatorForProvider(provider).adapter
413
377
  }));
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
378
+ const hasProvidedASoloProvider = savedUserProviders.some(provider => provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]);
379
+
380
+ // Solo providers can be considered as safe, so we do not have to check if the user needs
415
381
  // to provide an additional provider to login. An auth adapter with "solo" (like webauthn) means
416
382
  // no "additional" auth needs to be provided to login (like OTP, MFA)
417
-
418
383
  if (hasProvidedASoloProvider) {
419
384
  return;
420
385
  }
421
-
422
386
  const additionProvidersNotFound = [];
423
387
  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {
424
388
  if (provider && provider.adapter && provider.adapter.policy === 'additional') {
@@ -430,22 +394,20 @@ const checkIfUserHasProvidedConfiguredProvidersForLogin = (authData = {}, userAu
430
394
  }
431
395
  }
432
396
  });
433
-
434
397
  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {
435
398
  return;
436
399
  }
437
-
438
400
  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
-
401
+ };
441
402
 
403
+ // Validate each authData step-by-step and return the provider responses
442
404
  const handleAuthDataValidation = async (authData, req, foundUser) => {
443
405
  let user;
444
-
445
406
  if (foundUser) {
446
407
  user = Parse.User.fromJSON(_objectSpread({
447
408
  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
409
+ }, foundUser));
410
+ // Find user by session and current objectId; only pass user if it's the current user or master key is provided
449
411
  } 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
412
  user = new Parse.User();
451
413
  user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;
@@ -453,68 +415,56 @@ const handleAuthDataValidation = async (authData, req, foundUser) => {
453
415
  useMasterKey: true
454
416
  });
455
417
  }
456
-
457
418
  const {
458
419
  originalObject,
459
420
  updatedObject
460
421
  } = 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
422
+ const requestObject = (0, _triggers.getRequestObject)(undefined, req.auth, updatedObject, originalObject || user, req.config);
423
+ // Perform validation as step-by-step pipeline for better error consistency
462
424
  // and also to avoid to trigger a provider (like OTP SMS) if another one fails
463
-
464
425
  const acc = {
465
426
  authData: {},
466
427
  authDataResponse: {}
467
428
  };
468
429
  const authKeys = Object.keys(authData).sort();
469
-
470
430
  for (const provider of authKeys) {
471
431
  let method = '';
472
-
473
432
  try {
474
433
  if (authData[provider] === null) {
475
434
  acc.authData[provider] = null;
476
435
  continue;
477
436
  }
478
-
479
437
  const {
480
438
  validator
481
439
  } = req.config.authDataManager.getValidatorForProvider(provider);
482
440
  const authProvider = (req.config.auth || {})[provider] || {};
483
-
484
441
  if (authProvider.enabled == null) {
485
442
  _Deprecator.default.logRuntimeDeprecation({
486
- usage: `auth.${provider}`,
487
- solution: `auth.${provider}.enabled: true`
443
+ usage: `Using the authentication adapter "${provider}" without explicitly enabling it`,
444
+ solution: `Enable the authentication adapter by setting the Parse Server option "auth.${provider}.enabled: true".`
488
445
  });
489
446
  }
490
-
491
447
  if (!validator || authProvider.enabled === false) {
492
448
  throw new Parse.Error(Parse.Error.UNSUPPORTED_SERVICE, 'This authentication method is unsupported.');
493
449
  }
494
-
495
450
  let validationResult = await validator(authData[provider], req, user, requestObject);
496
451
  method = validationResult && validationResult.method;
497
452
  requestObject.triggerName = method;
498
-
499
453
  if (validationResult && validationResult.validator) {
500
454
  validationResult = await validationResult.validator();
501
455
  }
502
-
503
456
  if (!validationResult) {
504
457
  acc.authData[provider] = authData[provider];
505
458
  continue;
506
459
  }
507
-
508
460
  if (!Object.keys(validationResult).length) {
509
461
  acc.authData[provider] = authData[provider];
510
462
  continue;
511
463
  }
512
-
513
464
  if (validationResult.response) {
514
465
  acc.authDataResponse[provider] = validationResult.response;
515
- } // Some auth providers after initialization will avoid to replace authData already stored
516
-
517
-
466
+ }
467
+ // Some auth providers after initialization will avoid to replace authData already stored
518
468
  if (!validationResult.doNotSave) {
519
469
  acc.authData[provider] = validationResult.save || authData[provider];
520
470
  }
@@ -524,24 +474,21 @@ const handleAuthDataValidation = async (authData, req, foundUser) => {
524
474
  message: 'Auth failed. Unknown error.'
525
475
  });
526
476
  const userString = req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;
527
-
528
477
  _logger.logger.error(`Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` + JSON.stringify(e), {
529
478
  authenticationStep: method,
530
479
  error: e,
531
480
  user: userString,
532
481
  provider
533
482
  });
534
-
535
483
  throw e;
536
484
  }
537
485
  }
538
-
539
486
  return acc;
540
487
  };
541
-
542
488
  module.exports = {
543
489
  Auth,
544
490
  master,
491
+ maintenance,
545
492
  nobody,
546
493
  readOnly,
547
494
  getAuthForSessionToken,
@@ -551,4 +498,4 @@ module.exports = {
551
498
  checkIfUserHasProvidedConfiguredProvidersForLogin,
552
499
  handleAuthDataValidation
553
500
  };
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"]}
501
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","Auth","config","cacheController","undefined","isMaster","isMaintenance","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","maintenance","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  isMaintenance = 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.isMaintenance = isMaintenance;\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.isMaintenance) {\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 maintenance-level Auth object\nfunction maintenance(config) {\n  return new Auth({ config, isMaintenance: 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.isMaintenance || !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  maintenance,\n  nobody,\n  readOnly,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"],"mappings":"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"}