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.
- package/README.md +45 -17
- package/lib/AccountLockout.js +11 -26
- package/lib/Adapters/AdapterLoader.js +8 -14
- package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
- package/lib/Adapters/Auth/AuthAdapter.js +7 -16
- package/lib/Adapters/Auth/OAuth1Client.js +32 -57
- package/lib/Adapters/Auth/apple.js +6 -22
- package/lib/Adapters/Auth/facebook.js +7 -37
- package/lib/Adapters/Auth/gcenter.js +8 -37
- package/lib/Adapters/Auth/github.js +7 -10
- package/lib/Adapters/Auth/google.js +11 -34
- package/lib/Adapters/Auth/gpgames.js +5 -8
- package/lib/Adapters/Auth/httpsRequest.js +1 -7
- package/lib/Adapters/Auth/index.js +20 -65
- package/lib/Adapters/Auth/instagram.js +5 -9
- package/lib/Adapters/Auth/janraincapture.js +8 -12
- package/lib/Adapters/Auth/janrainengage.js +7 -11
- package/lib/Adapters/Auth/keycloak.js +5 -19
- package/lib/Adapters/Auth/ldap.js +1 -15
- package/lib/Adapters/Auth/line.js +7 -10
- package/lib/Adapters/Auth/linkedin.js +7 -12
- package/lib/Adapters/Auth/meetup.js +7 -10
- package/lib/Adapters/Auth/microsoft.js +7 -10
- package/lib/Adapters/Auth/oauth2.js +6 -18
- package/lib/Adapters/Auth/phantauth.js +8 -10
- package/lib/Adapters/Auth/qq.js +7 -13
- package/lib/Adapters/Auth/spotify.js +7 -14
- package/lib/Adapters/Auth/twitter.js +5 -15
- package/lib/Adapters/Auth/vkontakte.js +9 -15
- package/lib/Adapters/Auth/wechat.js +7 -10
- package/lib/Adapters/Auth/weibo.js +7 -11
- package/lib/Adapters/Cache/CacheAdapter.js +4 -12
- package/lib/Adapters/Cache/InMemoryCache.js +5 -19
- package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
- package/lib/Adapters/Cache/LRUCache.js +1 -11
- package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
- package/lib/Adapters/Cache/RedisCacheAdapter.js +46 -87
- package/lib/Adapters/Cache/SchemaCache.js +1 -6
- package/lib/Adapters/Email/MailAdapter.js +2 -7
- package/lib/Adapters/Files/FilesAdapter.js +7 -21
- package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
- package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
- package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
- package/lib/Adapters/Logger/WinstonLogger.js +3 -30
- package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
- package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
- package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
- package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
- package/lib/Adapters/PubSub/RedisPubSub.js +13 -10
- package/lib/Adapters/Push/PushAdapter.js +2 -8
- package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
- package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
- package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
- package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
- package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
- package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
- package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
- package/lib/Adapters/Storage/StorageAdapter.js +1 -1
- package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
- package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
- package/lib/Auth.js +54 -121
- package/lib/ClientSDK.js +3 -11
- package/lib/Config.js +69 -113
- package/lib/Controllers/AdaptableController.js +6 -18
- package/lib/Controllers/AnalyticsController.js +1 -9
- package/lib/Controllers/CacheController.js +3 -23
- package/lib/Controllers/DatabaseController.js +147 -345
- package/lib/Controllers/FilesController.js +5 -34
- package/lib/Controllers/HooksController.js +1 -51
- package/lib/Controllers/LiveQueryController.js +4 -23
- package/lib/Controllers/LoggerController.js +15 -54
- package/lib/Controllers/ParseGraphQLController.js +49 -104
- package/lib/Controllers/PushController.js +20 -59
- package/lib/Controllers/SchemaController.js +154 -344
- package/lib/Controllers/UserController.js +11 -72
- package/lib/Controllers/index.js +19 -68
- package/lib/Controllers/types.js +1 -1
- package/lib/Deprecator/Deprecations.js +1 -8
- package/lib/Deprecator/Deprecator.js +9 -18
- package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
- package/lib/GraphQL/ParseGraphQLServer.js +2 -29
- package/lib/GraphQL/helpers/objectsMutations.js +2 -12
- package/lib/GraphQL/helpers/objectsQueries.js +18 -76
- package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
- package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
- package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
- package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
- package/lib/GraphQL/loaders/filesMutations.js +2 -19
- package/lib/GraphQL/loaders/functionsMutations.js +6 -17
- package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
- package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
- package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
- package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
- package/lib/GraphQL/loaders/schemaMutations.js +1 -20
- package/lib/GraphQL/loaders/schemaQueries.js +1 -14
- package/lib/GraphQL/loaders/schemaTypes.js +2 -6
- package/lib/GraphQL/loaders/usersMutations.js +6 -28
- package/lib/GraphQL/loaders/usersQueries.js +4 -26
- package/lib/GraphQL/parseGraphQLUtils.js +6 -19
- package/lib/GraphQL/transformers/className.js +1 -4
- package/lib/GraphQL/transformers/constraintType.js +1 -20
- package/lib/GraphQL/transformers/inputType.js +1 -20
- package/lib/GraphQL/transformers/mutation.js +6 -51
- package/lib/GraphQL/transformers/outputType.js +1 -20
- package/lib/GraphQL/transformers/query.js +6 -42
- package/lib/GraphQL/transformers/schemaFields.js +7 -34
- package/lib/KeyPromiseQueue.js +1 -12
- package/lib/LiveQuery/Client.js +1 -25
- package/lib/LiveQuery/Id.js +1 -7
- package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
- package/lib/LiveQuery/ParseLiveQueryServer.js +92 -306
- package/lib/LiveQuery/ParsePubSub.js +1 -12
- package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
- package/lib/LiveQuery/QueryTools.js +14 -116
- package/lib/LiveQuery/RequestSchema.js +1 -1
- package/lib/LiveQuery/SessionTokenCache.js +1 -17
- package/lib/LiveQuery/Subscription.js +4 -18
- package/lib/LiveQuery/equalObjects.js +2 -14
- package/lib/Options/Definitions.js +79 -10
- package/lib/Options/docs.js +23 -3
- package/lib/Options/index.js +4 -12
- package/lib/Options/parsers.js +1 -18
- package/lib/Page.js +1 -9
- package/lib/ParseMessageQueue.js +1 -10
- package/lib/ParseServer.js +144 -182
- package/lib/ParseServerRESTController.js +6 -33
- package/lib/PromiseRouter.js +16 -50
- package/lib/Push/PushQueue.js +3 -15
- package/lib/Push/PushWorker.js +7 -32
- package/lib/Push/utils.js +9 -38
- package/lib/RestQuery.js +105 -242
- package/lib/RestWrite.js +212 -377
- package/lib/Routers/AggregateRouter.js +14 -51
- package/lib/Routers/AnalyticsRouter.js +2 -8
- package/lib/Routers/AudiencesRouter.js +1 -15
- package/lib/Routers/ClassesRouter.js +3 -53
- package/lib/Routers/CloudCodeRouter.js +1 -19
- package/lib/Routers/FeaturesRouter.js +1 -10
- package/lib/Routers/FilesRouter.js +29 -76
- package/lib/Routers/FunctionsRouter.js +5 -28
- package/lib/Routers/GlobalConfigRouter.js +4 -18
- package/lib/Routers/GraphQLRouter.js +1 -14
- package/lib/Routers/HooksRouter.js +1 -29
- package/lib/Routers/IAPValidationRouter.js +6 -29
- package/lib/Routers/InstallationsRouter.js +2 -12
- package/lib/Routers/LogsRouter.js +4 -16
- package/lib/Routers/PagesRouter.js +69 -129
- package/lib/Routers/PublicAPIRouter.js +3 -62
- package/lib/Routers/PurgeRouter.js +1 -15
- package/lib/Routers/PushRouter.js +2 -18
- package/lib/Routers/RolesRouter.js +1 -7
- package/lib/Routers/SchemasRouter.js +4 -34
- package/lib/Routers/SecurityRouter.js +1 -12
- package/lib/Routers/SessionsRouter.js +3 -19
- package/lib/Routers/UsersRouter.js +58 -155
- package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
- package/lib/SchemaMigrations/Migrations.js +2 -8
- package/lib/Security/Check.js +8 -16
- package/lib/Security/CheckGroup.js +4 -11
- package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
- package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
- package/lib/Security/CheckGroups/CheckGroups.js +1 -4
- package/lib/Security/CheckRunner.js +22 -41
- package/lib/StatusHandler.js +12 -69
- package/lib/TestUtils.js +1 -6
- package/lib/Utils.js +27 -66
- package/lib/batch.js +17 -28
- package/lib/cache.js +1 -3
- package/lib/cli/definitions/parse-live-query-server.js +1 -3
- package/lib/cli/definitions/parse-server.js +1 -3
- package/lib/cli/parse-live-query-server.js +1 -6
- package/lib/cli/parse-server.js +11 -21
- package/lib/cli/utils/commander.js +13 -51
- package/lib/cli/utils/runner.js +1 -14
- package/lib/cloud-code/Parse.Cloud.js +71 -92
- package/lib/cryptoUtils.js +11 -19
- package/lib/defaults.js +2 -14
- package/lib/deprecated.js +1 -2
- package/lib/index.js +16 -34
- package/lib/logger.js +6 -13
- package/lib/middlewares.js +147 -151
- package/lib/password.js +6 -10
- package/lib/request.js +173 -2
- package/lib/requiredParameter.js +1 -3
- package/lib/rest.js +19 -41
- package/lib/triggers.js +54 -252
- package/lib/vendor/mongodbUrl.js +125 -305
- package/package.json +22 -19
- package/lib/cloud-code/HTTPResponse.js +0 -73
- 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
|
|
21
|
-
|
|
22
|
-
function
|
|
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
|
-
}
|
|
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
|
-
}
|
|
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
|
-
}
|
|
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
|
-
}
|
|
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
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
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
|
-
|
|
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":"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"}
|