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
@@ -4,25 +4,17 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
-
8
7
  var _MongoCollection = _interopRequireDefault(require("./MongoCollection"));
9
-
10
8
  var _node = _interopRequireDefault(require("parse/node"));
11
-
12
9
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
-
14
- function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
15
-
10
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
16
11
  function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
17
-
18
12
  function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
19
-
20
- 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; }
21
-
22
- 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; }
23
-
24
- 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; }
25
-
13
+ 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; }
14
+ 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; }
15
+ 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; }
16
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
17
+ 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); }
26
18
  function mongoFieldToParseSchemaField(type) {
27
19
  if (type[0] === '*') {
28
20
  return {
@@ -30,79 +22,64 @@ function mongoFieldToParseSchemaField(type) {
30
22
  targetClass: type.slice(1)
31
23
  };
32
24
  }
33
-
34
25
  if (type.startsWith('relation<')) {
35
26
  return {
36
27
  type: 'Relation',
37
28
  targetClass: type.slice('relation<'.length, type.length - 1)
38
29
  };
39
30
  }
40
-
41
31
  switch (type) {
42
32
  case 'number':
43
33
  return {
44
34
  type: 'Number'
45
35
  };
46
-
47
36
  case 'string':
48
37
  return {
49
38
  type: 'String'
50
39
  };
51
-
52
40
  case 'boolean':
53
41
  return {
54
42
  type: 'Boolean'
55
43
  };
56
-
57
44
  case 'date':
58
45
  return {
59
46
  type: 'Date'
60
47
  };
61
-
62
48
  case 'map':
63
49
  case 'object':
64
50
  return {
65
51
  type: 'Object'
66
52
  };
67
-
68
53
  case 'array':
69
54
  return {
70
55
  type: 'Array'
71
56
  };
72
-
73
57
  case 'geopoint':
74
58
  return {
75
59
  type: 'GeoPoint'
76
60
  };
77
-
78
61
  case 'file':
79
62
  return {
80
63
  type: 'File'
81
64
  };
82
-
83
65
  case 'bytes':
84
66
  return {
85
67
  type: 'Bytes'
86
68
  };
87
-
88
69
  case 'polygon':
89
70
  return {
90
71
  type: 'Polygon'
91
72
  };
92
73
  }
93
74
  }
94
-
95
75
  const nonFieldSchemaKeys = ['_id', '_metadata', '_client_permissions'];
96
-
97
76
  function mongoSchemaFieldsToParseSchemaFields(schema) {
98
77
  var fieldNames = Object.keys(schema).filter(key => nonFieldSchemaKeys.indexOf(key) === -1);
99
78
  var response = fieldNames.reduce((obj, fieldName) => {
100
79
  obj[fieldName] = mongoFieldToParseSchemaField(schema[fieldName]);
101
-
102
80
  if (schema._metadata && schema._metadata.fields_options && schema._metadata.fields_options[fieldName]) {
103
81
  obj[fieldName] = Object.assign({}, obj[fieldName], schema._metadata.fields_options[fieldName]);
104
82
  }
105
-
106
83
  return obj;
107
84
  }, {});
108
85
  response.ACL = {
@@ -119,7 +96,6 @@ function mongoSchemaFieldsToParseSchemaFields(schema) {
119
96
  };
120
97
  return response;
121
98
  }
122
-
123
99
  const emptyCLPS = Object.freeze({
124
100
  find: {},
125
101
  count: {},
@@ -156,21 +132,17 @@ const defaultCLPS = Object.freeze({
156
132
  '*': []
157
133
  }
158
134
  });
159
-
160
135
  function mongoSchemaToParseSchema(mongoSchema) {
161
136
  let clps = defaultCLPS;
162
137
  let indexes = {};
163
-
164
138
  if (mongoSchema._metadata) {
165
139
  if (mongoSchema._metadata.class_permissions) {
166
140
  clps = _objectSpread(_objectSpread({}, emptyCLPS), mongoSchema._metadata.class_permissions);
167
141
  }
168
-
169
142
  if (mongoSchema._metadata.indexes) {
170
143
  indexes = _objectSpread({}, mongoSchema._metadata.indexes);
171
144
  }
172
145
  }
173
-
174
146
  return {
175
147
  className: mongoSchema._id,
176
148
  fields: mongoSchemaFieldsToParseSchemaFields(mongoSchema),
@@ -178,23 +150,20 @@ function mongoSchemaToParseSchema(mongoSchema) {
178
150
  indexes: indexes
179
151
  };
180
152
  }
181
-
182
153
  function _mongoSchemaQueryFromNameQuery(name, query) {
183
154
  const object = {
184
155
  _id: name
185
156
  };
186
-
187
157
  if (query) {
188
158
  Object.keys(query).forEach(key => {
189
159
  object[key] = query[key];
190
160
  });
191
161
  }
192
-
193
162
  return object;
194
- } // Returns a type suitable for inserting into mongo _SCHEMA collection.
195
- // Does no validation. That is expected to be done in Parse Server.
196
-
163
+ }
197
164
 
165
+ // Returns a type suitable for inserting into mongo _SCHEMA collection.
166
+ // Does no validation. That is expected to be done in Parse Server.
198
167
  function parseFieldTypeToMongoFieldType({
199
168
  type,
200
169
  targetClass
@@ -202,51 +171,37 @@ function parseFieldTypeToMongoFieldType({
202
171
  switch (type) {
203
172
  case 'Pointer':
204
173
  return `*${targetClass}`;
205
-
206
174
  case 'Relation':
207
175
  return `relation<${targetClass}>`;
208
-
209
176
  case 'Number':
210
177
  return 'number';
211
-
212
178
  case 'String':
213
179
  return 'string';
214
-
215
180
  case 'Boolean':
216
181
  return 'boolean';
217
-
218
182
  case 'Date':
219
183
  return 'date';
220
-
221
184
  case 'Object':
222
185
  return 'object';
223
-
224
186
  case 'Array':
225
187
  return 'array';
226
-
227
188
  case 'GeoPoint':
228
189
  return 'geopoint';
229
-
230
190
  case 'File':
231
191
  return 'file';
232
-
233
192
  case 'Bytes':
234
193
  return 'bytes';
235
-
236
194
  case 'Polygon':
237
195
  return 'polygon';
238
196
  }
239
197
  }
240
-
241
198
  class MongoSchemaCollection {
242
199
  constructor(collection) {
243
200
  this._collection = collection;
244
201
  }
245
-
246
202
  _fetchAllSchemasFrom_SCHEMA() {
247
203
  return this._collection._rawFind({}).then(schemas => schemas.map(mongoSchemaToParseSchema));
248
204
  }
249
-
250
205
  _fetchOneSchemaFrom_SCHEMA(name) {
251
206
  return this._collection._rawFind(_mongoSchemaQueryFromNameQuery(name), {
252
207
  limit: 1
@@ -257,13 +212,12 @@ class MongoSchemaCollection {
257
212
  throw undefined;
258
213
  }
259
214
  });
260
- } // Atomically find and delete an object based on query.
261
-
215
+ }
262
216
 
217
+ // Atomically find and delete an object based on query.
263
218
  findAndDeleteSchema(name) {
264
219
  return this._collection._mongoCollection.findOneAndDelete(_mongoSchemaQueryFromNameQuery(name));
265
220
  }
266
-
267
221
  insertSchema(schema) {
268
222
  return this._collection.insertOne(schema).then(() => mongoSchemaToParseSchema(schema)).catch(error => {
269
223
  if (error.code === 11000) {
@@ -274,39 +228,37 @@ class MongoSchemaCollection {
274
228
  }
275
229
  });
276
230
  }
277
-
278
231
  updateSchema(name, update) {
279
232
  return this._collection.updateOne(_mongoSchemaQueryFromNameQuery(name), update);
280
233
  }
281
-
282
234
  upsertSchema(name, query, update) {
283
235
  return this._collection.upsertOne(_mongoSchemaQueryFromNameQuery(name, query), update);
284
- } // Add a field to the schema. If database does not support the field
236
+ }
237
+
238
+ // Add a field to the schema. If database does not support the field
285
239
  // type (e.g. mongo doesn't support more than one GeoPoint in a class) reject with an "Incorrect Type"
286
240
  // Parse error with a desciptive message. If the field already exists, this function must
287
241
  // not modify the schema, and must reject with DUPLICATE_VALUE error.
288
242
  // If this is called for a class that doesn't exist, this function must create that class.
243
+
289
244
  // TODO: throw an error if an unsupported field type is passed. Deciding whether a type is supported
290
245
  // should be the job of the adapter. Some adapters may not support GeoPoint at all. Others may
291
246
  // Support additional types that Mongo doesn't, like Money, or something.
292
- // TODO: don't spend an extra query on finding the schema if the type we are trying to add isn't a GeoPoint.
293
-
294
247
 
248
+ // TODO: don't spend an extra query on finding the schema if the type we are trying to add isn't a GeoPoint.
295
249
  addFieldIfNotExists(className, fieldName, fieldType) {
296
250
  return this._fetchOneSchemaFrom_SCHEMA(className).then(schema => {
297
251
  // If a field with this name already exists, it will be handled elsewhere.
298
252
  if (schema.fields[fieldName] !== undefined) {
299
253
  return;
300
- } // The schema exists. Check for existing GeoPoints.
301
-
302
-
254
+ }
255
+ // The schema exists. Check for existing GeoPoints.
303
256
  if (fieldType.type === 'GeoPoint') {
304
257
  // Make sure there are not other geopoint fields
305
258
  if (Object.keys(schema.fields).some(existingField => schema.fields[existingField].type === 'GeoPoint')) {
306
259
  throw new _node.default.Error(_node.default.Error.INCORRECT_TYPE, 'MongoDB only supports one GeoPoint field in a class.');
307
260
  }
308
261
  }
309
-
310
262
  return;
311
263
  }, error => {
312
264
  // If error is undefined, the schema doesn't exist, and we can create the schema with the field.
@@ -314,17 +266,15 @@ class MongoSchemaCollection {
314
266
  if (error === undefined) {
315
267
  return;
316
268
  }
317
-
318
269
  throw error;
319
270
  }).then(() => {
320
271
  const {
321
- type,
322
- targetClass
323
- } = fieldType,
324
- fieldOptions = _objectWithoutProperties(fieldType, ["type", "targetClass"]); // We use $exists and $set to avoid overwriting the field type if it
272
+ type,
273
+ targetClass
274
+ } = fieldType,
275
+ fieldOptions = _objectWithoutProperties(fieldType, ["type", "targetClass"]);
276
+ // We use $exists and $set to avoid overwriting the field type if it
325
277
  // already exists. (it could have added inbetween the last query and the update)
326
-
327
-
328
278
  if (fieldOptions && Object.keys(fieldOptions).length > 0) {
329
279
  return this.upsertSchema(className, {
330
280
  [fieldName]: {
@@ -355,10 +305,8 @@ class MongoSchemaCollection {
355
305
  }
356
306
  });
357
307
  }
358
-
359
308
  async updateFieldOptions(className, fieldName, fieldType) {
360
309
  const fieldOptions = _extends({}, fieldType);
361
-
362
310
  delete fieldOptions.type;
363
311
  delete fieldOptions.targetClass;
364
312
  await this.upsertSchema(className, {
@@ -371,13 +319,12 @@ class MongoSchemaCollection {
371
319
  }
372
320
  });
373
321
  }
322
+ }
374
323
 
375
- } // Exported for testing reasons and because we haven't moved all mongo schema format
324
+ // Exported for testing reasons and because we haven't moved all mongo schema format
376
325
  // related logic into the database adapter yet.
377
-
378
-
379
326
  MongoSchemaCollection._TESTmongoSchemaToParseSchema = mongoSchemaToParseSchema;
380
327
  MongoSchemaCollection.parseFieldTypeToMongoFieldType = parseFieldTypeToMongoFieldType;
381
328
  var _default = MongoSchemaCollection;
382
329
  exports.default = _default;
383
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Adapters/Storage/Mongo/MongoSchemaCollection.js"],"names":["mongoFieldToParseSchemaField","type","targetClass","slice","startsWith","length","nonFieldSchemaKeys","mongoSchemaFieldsToParseSchemaFields","schema","fieldNames","Object","keys","filter","key","indexOf","response","reduce","obj","fieldName","_metadata","fields_options","assign","ACL","createdAt","updatedAt","objectId","emptyCLPS","freeze","find","count","get","create","update","delete","addField","protectedFields","defaultCLPS","mongoSchemaToParseSchema","mongoSchema","clps","indexes","class_permissions","className","_id","fields","classLevelPermissions","_mongoSchemaQueryFromNameQuery","name","query","object","forEach","parseFieldTypeToMongoFieldType","MongoSchemaCollection","constructor","collection","_collection","_fetchAllSchemasFrom_SCHEMA","_rawFind","then","schemas","map","_fetchOneSchemaFrom_SCHEMA","limit","results","undefined","findAndDeleteSchema","_mongoCollection","findOneAndDelete","insertSchema","insertOne","catch","error","code","Parse","Error","DUPLICATE_VALUE","updateSchema","updateOne","upsertSchema","upsertOne","addFieldIfNotExists","fieldType","some","existingField","INCORRECT_TYPE","fieldOptions","$exists","$set","updateFieldOptions","_TESTmongoSchemaToParseSchema"],"mappings":"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","sourcesContent":["import MongoCollection from './MongoCollection';\nimport Parse from 'parse/node';\n\nfunction mongoFieldToParseSchemaField(type) {\n  if (type[0] === '*') {\n    return {\n      type: 'Pointer',\n      targetClass: type.slice(1),\n    };\n  }\n  if (type.startsWith('relation<')) {\n    return {\n      type: 'Relation',\n      targetClass: type.slice('relation<'.length, type.length - 1),\n    };\n  }\n  switch (type) {\n    case 'number':\n      return { type: 'Number' };\n    case 'string':\n      return { type: 'String' };\n    case 'boolean':\n      return { type: 'Boolean' };\n    case 'date':\n      return { type: 'Date' };\n    case 'map':\n    case 'object':\n      return { type: 'Object' };\n    case 'array':\n      return { type: 'Array' };\n    case 'geopoint':\n      return { type: 'GeoPoint' };\n    case 'file':\n      return { type: 'File' };\n    case 'bytes':\n      return { type: 'Bytes' };\n    case 'polygon':\n      return { type: 'Polygon' };\n  }\n}\n\nconst nonFieldSchemaKeys = ['_id', '_metadata', '_client_permissions'];\nfunction mongoSchemaFieldsToParseSchemaFields(schema) {\n  var fieldNames = Object.keys(schema).filter(key => nonFieldSchemaKeys.indexOf(key) === -1);\n  var response = fieldNames.reduce((obj, fieldName) => {\n    obj[fieldName] = mongoFieldToParseSchemaField(schema[fieldName]);\n    if (\n      schema._metadata &&\n      schema._metadata.fields_options &&\n      schema._metadata.fields_options[fieldName]\n    ) {\n      obj[fieldName] = Object.assign(\n        {},\n        obj[fieldName],\n        schema._metadata.fields_options[fieldName]\n      );\n    }\n    return obj;\n  }, {});\n  response.ACL = { type: 'ACL' };\n  response.createdAt = { type: 'Date' };\n  response.updatedAt = { type: 'Date' };\n  response.objectId = { type: 'String' };\n  return response;\n}\n\nconst emptyCLPS = Object.freeze({\n  find: {},\n  count: {},\n  get: {},\n  create: {},\n  update: {},\n  delete: {},\n  addField: {},\n  protectedFields: {},\n});\n\nconst defaultCLPS = Object.freeze({\n  find: { '*': true },\n  count: { '*': true },\n  get: { '*': true },\n  create: { '*': true },\n  update: { '*': true },\n  delete: { '*': true },\n  addField: { '*': true },\n  protectedFields: { '*': [] },\n});\n\nfunction mongoSchemaToParseSchema(mongoSchema) {\n  let clps = defaultCLPS;\n  let indexes = {};\n  if (mongoSchema._metadata) {\n    if (mongoSchema._metadata.class_permissions) {\n      clps = { ...emptyCLPS, ...mongoSchema._metadata.class_permissions };\n    }\n    if (mongoSchema._metadata.indexes) {\n      indexes = { ...mongoSchema._metadata.indexes };\n    }\n  }\n  return {\n    className: mongoSchema._id,\n    fields: mongoSchemaFieldsToParseSchemaFields(mongoSchema),\n    classLevelPermissions: clps,\n    indexes: indexes,\n  };\n}\n\nfunction _mongoSchemaQueryFromNameQuery(name: string, query) {\n  const object = { _id: name };\n  if (query) {\n    Object.keys(query).forEach(key => {\n      object[key] = query[key];\n    });\n  }\n  return object;\n}\n\n// Returns a type suitable for inserting into mongo _SCHEMA collection.\n// Does no validation. That is expected to be done in Parse Server.\nfunction parseFieldTypeToMongoFieldType({ type, targetClass }) {\n  switch (type) {\n    case 'Pointer':\n      return `*${targetClass}`;\n    case 'Relation':\n      return `relation<${targetClass}>`;\n    case 'Number':\n      return 'number';\n    case 'String':\n      return 'string';\n    case 'Boolean':\n      return 'boolean';\n    case 'Date':\n      return 'date';\n    case 'Object':\n      return 'object';\n    case 'Array':\n      return 'array';\n    case 'GeoPoint':\n      return 'geopoint';\n    case 'File':\n      return 'file';\n    case 'Bytes':\n      return 'bytes';\n    case 'Polygon':\n      return 'polygon';\n  }\n}\n\nclass MongoSchemaCollection {\n  _collection: MongoCollection;\n\n  constructor(collection: MongoCollection) {\n    this._collection = collection;\n  }\n\n  _fetchAllSchemasFrom_SCHEMA() {\n    return this._collection._rawFind({}).then(schemas => schemas.map(mongoSchemaToParseSchema));\n  }\n\n  _fetchOneSchemaFrom_SCHEMA(name: string) {\n    return this._collection\n      ._rawFind(_mongoSchemaQueryFromNameQuery(name), { limit: 1 })\n      .then(results => {\n        if (results.length === 1) {\n          return mongoSchemaToParseSchema(results[0]);\n        } else {\n          throw undefined;\n        }\n      });\n  }\n\n  // Atomically find and delete an object based on query.\n  findAndDeleteSchema(name: string) {\n    return this._collection._mongoCollection.findOneAndDelete(_mongoSchemaQueryFromNameQuery(name));\n  }\n\n  insertSchema(schema: any) {\n    return this._collection\n      .insertOne(schema)\n      .then(() => mongoSchemaToParseSchema(schema))\n      .catch(error => {\n        if (error.code === 11000) {\n          //Mongo's duplicate key error\n          throw new Parse.Error(Parse.Error.DUPLICATE_VALUE, 'Class already exists.');\n        } else {\n          throw error;\n        }\n      });\n  }\n\n  updateSchema(name: string, update) {\n    return this._collection.updateOne(_mongoSchemaQueryFromNameQuery(name), update);\n  }\n\n  upsertSchema(name: string, query: string, update) {\n    return this._collection.upsertOne(_mongoSchemaQueryFromNameQuery(name, query), update);\n  }\n\n  // Add a field to the schema. If database does not support the field\n  // type (e.g. mongo doesn't support more than one GeoPoint in a class) reject with an \"Incorrect Type\"\n  // Parse error with a desciptive message. If the field already exists, this function must\n  // not modify the schema, and must reject with DUPLICATE_VALUE error.\n  // If this is called for a class that doesn't exist, this function must create that class.\n\n  // TODO: throw an error if an unsupported field type is passed. Deciding whether a type is supported\n  // should be the job of the adapter. Some adapters may not support GeoPoint at all. Others may\n  // Support additional types that Mongo doesn't, like Money, or something.\n\n  // TODO: don't spend an extra query on finding the schema if the type we are trying to add isn't a GeoPoint.\n  addFieldIfNotExists(className: string, fieldName: string, fieldType: string) {\n    return this._fetchOneSchemaFrom_SCHEMA(className)\n      .then(\n        schema => {\n          // If a field with this name already exists, it will be handled elsewhere.\n          if (schema.fields[fieldName] !== undefined) {\n            return;\n          }\n          // The schema exists. Check for existing GeoPoints.\n          if (fieldType.type === 'GeoPoint') {\n            // Make sure there are not other geopoint fields\n            if (\n              Object.keys(schema.fields).some(\n                existingField => schema.fields[existingField].type === 'GeoPoint'\n              )\n            ) {\n              throw new Parse.Error(\n                Parse.Error.INCORRECT_TYPE,\n                'MongoDB only supports one GeoPoint field in a class.'\n              );\n            }\n          }\n          return;\n        },\n        error => {\n          // If error is undefined, the schema doesn't exist, and we can create the schema with the field.\n          // If some other error, reject with it.\n          if (error === undefined) {\n            return;\n          }\n          throw error;\n        }\n      )\n      .then(() => {\n        const { type, targetClass, ...fieldOptions } = fieldType;\n        // We use $exists and $set to avoid overwriting the field type if it\n        // already exists. (it could have added inbetween the last query and the update)\n        if (fieldOptions && Object.keys(fieldOptions).length > 0) {\n          return this.upsertSchema(\n            className,\n            { [fieldName]: { $exists: false } },\n            {\n              $set: {\n                [fieldName]: parseFieldTypeToMongoFieldType({\n                  type,\n                  targetClass,\n                }),\n                [`_metadata.fields_options.${fieldName}`]: fieldOptions,\n              },\n            }\n          );\n        } else {\n          return this.upsertSchema(\n            className,\n            { [fieldName]: { $exists: false } },\n            {\n              $set: {\n                [fieldName]: parseFieldTypeToMongoFieldType({\n                  type,\n                  targetClass,\n                }),\n              },\n            }\n          );\n        }\n      });\n  }\n\n  async updateFieldOptions(className: string, fieldName: string, fieldType: any) {\n    const { ...fieldOptions } = fieldType;\n    delete fieldOptions.type;\n    delete fieldOptions.targetClass;\n\n    await this.upsertSchema(\n      className,\n      { [fieldName]: { $exists: true } },\n      {\n        $set: {\n          [`_metadata.fields_options.${fieldName}`]: fieldOptions,\n        },\n      }\n    );\n  }\n}\n\n// Exported for testing reasons and because we haven't moved all mongo schema format\n// related logic into the database adapter yet.\nMongoSchemaCollection._TESTmongoSchemaToParseSchema = mongoSchemaToParseSchema;\nMongoSchemaCollection.parseFieldTypeToMongoFieldType = parseFieldTypeToMongoFieldType;\n\nexport default MongoSchemaCollection;\n"]}
330
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["mongoFieldToParseSchemaField","type","targetClass","slice","startsWith","length","nonFieldSchemaKeys","mongoSchemaFieldsToParseSchemaFields","schema","fieldNames","Object","keys","filter","key","indexOf","response","reduce","obj","fieldName","_metadata","fields_options","assign","ACL","createdAt","updatedAt","objectId","emptyCLPS","freeze","find","count","get","create","update","delete","addField","protectedFields","defaultCLPS","mongoSchemaToParseSchema","mongoSchema","clps","indexes","class_permissions","className","_id","fields","classLevelPermissions","_mongoSchemaQueryFromNameQuery","name","query","object","forEach","parseFieldTypeToMongoFieldType","MongoSchemaCollection","constructor","collection","_collection","_fetchAllSchemasFrom_SCHEMA","_rawFind","then","schemas","map","_fetchOneSchemaFrom_SCHEMA","limit","results","undefined","findAndDeleteSchema","_mongoCollection","findOneAndDelete","insertSchema","insertOne","catch","error","code","Parse","Error","DUPLICATE_VALUE","updateSchema","updateOne","upsertSchema","upsertOne","addFieldIfNotExists","fieldType","some","existingField","INCORRECT_TYPE","fieldOptions","$exists","$set","updateFieldOptions","_TESTmongoSchemaToParseSchema"],"sources":["../../../../src/Adapters/Storage/Mongo/MongoSchemaCollection.js"],"sourcesContent":["import MongoCollection from './MongoCollection';\nimport Parse from 'parse/node';\n\nfunction mongoFieldToParseSchemaField(type) {\n  if (type[0] === '*') {\n    return {\n      type: 'Pointer',\n      targetClass: type.slice(1),\n    };\n  }\n  if (type.startsWith('relation<')) {\n    return {\n      type: 'Relation',\n      targetClass: type.slice('relation<'.length, type.length - 1),\n    };\n  }\n  switch (type) {\n    case 'number':\n      return { type: 'Number' };\n    case 'string':\n      return { type: 'String' };\n    case 'boolean':\n      return { type: 'Boolean' };\n    case 'date':\n      return { type: 'Date' };\n    case 'map':\n    case 'object':\n      return { type: 'Object' };\n    case 'array':\n      return { type: 'Array' };\n    case 'geopoint':\n      return { type: 'GeoPoint' };\n    case 'file':\n      return { type: 'File' };\n    case 'bytes':\n      return { type: 'Bytes' };\n    case 'polygon':\n      return { type: 'Polygon' };\n  }\n}\n\nconst nonFieldSchemaKeys = ['_id', '_metadata', '_client_permissions'];\nfunction mongoSchemaFieldsToParseSchemaFields(schema) {\n  var fieldNames = Object.keys(schema).filter(key => nonFieldSchemaKeys.indexOf(key) === -1);\n  var response = fieldNames.reduce((obj, fieldName) => {\n    obj[fieldName] = mongoFieldToParseSchemaField(schema[fieldName]);\n    if (\n      schema._metadata &&\n      schema._metadata.fields_options &&\n      schema._metadata.fields_options[fieldName]\n    ) {\n      obj[fieldName] = Object.assign(\n        {},\n        obj[fieldName],\n        schema._metadata.fields_options[fieldName]\n      );\n    }\n    return obj;\n  }, {});\n  response.ACL = { type: 'ACL' };\n  response.createdAt = { type: 'Date' };\n  response.updatedAt = { type: 'Date' };\n  response.objectId = { type: 'String' };\n  return response;\n}\n\nconst emptyCLPS = Object.freeze({\n  find: {},\n  count: {},\n  get: {},\n  create: {},\n  update: {},\n  delete: {},\n  addField: {},\n  protectedFields: {},\n});\n\nconst defaultCLPS = Object.freeze({\n  find: { '*': true },\n  count: { '*': true },\n  get: { '*': true },\n  create: { '*': true },\n  update: { '*': true },\n  delete: { '*': true },\n  addField: { '*': true },\n  protectedFields: { '*': [] },\n});\n\nfunction mongoSchemaToParseSchema(mongoSchema) {\n  let clps = defaultCLPS;\n  let indexes = {};\n  if (mongoSchema._metadata) {\n    if (mongoSchema._metadata.class_permissions) {\n      clps = { ...emptyCLPS, ...mongoSchema._metadata.class_permissions };\n    }\n    if (mongoSchema._metadata.indexes) {\n      indexes = { ...mongoSchema._metadata.indexes };\n    }\n  }\n  return {\n    className: mongoSchema._id,\n    fields: mongoSchemaFieldsToParseSchemaFields(mongoSchema),\n    classLevelPermissions: clps,\n    indexes: indexes,\n  };\n}\n\nfunction _mongoSchemaQueryFromNameQuery(name: string, query) {\n  const object = { _id: name };\n  if (query) {\n    Object.keys(query).forEach(key => {\n      object[key] = query[key];\n    });\n  }\n  return object;\n}\n\n// Returns a type suitable for inserting into mongo _SCHEMA collection.\n// Does no validation. That is expected to be done in Parse Server.\nfunction parseFieldTypeToMongoFieldType({ type, targetClass }) {\n  switch (type) {\n    case 'Pointer':\n      return `*${targetClass}`;\n    case 'Relation':\n      return `relation<${targetClass}>`;\n    case 'Number':\n      return 'number';\n    case 'String':\n      return 'string';\n    case 'Boolean':\n      return 'boolean';\n    case 'Date':\n      return 'date';\n    case 'Object':\n      return 'object';\n    case 'Array':\n      return 'array';\n    case 'GeoPoint':\n      return 'geopoint';\n    case 'File':\n      return 'file';\n    case 'Bytes':\n      return 'bytes';\n    case 'Polygon':\n      return 'polygon';\n  }\n}\n\nclass MongoSchemaCollection {\n  _collection: MongoCollection;\n\n  constructor(collection: MongoCollection) {\n    this._collection = collection;\n  }\n\n  _fetchAllSchemasFrom_SCHEMA() {\n    return this._collection._rawFind({}).then(schemas => schemas.map(mongoSchemaToParseSchema));\n  }\n\n  _fetchOneSchemaFrom_SCHEMA(name: string) {\n    return this._collection\n      ._rawFind(_mongoSchemaQueryFromNameQuery(name), { limit: 1 })\n      .then(results => {\n        if (results.length === 1) {\n          return mongoSchemaToParseSchema(results[0]);\n        } else {\n          throw undefined;\n        }\n      });\n  }\n\n  // Atomically find and delete an object based on query.\n  findAndDeleteSchema(name: string) {\n    return this._collection._mongoCollection.findOneAndDelete(_mongoSchemaQueryFromNameQuery(name));\n  }\n\n  insertSchema(schema: any) {\n    return this._collection\n      .insertOne(schema)\n      .then(() => mongoSchemaToParseSchema(schema))\n      .catch(error => {\n        if (error.code === 11000) {\n          //Mongo's duplicate key error\n          throw new Parse.Error(Parse.Error.DUPLICATE_VALUE, 'Class already exists.');\n        } else {\n          throw error;\n        }\n      });\n  }\n\n  updateSchema(name: string, update) {\n    return this._collection.updateOne(_mongoSchemaQueryFromNameQuery(name), update);\n  }\n\n  upsertSchema(name: string, query: string, update) {\n    return this._collection.upsertOne(_mongoSchemaQueryFromNameQuery(name, query), update);\n  }\n\n  // Add a field to the schema. If database does not support the field\n  // type (e.g. mongo doesn't support more than one GeoPoint in a class) reject with an \"Incorrect Type\"\n  // Parse error with a desciptive message. If the field already exists, this function must\n  // not modify the schema, and must reject with DUPLICATE_VALUE error.\n  // If this is called for a class that doesn't exist, this function must create that class.\n\n  // TODO: throw an error if an unsupported field type is passed. Deciding whether a type is supported\n  // should be the job of the adapter. Some adapters may not support GeoPoint at all. Others may\n  // Support additional types that Mongo doesn't, like Money, or something.\n\n  // TODO: don't spend an extra query on finding the schema if the type we are trying to add isn't a GeoPoint.\n  addFieldIfNotExists(className: string, fieldName: string, fieldType: string) {\n    return this._fetchOneSchemaFrom_SCHEMA(className)\n      .then(\n        schema => {\n          // If a field with this name already exists, it will be handled elsewhere.\n          if (schema.fields[fieldName] !== undefined) {\n            return;\n          }\n          // The schema exists. Check for existing GeoPoints.\n          if (fieldType.type === 'GeoPoint') {\n            // Make sure there are not other geopoint fields\n            if (\n              Object.keys(schema.fields).some(\n                existingField => schema.fields[existingField].type === 'GeoPoint'\n              )\n            ) {\n              throw new Parse.Error(\n                Parse.Error.INCORRECT_TYPE,\n                'MongoDB only supports one GeoPoint field in a class.'\n              );\n            }\n          }\n          return;\n        },\n        error => {\n          // If error is undefined, the schema doesn't exist, and we can create the schema with the field.\n          // If some other error, reject with it.\n          if (error === undefined) {\n            return;\n          }\n          throw error;\n        }\n      )\n      .then(() => {\n        const { type, targetClass, ...fieldOptions } = fieldType;\n        // We use $exists and $set to avoid overwriting the field type if it\n        // already exists. (it could have added inbetween the last query and the update)\n        if (fieldOptions && Object.keys(fieldOptions).length > 0) {\n          return this.upsertSchema(\n            className,\n            { [fieldName]: { $exists: false } },\n            {\n              $set: {\n                [fieldName]: parseFieldTypeToMongoFieldType({\n                  type,\n                  targetClass,\n                }),\n                [`_metadata.fields_options.${fieldName}`]: fieldOptions,\n              },\n            }\n          );\n        } else {\n          return this.upsertSchema(\n            className,\n            { [fieldName]: { $exists: false } },\n            {\n              $set: {\n                [fieldName]: parseFieldTypeToMongoFieldType({\n                  type,\n                  targetClass,\n                }),\n              },\n            }\n          );\n        }\n      });\n  }\n\n  async updateFieldOptions(className: string, fieldName: string, fieldType: any) {\n    const { ...fieldOptions } = fieldType;\n    delete fieldOptions.type;\n    delete fieldOptions.targetClass;\n\n    await this.upsertSchema(\n      className,\n      { [fieldName]: { $exists: true } },\n      {\n        $set: {\n          [`_metadata.fields_options.${fieldName}`]: fieldOptions,\n        },\n      }\n    );\n  }\n}\n\n// Exported for testing reasons and because we haven't moved all mongo schema format\n// related logic into the database adapter yet.\nMongoSchemaCollection._TESTmongoSchemaToParseSchema = mongoSchemaToParseSchema;\nMongoSchemaCollection.parseFieldTypeToMongoFieldType = parseFieldTypeToMongoFieldType;\n\nexport default MongoSchemaCollection;\n"],"mappings":";;;;;;AAAA;AACA;AAA+B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAE/B,SAASA,4BAA4B,CAACC,IAAI,EAAE;EAC1C,IAAIA,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;IACnB,OAAO;MACLA,IAAI,EAAE,SAAS;MACfC,WAAW,EAAED,IAAI,CAACE,KAAK,CAAC,CAAC;IAC3B,CAAC;EACH;EACA,IAAIF,IAAI,CAACG,UAAU,CAAC,WAAW,CAAC,EAAE;IAChC,OAAO;MACLH,IAAI,EAAE,UAAU;MAChBC,WAAW,EAAED,IAAI,CAACE,KAAK,CAAC,WAAW,CAACE,MAAM,EAAEJ,IAAI,CAACI,MAAM,GAAG,CAAC;IAC7D,CAAC;EACH;EACA,QAAQJ,IAAI;IACV,KAAK,QAAQ;MACX,OAAO;QAAEA,IAAI,EAAE;MAAS,CAAC;IAC3B,KAAK,QAAQ;MACX,OAAO;QAAEA,IAAI,EAAE;MAAS,CAAC;IAC3B,KAAK,SAAS;MACZ,OAAO;QAAEA,IAAI,EAAE;MAAU,CAAC;IAC5B,KAAK,MAAM;MACT,OAAO;QAAEA,IAAI,EAAE;MAAO,CAAC;IACzB,KAAK,KAAK;IACV,KAAK,QAAQ;MACX,OAAO;QAAEA,IAAI,EAAE;MAAS,CAAC;IAC3B,KAAK,OAAO;MACV,OAAO;QAAEA,IAAI,EAAE;MAAQ,CAAC;IAC1B,KAAK,UAAU;MACb,OAAO;QAAEA,IAAI,EAAE;MAAW,CAAC;IAC7B,KAAK,MAAM;MACT,OAAO;QAAEA,IAAI,EAAE;MAAO,CAAC;IACzB,KAAK,OAAO;MACV,OAAO;QAAEA,IAAI,EAAE;MAAQ,CAAC;IAC1B,KAAK,SAAS;MACZ,OAAO;QAAEA,IAAI,EAAE;MAAU,CAAC;EAAC;AAEjC;AAEA,MAAMK,kBAAkB,GAAG,CAAC,KAAK,EAAE,WAAW,EAAE,qBAAqB,CAAC;AACtE,SAASC,oCAAoC,CAACC,MAAM,EAAE;EACpD,IAAIC,UAAU,GAAGC,MAAM,CAACC,IAAI,CAACH,MAAM,CAAC,CAACI,MAAM,CAACC,GAAG,IAAIP,kBAAkB,CAACQ,OAAO,CAACD,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;EAC1F,IAAIE,QAAQ,GAAGN,UAAU,CAACO,MAAM,CAAC,CAACC,GAAG,EAAEC,SAAS,KAAK;IACnDD,GAAG,CAACC,SAAS,CAAC,GAAGlB,4BAA4B,CAACQ,MAAM,CAACU,SAAS,CAAC,CAAC;IAChE,IACEV,MAAM,CAACW,SAAS,IAChBX,MAAM,CAACW,SAAS,CAACC,cAAc,IAC/BZ,MAAM,CAACW,SAAS,CAACC,cAAc,CAACF,SAAS,CAAC,EAC1C;MACAD,GAAG,CAACC,SAAS,CAAC,GAAGR,MAAM,CAACW,MAAM,CAC5B,CAAC,CAAC,EACFJ,GAAG,CAACC,SAAS,CAAC,EACdV,MAAM,CAACW,SAAS,CAACC,cAAc,CAACF,SAAS,CAAC,CAC3C;IACH;IACA,OAAOD,GAAG;EACZ,CAAC,EAAE,CAAC,CAAC,CAAC;EACNF,QAAQ,CAACO,GAAG,GAAG;IAAErB,IAAI,EAAE;EAAM,CAAC;EAC9Bc,QAAQ,CAACQ,SAAS,GAAG;IAAEtB,IAAI,EAAE;EAAO,CAAC;EACrCc,QAAQ,CAACS,SAAS,GAAG;IAAEvB,IAAI,EAAE;EAAO,CAAC;EACrCc,QAAQ,CAACU,QAAQ,GAAG;IAAExB,IAAI,EAAE;EAAS,CAAC;EACtC,OAAOc,QAAQ;AACjB;AAEA,MAAMW,SAAS,GAAGhB,MAAM,CAACiB,MAAM,CAAC;EAC9BC,IAAI,EAAE,CAAC,CAAC;EACRC,KAAK,EAAE,CAAC,CAAC;EACTC,GAAG,EAAE,CAAC,CAAC;EACPC,MAAM,EAAE,CAAC,CAAC;EACVC,MAAM,EAAE,CAAC,CAAC;EACVC,MAAM,EAAE,CAAC,CAAC;EACVC,QAAQ,EAAE,CAAC,CAAC;EACZC,eAAe,EAAE,CAAC;AACpB,CAAC,CAAC;AAEF,MAAMC,WAAW,GAAG1B,MAAM,CAACiB,MAAM,CAAC;EAChCC,IAAI,EAAE;IAAE,GAAG,EAAE;EAAK,CAAC;EACnBC,KAAK,EAAE;IAAE,GAAG,EAAE;EAAK,CAAC;EACpBC,GAAG,EAAE;IAAE,GAAG,EAAE;EAAK,CAAC;EAClBC,MAAM,EAAE;IAAE,GAAG,EAAE;EAAK,CAAC;EACrBC,MAAM,EAAE;IAAE,GAAG,EAAE;EAAK,CAAC;EACrBC,MAAM,EAAE;IAAE,GAAG,EAAE;EAAK,CAAC;EACrBC,QAAQ,EAAE;IAAE,GAAG,EAAE;EAAK,CAAC;EACvBC,eAAe,EAAE;IAAE,GAAG,EAAE;EAAG;AAC7B,CAAC,CAAC;AAEF,SAASE,wBAAwB,CAACC,WAAW,EAAE;EAC7C,IAAIC,IAAI,GAAGH,WAAW;EACtB,IAAII,OAAO,GAAG,CAAC,CAAC;EAChB,IAAIF,WAAW,CAACnB,SAAS,EAAE;IACzB,IAAImB,WAAW,CAACnB,SAAS,CAACsB,iBAAiB,EAAE;MAC3CF,IAAI,mCAAQb,SAAS,GAAKY,WAAW,CAACnB,SAAS,CAACsB,iBAAiB,CAAE;IACrE;IACA,IAAIH,WAAW,CAACnB,SAAS,CAACqB,OAAO,EAAE;MACjCA,OAAO,qBAAQF,WAAW,CAACnB,SAAS,CAACqB,OAAO,CAAE;IAChD;EACF;EACA,OAAO;IACLE,SAAS,EAAEJ,WAAW,CAACK,GAAG;IAC1BC,MAAM,EAAErC,oCAAoC,CAAC+B,WAAW,CAAC;IACzDO,qBAAqB,EAAEN,IAAI;IAC3BC,OAAO,EAAEA;EACX,CAAC;AACH;AAEA,SAASM,8BAA8B,CAACC,IAAY,EAAEC,KAAK,EAAE;EAC3D,MAAMC,MAAM,GAAG;IAAEN,GAAG,EAAEI;EAAK,CAAC;EAC5B,IAAIC,KAAK,EAAE;IACTtC,MAAM,CAACC,IAAI,CAACqC,KAAK,CAAC,CAACE,OAAO,CAACrC,GAAG,IAAI;MAChCoC,MAAM,CAACpC,GAAG,CAAC,GAAGmC,KAAK,CAACnC,GAAG,CAAC;IAC1B,CAAC,CAAC;EACJ;EACA,OAAOoC,MAAM;AACf;;AAEA;AACA;AACA,SAASE,8BAA8B,CAAC;EAAElD,IAAI;EAAEC;AAAY,CAAC,EAAE;EAC7D,QAAQD,IAAI;IACV,KAAK,SAAS;MACZ,OAAQ,IAAGC,WAAY,EAAC;IAC1B,KAAK,UAAU;MACb,OAAQ,YAAWA,WAAY,GAAE;IACnC,KAAK,QAAQ;MACX,OAAO,QAAQ;IACjB,KAAK,QAAQ;MACX,OAAO,QAAQ;IACjB,KAAK,SAAS;MACZ,OAAO,SAAS;IAClB,KAAK,MAAM;MACT,OAAO,MAAM;IACf,KAAK,QAAQ;MACX,OAAO,QAAQ;IACjB,KAAK,OAAO;MACV,OAAO,OAAO;IAChB,KAAK,UAAU;MACb,OAAO,UAAU;IACnB,KAAK,MAAM;MACT,OAAO,MAAM;IACf,KAAK,OAAO;MACV,OAAO,OAAO;IAChB,KAAK,SAAS;MACZ,OAAO,SAAS;EAAC;AAEvB;AAEA,MAAMkD,qBAAqB,CAAC;EAG1BC,WAAW,CAACC,UAA2B,EAAE;IACvC,IAAI,CAACC,WAAW,GAAGD,UAAU;EAC/B;EAEAE,2BAA2B,GAAG;IAC5B,OAAO,IAAI,CAACD,WAAW,CAACE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAACC,IAAI,CAACC,OAAO,IAAIA,OAAO,CAACC,GAAG,CAACvB,wBAAwB,CAAC,CAAC;EAC7F;EAEAwB,0BAA0B,CAACd,IAAY,EAAE;IACvC,OAAO,IAAI,CAACQ,WAAW,CACpBE,QAAQ,CAACX,8BAA8B,CAACC,IAAI,CAAC,EAAE;MAAEe,KAAK,EAAE;IAAE,CAAC,CAAC,CAC5DJ,IAAI,CAACK,OAAO,IAAI;MACf,IAAIA,OAAO,CAAC1D,MAAM,KAAK,CAAC,EAAE;QACxB,OAAOgC,wBAAwB,CAAC0B,OAAO,CAAC,CAAC,CAAC,CAAC;MAC7C,CAAC,MAAM;QACL,MAAMC,SAAS;MACjB;IACF,CAAC,CAAC;EACN;;EAEA;EACAC,mBAAmB,CAAClB,IAAY,EAAE;IAChC,OAAO,IAAI,CAACQ,WAAW,CAACW,gBAAgB,CAACC,gBAAgB,CAACrB,8BAA8B,CAACC,IAAI,CAAC,CAAC;EACjG;EAEAqB,YAAY,CAAC5D,MAAW,EAAE;IACxB,OAAO,IAAI,CAAC+C,WAAW,CACpBc,SAAS,CAAC7D,MAAM,CAAC,CACjBkD,IAAI,CAAC,MAAMrB,wBAAwB,CAAC7B,MAAM,CAAC,CAAC,CAC5C8D,KAAK,CAACC,KAAK,IAAI;MACd,IAAIA,KAAK,CAACC,IAAI,KAAK,KAAK,EAAE;QACxB;QACA,MAAM,IAAIC,aAAK,CAACC,KAAK,CAACD,aAAK,CAACC,KAAK,CAACC,eAAe,EAAE,uBAAuB,CAAC;MAC7E,CAAC,MAAM;QACL,MAAMJ,KAAK;MACb;IACF,CAAC,CAAC;EACN;EAEAK,YAAY,CAAC7B,IAAY,EAAEf,MAAM,EAAE;IACjC,OAAO,IAAI,CAACuB,WAAW,CAACsB,SAAS,CAAC/B,8BAA8B,CAACC,IAAI,CAAC,EAAEf,MAAM,CAAC;EACjF;EAEA8C,YAAY,CAAC/B,IAAY,EAAEC,KAAa,EAAEhB,MAAM,EAAE;IAChD,OAAO,IAAI,CAACuB,WAAW,CAACwB,SAAS,CAACjC,8BAA8B,CAACC,IAAI,EAAEC,KAAK,CAAC,EAAEhB,MAAM,CAAC;EACxF;;EAEA;EACA;EACA;EACA;EACA;;EAEA;EACA;EACA;;EAEA;EACAgD,mBAAmB,CAACtC,SAAiB,EAAExB,SAAiB,EAAE+D,SAAiB,EAAE;IAC3E,OAAO,IAAI,CAACpB,0BAA0B,CAACnB,SAAS,CAAC,CAC9CgB,IAAI,CACHlD,MAAM,IAAI;MACR;MACA,IAAIA,MAAM,CAACoC,MAAM,CAAC1B,SAAS,CAAC,KAAK8C,SAAS,EAAE;QAC1C;MACF;MACA;MACA,IAAIiB,SAAS,CAAChF,IAAI,KAAK,UAAU,EAAE;QACjC;QACA,IACES,MAAM,CAACC,IAAI,CAACH,MAAM,CAACoC,MAAM,CAAC,CAACsC,IAAI,CAC7BC,aAAa,IAAI3E,MAAM,CAACoC,MAAM,CAACuC,aAAa,CAAC,CAAClF,IAAI,KAAK,UAAU,CAClE,EACD;UACA,MAAM,IAAIwE,aAAK,CAACC,KAAK,CACnBD,aAAK,CAACC,KAAK,CAACU,cAAc,EAC1B,sDAAsD,CACvD;QACH;MACF;MACA;IACF,CAAC,EACDb,KAAK,IAAI;MACP;MACA;MACA,IAAIA,KAAK,KAAKP,SAAS,EAAE;QACvB;MACF;MACA,MAAMO,KAAK;IACb,CAAC,CACF,CACAb,IAAI,CAAC,MAAM;MACV,MAAM;UAAEzD,IAAI;UAAEC;QAA6B,CAAC,GAAG+E,SAAS;QAA1BI,YAAY,4BAAKJ,SAAS;MACxD;MACA;MACA,IAAII,YAAY,IAAI3E,MAAM,CAACC,IAAI,CAAC0E,YAAY,CAAC,CAAChF,MAAM,GAAG,CAAC,EAAE;QACxD,OAAO,IAAI,CAACyE,YAAY,CACtBpC,SAAS,EACT;UAAE,CAACxB,SAAS,GAAG;YAAEoE,OAAO,EAAE;UAAM;QAAE,CAAC,EACnC;UACEC,IAAI,EAAE;YACJ,CAACrE,SAAS,GAAGiC,8BAA8B,CAAC;cAC1ClD,IAAI;cACJC;YACF,CAAC,CAAC;YACF,CAAE,4BAA2BgB,SAAU,EAAC,GAAGmE;UAC7C;QACF,CAAC,CACF;MACH,CAAC,MAAM;QACL,OAAO,IAAI,CAACP,YAAY,CACtBpC,SAAS,EACT;UAAE,CAACxB,SAAS,GAAG;YAAEoE,OAAO,EAAE;UAAM;QAAE,CAAC,EACnC;UACEC,IAAI,EAAE;YACJ,CAACrE,SAAS,GAAGiC,8BAA8B,CAAC;cAC1ClD,IAAI;cACJC;YACF,CAAC;UACH;QACF,CAAC,CACF;MACH;IACF,CAAC,CAAC;EACN;EAEA,MAAMsF,kBAAkB,CAAC9C,SAAiB,EAAExB,SAAiB,EAAE+D,SAAc,EAAE;IAC7E,MAAWI,YAAY,gBAAKJ,SAAS;IACrC,OAAOI,YAAY,CAACpF,IAAI;IACxB,OAAOoF,YAAY,CAACnF,WAAW;IAE/B,MAAM,IAAI,CAAC4E,YAAY,CACrBpC,SAAS,EACT;MAAE,CAACxB,SAAS,GAAG;QAAEoE,OAAO,EAAE;MAAK;IAAE,CAAC,EAClC;MACEC,IAAI,EAAE;QACJ,CAAE,4BAA2BrE,SAAU,EAAC,GAAGmE;MAC7C;IACF,CAAC,CACF;EACH;AACF;;AAEA;AACA;AACAjC,qBAAqB,CAACqC,6BAA6B,GAAGpD,wBAAwB;AAC9Ee,qBAAqB,CAACD,8BAA8B,GAAGA,8BAA8B;AAAC,eAEvEC,qBAAqB;AAAA"}