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
package/lib/password.js
CHANGED
|
@@ -3,36 +3,32 @@
|
|
|
3
3
|
// Tools for encrypting and decrypting passwords.
|
|
4
4
|
// Basically promise-friendly wrappers for bcrypt.
|
|
5
5
|
var bcrypt = require('bcryptjs');
|
|
6
|
-
|
|
7
6
|
try {
|
|
8
7
|
const _bcrypt = require('@node-rs/bcrypt');
|
|
9
|
-
|
|
10
8
|
bcrypt = {
|
|
11
9
|
hash: _bcrypt.hash,
|
|
12
10
|
compare: _bcrypt.verify
|
|
13
11
|
};
|
|
14
12
|
} catch (e) {
|
|
15
13
|
/* */
|
|
16
|
-
}
|
|
17
|
-
|
|
14
|
+
}
|
|
18
15
|
|
|
16
|
+
// Returns a promise for a hashed password string.
|
|
19
17
|
function hash(password) {
|
|
20
18
|
return bcrypt.hash(password, 10);
|
|
21
|
-
}
|
|
22
|
-
// hashed password.
|
|
23
|
-
|
|
19
|
+
}
|
|
24
20
|
|
|
21
|
+
// Returns a promise for whether this password compares to equal this
|
|
22
|
+
// hashed password.
|
|
25
23
|
function compare(password, hashedPassword) {
|
|
26
24
|
// Cannot bcrypt compare when one is undefined
|
|
27
25
|
if (!password || !hashedPassword) {
|
|
28
26
|
return Promise.resolve(false);
|
|
29
27
|
}
|
|
30
|
-
|
|
31
28
|
return bcrypt.compare(password, hashedPassword);
|
|
32
29
|
}
|
|
33
|
-
|
|
34
30
|
module.exports = {
|
|
35
31
|
hash: hash,
|
|
36
32
|
compare: compare
|
|
37
33
|
};
|
|
38
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJiY3J5cHQiLCJyZXF1aXJlIiwiX2JjcnlwdCIsImhhc2giLCJjb21wYXJlIiwidmVyaWZ5IiwiZSIsInBhc3N3b3JkIiwiaGFzaGVkUGFzc3dvcmQiLCJQcm9taXNlIiwicmVzb2x2ZSIsIm1vZHVsZSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi9zcmMvcGFzc3dvcmQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gVG9vbHMgZm9yIGVuY3J5cHRpbmcgYW5kIGRlY3J5cHRpbmcgcGFzc3dvcmRzLlxuLy8gQmFzaWNhbGx5IHByb21pc2UtZnJpZW5kbHkgd3JhcHBlcnMgZm9yIGJjcnlwdC5cbnZhciBiY3J5cHQgPSByZXF1aXJlKCdiY3J5cHRqcycpO1xuXG50cnkge1xuICBjb25zdCBfYmNyeXB0ID0gcmVxdWlyZSgnQG5vZGUtcnMvYmNyeXB0Jyk7XG4gIGJjcnlwdCA9IHtcbiAgICBoYXNoOiBfYmNyeXB0Lmhhc2gsXG4gICAgY29tcGFyZTogX2JjcnlwdC52ZXJpZnksXG4gIH07XG59IGNhdGNoIChlKSB7XG4gIC8qICovXG59XG5cbi8vIFJldHVybnMgYSBwcm9taXNlIGZvciBhIGhhc2hlZCBwYXNzd29yZCBzdHJpbmcuXG5mdW5jdGlvbiBoYXNoKHBhc3N3b3JkKSB7XG4gIHJldHVybiBiY3J5cHQuaGFzaChwYXNzd29yZCwgMTApO1xufVxuXG4vLyBSZXR1cm5zIGEgcHJvbWlzZSBmb3Igd2hldGhlciB0aGlzIHBhc3N3b3JkIGNvbXBhcmVzIHRvIGVxdWFsIHRoaXNcbi8vIGhhc2hlZCBwYXNzd29yZC5cbmZ1bmN0aW9uIGNvbXBhcmUocGFzc3dvcmQsIGhhc2hlZFBhc3N3b3JkKSB7XG4gIC8vIENhbm5vdCBiY3J5cHQgY29tcGFyZSB3aGVuIG9uZSBpcyB1bmRlZmluZWRcbiAgaWYgKCFwYXNzd29yZCB8fCAhaGFzaGVkUGFzc3dvcmQpIHtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKGZhbHNlKTtcbiAgfVxuICByZXR1cm4gYmNyeXB0LmNvbXBhcmUocGFzc3dvcmQsIGhhc2hlZFBhc3N3b3JkKTtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gIGhhc2g6IGhhc2gsXG4gIGNvbXBhcmU6IGNvbXBhcmUsXG59O1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBO0FBQ0E7QUFDQSxJQUFJQSxNQUFNLEdBQUdDLE9BQU8sQ0FBQyxVQUFVLENBQUM7QUFFaEMsSUFBSTtFQUNGLE1BQU1DLE9BQU8sR0FBR0QsT0FBTyxDQUFDLGlCQUFpQixDQUFDO0VBQzFDRCxNQUFNLEdBQUc7SUFDUEcsSUFBSSxFQUFFRCxPQUFPLENBQUNDLElBQUk7SUFDbEJDLE9BQU8sRUFBRUYsT0FBTyxDQUFDRztFQUNuQixDQUFDO0FBQ0gsQ0FBQyxDQUFDLE9BQU9DLENBQUMsRUFBRTtFQUNWO0FBQUE7O0FBR0Y7QUFDQSxTQUFTSCxJQUFJLENBQUNJLFFBQVEsRUFBRTtFQUN0QixPQUFPUCxNQUFNLENBQUNHLElBQUksQ0FBQ0ksUUFBUSxFQUFFLEVBQUUsQ0FBQztBQUNsQzs7QUFFQTtBQUNBO0FBQ0EsU0FBU0gsT0FBTyxDQUFDRyxRQUFRLEVBQUVDLGNBQWMsRUFBRTtFQUN6QztFQUNBLElBQUksQ0FBQ0QsUUFBUSxJQUFJLENBQUNDLGNBQWMsRUFBRTtJQUNoQyxPQUFPQyxPQUFPLENBQUNDLE9BQU8sQ0FBQyxLQUFLLENBQUM7RUFDL0I7RUFDQSxPQUFPVixNQUFNLENBQUNJLE9BQU8sQ0FBQ0csUUFBUSxFQUFFQyxjQUFjLENBQUM7QUFDakQ7QUFFQUcsTUFBTSxDQUFDQyxPQUFPLEdBQUc7RUFDZlQsSUFBSSxFQUFFQSxJQUFJO0VBQ1ZDLE9BQU8sRUFBRUE7QUFDWCxDQUFDIn0=
|
package/lib/request.js
CHANGED
|
@@ -1,4 +1,175 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
3
|
+
var _querystring = _interopRequireDefault(require("querystring"));
|
|
4
|
+
var _logger = _interopRequireDefault(require("./logger"));
|
|
5
|
+
var _followRedirects = require("follow-redirects");
|
|
6
|
+
var _url = require("url");
|
|
7
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
8
|
+
class HTTPResponse {
|
|
9
|
+
constructor(response, body) {
|
|
10
|
+
let _text, _data;
|
|
11
|
+
this.status = response.statusCode;
|
|
12
|
+
this.headers = response.headers || {};
|
|
13
|
+
this.cookies = this.headers['set-cookie'];
|
|
14
|
+
if (typeof body == 'string') {
|
|
15
|
+
_text = body;
|
|
16
|
+
} else if (Buffer.isBuffer(body)) {
|
|
17
|
+
this.buffer = body;
|
|
18
|
+
} else if (typeof body == 'object') {
|
|
19
|
+
_data = body;
|
|
20
|
+
}
|
|
21
|
+
const getText = () => {
|
|
22
|
+
if (!_text && this.buffer) {
|
|
23
|
+
_text = this.buffer.toString('utf-8');
|
|
24
|
+
} else if (!_text && _data) {
|
|
25
|
+
_text = JSON.stringify(_data);
|
|
26
|
+
}
|
|
27
|
+
return _text;
|
|
28
|
+
};
|
|
29
|
+
const getData = () => {
|
|
30
|
+
if (!_data) {
|
|
31
|
+
try {
|
|
32
|
+
_data = JSON.parse(getText());
|
|
33
|
+
} catch (e) {
|
|
34
|
+
/* */
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
return _data;
|
|
38
|
+
};
|
|
39
|
+
Object.defineProperty(this, 'body', {
|
|
40
|
+
get: () => {
|
|
41
|
+
return body;
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
Object.defineProperty(this, 'text', {
|
|
45
|
+
enumerable: true,
|
|
46
|
+
get: getText
|
|
47
|
+
});
|
|
48
|
+
Object.defineProperty(this, 'data', {
|
|
49
|
+
enumerable: true,
|
|
50
|
+
get: getData
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
const clients = {
|
|
55
|
+
'http:': _followRedirects.http,
|
|
56
|
+
'https:': _followRedirects.https
|
|
57
|
+
};
|
|
58
|
+
function makeCallback(resolve, reject) {
|
|
59
|
+
return function (response) {
|
|
60
|
+
const chunks = [];
|
|
61
|
+
response.on('data', chunk => {
|
|
62
|
+
chunks.push(chunk);
|
|
63
|
+
});
|
|
64
|
+
response.on('end', () => {
|
|
65
|
+
const body = Buffer.concat(chunks);
|
|
66
|
+
const httpResponse = new HTTPResponse(response, body);
|
|
67
|
+
|
|
68
|
+
// Consider <200 && >= 400 as errors
|
|
69
|
+
if (httpResponse.status < 200 || httpResponse.status >= 400) {
|
|
70
|
+
return reject(httpResponse);
|
|
71
|
+
} else {
|
|
72
|
+
return resolve(httpResponse);
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
response.on('error', reject);
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
const encodeBody = function ({
|
|
79
|
+
body,
|
|
80
|
+
headers = {}
|
|
81
|
+
}) {
|
|
82
|
+
if (typeof body !== 'object') {
|
|
83
|
+
return {
|
|
84
|
+
body,
|
|
85
|
+
headers
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
var contentTypeKeys = Object.keys(headers).filter(key => {
|
|
89
|
+
return key.match(/content-type/i) != null;
|
|
90
|
+
});
|
|
91
|
+
if (contentTypeKeys.length == 0) {
|
|
92
|
+
// no content type
|
|
93
|
+
// As per https://parse.com/docs/cloudcode/guide#cloud-code-advanced-sending-a-post-request the default encoding is supposedly x-www-form-urlencoded
|
|
94
|
+
|
|
95
|
+
body = _querystring.default.stringify(body);
|
|
96
|
+
headers['Content-Type'] = 'application/x-www-form-urlencoded';
|
|
97
|
+
} else {
|
|
98
|
+
/* istanbul ignore next */
|
|
99
|
+
if (contentTypeKeys.length > 1) {
|
|
100
|
+
_logger.default.error('Parse.Cloud.httpRequest', 'multiple content-type headers are set.');
|
|
101
|
+
}
|
|
102
|
+
// There maybe many, we'll just take the 1st one
|
|
103
|
+
var contentType = contentTypeKeys[0];
|
|
104
|
+
if (headers[contentType].match(/application\/json/i)) {
|
|
105
|
+
body = JSON.stringify(body);
|
|
106
|
+
} else if (headers[contentType].match(/application\/x-www-form-urlencoded/i)) {
|
|
107
|
+
body = _querystring.default.stringify(body);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return {
|
|
111
|
+
body,
|
|
112
|
+
headers
|
|
113
|
+
};
|
|
114
|
+
};
|
|
115
|
+
function httpRequest(options) {
|
|
116
|
+
let url;
|
|
117
|
+
try {
|
|
118
|
+
url = (0, _url.parse)(options.url);
|
|
119
|
+
} catch (e) {
|
|
120
|
+
return Promise.reject(e);
|
|
121
|
+
}
|
|
122
|
+
options = Object.assign(options, encodeBody(options));
|
|
123
|
+
// support params options
|
|
124
|
+
if (typeof options.params === 'object') {
|
|
125
|
+
options.qs = options.params;
|
|
126
|
+
} else if (typeof options.params === 'string') {
|
|
127
|
+
options.qs = _querystring.default.parse(options.params);
|
|
128
|
+
}
|
|
129
|
+
const client = clients[url.protocol];
|
|
130
|
+
if (!client) {
|
|
131
|
+
return Promise.reject(`Unsupported protocol ${url.protocol}`);
|
|
132
|
+
}
|
|
133
|
+
const requestOptions = {
|
|
134
|
+
method: options.method,
|
|
135
|
+
port: Number(url.port),
|
|
136
|
+
path: url.pathname,
|
|
137
|
+
hostname: url.hostname,
|
|
138
|
+
headers: options.headers,
|
|
139
|
+
encoding: null,
|
|
140
|
+
followRedirects: options.followRedirects === true
|
|
141
|
+
};
|
|
142
|
+
if (requestOptions.headers) {
|
|
143
|
+
Object.keys(requestOptions.headers).forEach(key => {
|
|
144
|
+
if (typeof requestOptions.headers[key] === 'undefined') {
|
|
145
|
+
delete requestOptions.headers[key];
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
if (url.search) {
|
|
150
|
+
options.qs = Object.assign({}, options.qs, _querystring.default.parse(url.query));
|
|
151
|
+
}
|
|
152
|
+
if (url.auth) {
|
|
153
|
+
requestOptions.auth = url.auth;
|
|
154
|
+
}
|
|
155
|
+
if (options.qs) {
|
|
156
|
+
requestOptions.path += `?${_querystring.default.stringify(options.qs)}`;
|
|
157
|
+
}
|
|
158
|
+
if (options.agent) {
|
|
159
|
+
requestOptions.agent = options.agent;
|
|
160
|
+
}
|
|
161
|
+
return new Promise((resolve, reject) => {
|
|
162
|
+
const req = client.request(requestOptions, makeCallback(resolve, reject, options));
|
|
163
|
+
if (options.body) {
|
|
164
|
+
req.write(options.body);
|
|
165
|
+
}
|
|
166
|
+
req.on('error', error => {
|
|
167
|
+
reject(error);
|
|
168
|
+
});
|
|
169
|
+
req.end();
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
module.exports = httpRequest;
|
|
173
|
+
module.exports.encodeBody = encodeBody;
|
|
174
|
+
module.exports.HTTPResponse = HTTPResponse;
|
|
175
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["HTTPResponse","constructor","response","body","_text","_data","status","statusCode","headers","cookies","Buffer","isBuffer","buffer","getText","toString","JSON","stringify","getData","parse","e","Object","defineProperty","get","enumerable","clients","http","https","makeCallback","resolve","reject","chunks","on","chunk","push","concat","httpResponse","encodeBody","contentTypeKeys","keys","filter","key","match","length","querystring","log","error","contentType","httpRequest","options","url","Promise","assign","params","qs","client","protocol","requestOptions","method","port","Number","path","pathname","hostname","encoding","followRedirects","forEach","search","query","auth","agent","req","request","write","end","module","exports"],"sources":["../src/request.js"],"sourcesContent":["import querystring from 'querystring';\nimport log from './logger';\nimport { http, https } from 'follow-redirects';\nimport { parse } from 'url';\n\nclass HTTPResponse {\n  constructor(response, body) {\n    let _text, _data;\n    this.status = response.statusCode;\n    this.headers = response.headers || {};\n    this.cookies = this.headers['set-cookie'];\n\n    if (typeof body == 'string') {\n      _text = body;\n    } else if (Buffer.isBuffer(body)) {\n      this.buffer = body;\n    } else if (typeof body == 'object') {\n      _data = body;\n    }\n\n    const getText = () => {\n      if (!_text && this.buffer) {\n        _text = this.buffer.toString('utf-8');\n      } else if (!_text && _data) {\n        _text = JSON.stringify(_data);\n      }\n      return _text;\n    };\n\n    const getData = () => {\n      if (!_data) {\n        try {\n          _data = JSON.parse(getText());\n        } catch (e) {\n          /* */\n        }\n      }\n      return _data;\n    };\n\n    Object.defineProperty(this, 'body', {\n      get: () => {\n        return body;\n      },\n    });\n\n    Object.defineProperty(this, 'text', {\n      enumerable: true,\n      get: getText,\n    });\n\n    Object.defineProperty(this, 'data', {\n      enumerable: true,\n      get: getData,\n    });\n  }\n}\n\nconst clients = {\n  'http:': http,\n  'https:': https,\n};\n\nfunction makeCallback(resolve, reject) {\n  return function (response) {\n    const chunks = [];\n    response.on('data', chunk => {\n      chunks.push(chunk);\n    });\n    response.on('end', () => {\n      const body = Buffer.concat(chunks);\n      const httpResponse = new HTTPResponse(response, body);\n\n      // Consider <200 && >= 400 as errors\n      if (httpResponse.status < 200 || httpResponse.status >= 400) {\n        return reject(httpResponse);\n      } else {\n        return resolve(httpResponse);\n      }\n    });\n    response.on('error', reject);\n  };\n}\n\nconst encodeBody = function ({ body, headers = {} }) {\n  if (typeof body !== 'object') {\n    return { body, headers };\n  }\n  var contentTypeKeys = Object.keys(headers).filter(key => {\n    return key.match(/content-type/i) != null;\n  });\n\n  if (contentTypeKeys.length == 0) {\n    // no content type\n    //  As per https://parse.com/docs/cloudcode/guide#cloud-code-advanced-sending-a-post-request the default encoding is supposedly x-www-form-urlencoded\n\n    body = querystring.stringify(body);\n    headers['Content-Type'] = 'application/x-www-form-urlencoded';\n  } else {\n    /* istanbul ignore next */\n    if (contentTypeKeys.length > 1) {\n      log.error('Parse.Cloud.httpRequest', 'multiple content-type headers are set.');\n    }\n    // There maybe many, we'll just take the 1st one\n    var contentType = contentTypeKeys[0];\n    if (headers[contentType].match(/application\\/json/i)) {\n      body = JSON.stringify(body);\n    } else if (headers[contentType].match(/application\\/x-www-form-urlencoded/i)) {\n      body = querystring.stringify(body);\n    }\n  }\n  return { body, headers };\n};\n\nfunction httpRequest(options) {\n  let url;\n  try {\n    url = parse(options.url);\n  } catch (e) {\n    return Promise.reject(e);\n  }\n  options = Object.assign(options, encodeBody(options));\n  // support params options\n  if (typeof options.params === 'object') {\n    options.qs = options.params;\n  } else if (typeof options.params === 'string') {\n    options.qs = querystring.parse(options.params);\n  }\n  const client = clients[url.protocol];\n  if (!client) {\n    return Promise.reject(`Unsupported protocol ${url.protocol}`);\n  }\n  const requestOptions = {\n    method: options.method,\n    port: Number(url.port),\n    path: url.pathname,\n    hostname: url.hostname,\n    headers: options.headers,\n    encoding: null,\n    followRedirects: options.followRedirects === true,\n  };\n  if (requestOptions.headers) {\n    Object.keys(requestOptions.headers).forEach(key => {\n      if (typeof requestOptions.headers[key] === 'undefined') {\n        delete requestOptions.headers[key];\n      }\n    });\n  }\n  if (url.search) {\n    options.qs = Object.assign({}, options.qs, querystring.parse(url.query));\n  }\n  if (url.auth) {\n    requestOptions.auth = url.auth;\n  }\n  if (options.qs) {\n    requestOptions.path += `?${querystring.stringify(options.qs)}`;\n  }\n  if (options.agent) {\n    requestOptions.agent = options.agent;\n  }\n  return new Promise((resolve, reject) => {\n    const req = client.request(requestOptions, makeCallback(resolve, reject, options));\n    if (options.body) {\n      req.write(options.body);\n    }\n    req.on('error', error => {\n      reject(error);\n    });\n    req.end();\n  });\n}\nmodule.exports = httpRequest;\nmodule.exports.encodeBody = encodeBody;\nmodule.exports.HTTPResponse = HTTPResponse;\n"],"mappings":";;AAAA;AACA;AACA;AACA;AAA4B;AAE5B,MAAMA,YAAY,CAAC;EACjBC,WAAW,CAACC,QAAQ,EAAEC,IAAI,EAAE;IAC1B,IAAIC,KAAK,EAAEC,KAAK;IAChB,IAAI,CAACC,MAAM,GAAGJ,QAAQ,CAACK,UAAU;IACjC,IAAI,CAACC,OAAO,GAAGN,QAAQ,CAACM,OAAO,IAAI,CAAC,CAAC;IACrC,IAAI,CAACC,OAAO,GAAG,IAAI,CAACD,OAAO,CAAC,YAAY,CAAC;IAEzC,IAAI,OAAOL,IAAI,IAAI,QAAQ,EAAE;MAC3BC,KAAK,GAAGD,IAAI;IACd,CAAC,MAAM,IAAIO,MAAM,CAACC,QAAQ,CAACR,IAAI,CAAC,EAAE;MAChC,IAAI,CAACS,MAAM,GAAGT,IAAI;IACpB,CAAC,MAAM,IAAI,OAAOA,IAAI,IAAI,QAAQ,EAAE;MAClCE,KAAK,GAAGF,IAAI;IACd;IAEA,MAAMU,OAAO,GAAG,MAAM;MACpB,IAAI,CAACT,KAAK,IAAI,IAAI,CAACQ,MAAM,EAAE;QACzBR,KAAK,GAAG,IAAI,CAACQ,MAAM,CAACE,QAAQ,CAAC,OAAO,CAAC;MACvC,CAAC,MAAM,IAAI,CAACV,KAAK,IAAIC,KAAK,EAAE;QAC1BD,KAAK,GAAGW,IAAI,CAACC,SAAS,CAACX,KAAK,CAAC;MAC/B;MACA,OAAOD,KAAK;IACd,CAAC;IAED,MAAMa,OAAO,GAAG,MAAM;MACpB,IAAI,CAACZ,KAAK,EAAE;QACV,IAAI;UACFA,KAAK,GAAGU,IAAI,CAACG,KAAK,CAACL,OAAO,EAAE,CAAC;QAC/B,CAAC,CAAC,OAAOM,CAAC,EAAE;UACV;QAAA;MAEJ;MACA,OAAOd,KAAK;IACd,CAAC;IAEDe,MAAM,CAACC,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE;MAClCC,GAAG,EAAE,MAAM;QACT,OAAOnB,IAAI;MACb;IACF,CAAC,CAAC;IAEFiB,MAAM,CAACC,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE;MAClCE,UAAU,EAAE,IAAI;MAChBD,GAAG,EAAET;IACP,CAAC,CAAC;IAEFO,MAAM,CAACC,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE;MAClCE,UAAU,EAAE,IAAI;MAChBD,GAAG,EAAEL;IACP,CAAC,CAAC;EACJ;AACF;AAEA,MAAMO,OAAO,GAAG;EACd,OAAO,EAAEC,qBAAI;EACb,QAAQ,EAAEC;AACZ,CAAC;AAED,SAASC,YAAY,CAACC,OAAO,EAAEC,MAAM,EAAE;EACrC,OAAO,UAAU3B,QAAQ,EAAE;IACzB,MAAM4B,MAAM,GAAG,EAAE;IACjB5B,QAAQ,CAAC6B,EAAE,CAAC,MAAM,EAAEC,KAAK,IAAI;MAC3BF,MAAM,CAACG,IAAI,CAACD,KAAK,CAAC;IACpB,CAAC,CAAC;IACF9B,QAAQ,CAAC6B,EAAE,CAAC,KAAK,EAAE,MAAM;MACvB,MAAM5B,IAAI,GAAGO,MAAM,CAACwB,MAAM,CAACJ,MAAM,CAAC;MAClC,MAAMK,YAAY,GAAG,IAAInC,YAAY,CAACE,QAAQ,EAAEC,IAAI,CAAC;;MAErD;MACA,IAAIgC,YAAY,CAAC7B,MAAM,GAAG,GAAG,IAAI6B,YAAY,CAAC7B,MAAM,IAAI,GAAG,EAAE;QAC3D,OAAOuB,MAAM,CAACM,YAAY,CAAC;MAC7B,CAAC,MAAM;QACL,OAAOP,OAAO,CAACO,YAAY,CAAC;MAC9B;IACF,CAAC,CAAC;IACFjC,QAAQ,CAAC6B,EAAE,CAAC,OAAO,EAAEF,MAAM,CAAC;EAC9B,CAAC;AACH;AAEA,MAAMO,UAAU,GAAG,UAAU;EAAEjC,IAAI;EAAEK,OAAO,GAAG,CAAC;AAAE,CAAC,EAAE;EACnD,IAAI,OAAOL,IAAI,KAAK,QAAQ,EAAE;IAC5B,OAAO;MAAEA,IAAI;MAAEK;IAAQ,CAAC;EAC1B;EACA,IAAI6B,eAAe,GAAGjB,MAAM,CAACkB,IAAI,CAAC9B,OAAO,CAAC,CAAC+B,MAAM,CAACC,GAAG,IAAI;IACvD,OAAOA,GAAG,CAACC,KAAK,CAAC,eAAe,CAAC,IAAI,IAAI;EAC3C,CAAC,CAAC;EAEF,IAAIJ,eAAe,CAACK,MAAM,IAAI,CAAC,EAAE;IAC/B;IACA;;IAEAvC,IAAI,GAAGwC,oBAAW,CAAC3B,SAAS,CAACb,IAAI,CAAC;IAClCK,OAAO,CAAC,cAAc,CAAC,GAAG,mCAAmC;EAC/D,CAAC,MAAM;IACL;IACA,IAAI6B,eAAe,CAACK,MAAM,GAAG,CAAC,EAAE;MAC9BE,eAAG,CAACC,KAAK,CAAC,yBAAyB,EAAE,wCAAwC,CAAC;IAChF;IACA;IACA,IAAIC,WAAW,GAAGT,eAAe,CAAC,CAAC,CAAC;IACpC,IAAI7B,OAAO,CAACsC,WAAW,CAAC,CAACL,KAAK,CAAC,oBAAoB,CAAC,EAAE;MACpDtC,IAAI,GAAGY,IAAI,CAACC,SAAS,CAACb,IAAI,CAAC;IAC7B,CAAC,MAAM,IAAIK,OAAO,CAACsC,WAAW,CAAC,CAACL,KAAK,CAAC,qCAAqC,CAAC,EAAE;MAC5EtC,IAAI,GAAGwC,oBAAW,CAAC3B,SAAS,CAACb,IAAI,CAAC;IACpC;EACF;EACA,OAAO;IAAEA,IAAI;IAAEK;EAAQ,CAAC;AAC1B,CAAC;AAED,SAASuC,WAAW,CAACC,OAAO,EAAE;EAC5B,IAAIC,GAAG;EACP,IAAI;IACFA,GAAG,GAAG,IAAA/B,UAAK,EAAC8B,OAAO,CAACC,GAAG,CAAC;EAC1B,CAAC,CAAC,OAAO9B,CAAC,EAAE;IACV,OAAO+B,OAAO,CAACrB,MAAM,CAACV,CAAC,CAAC;EAC1B;EACA6B,OAAO,GAAG5B,MAAM,CAAC+B,MAAM,CAACH,OAAO,EAAEZ,UAAU,CAACY,OAAO,CAAC,CAAC;EACrD;EACA,IAAI,OAAOA,OAAO,CAACI,MAAM,KAAK,QAAQ,EAAE;IACtCJ,OAAO,CAACK,EAAE,GAAGL,OAAO,CAACI,MAAM;EAC7B,CAAC,MAAM,IAAI,OAAOJ,OAAO,CAACI,MAAM,KAAK,QAAQ,EAAE;IAC7CJ,OAAO,CAACK,EAAE,GAAGV,oBAAW,CAACzB,KAAK,CAAC8B,OAAO,CAACI,MAAM,CAAC;EAChD;EACA,MAAME,MAAM,GAAG9B,OAAO,CAACyB,GAAG,CAACM,QAAQ,CAAC;EACpC,IAAI,CAACD,MAAM,EAAE;IACX,OAAOJ,OAAO,CAACrB,MAAM,CAAE,wBAAuBoB,GAAG,CAACM,QAAS,EAAC,CAAC;EAC/D;EACA,MAAMC,cAAc,GAAG;IACrBC,MAAM,EAAET,OAAO,CAACS,MAAM;IACtBC,IAAI,EAAEC,MAAM,CAACV,GAAG,CAACS,IAAI,CAAC;IACtBE,IAAI,EAAEX,GAAG,CAACY,QAAQ;IAClBC,QAAQ,EAAEb,GAAG,CAACa,QAAQ;IACtBtD,OAAO,EAAEwC,OAAO,CAACxC,OAAO;IACxBuD,QAAQ,EAAE,IAAI;IACdC,eAAe,EAAEhB,OAAO,CAACgB,eAAe,KAAK;EAC/C,CAAC;EACD,IAAIR,cAAc,CAAChD,OAAO,EAAE;IAC1BY,MAAM,CAACkB,IAAI,CAACkB,cAAc,CAAChD,OAAO,CAAC,CAACyD,OAAO,CAACzB,GAAG,IAAI;MACjD,IAAI,OAAOgB,cAAc,CAAChD,OAAO,CAACgC,GAAG,CAAC,KAAK,WAAW,EAAE;QACtD,OAAOgB,cAAc,CAAChD,OAAO,CAACgC,GAAG,CAAC;MACpC;IACF,CAAC,CAAC;EACJ;EACA,IAAIS,GAAG,CAACiB,MAAM,EAAE;IACdlB,OAAO,CAACK,EAAE,GAAGjC,MAAM,CAAC+B,MAAM,CAAC,CAAC,CAAC,EAAEH,OAAO,CAACK,EAAE,EAAEV,oBAAW,CAACzB,KAAK,CAAC+B,GAAG,CAACkB,KAAK,CAAC,CAAC;EAC1E;EACA,IAAIlB,GAAG,CAACmB,IAAI,EAAE;IACZZ,cAAc,CAACY,IAAI,GAAGnB,GAAG,CAACmB,IAAI;EAChC;EACA,IAAIpB,OAAO,CAACK,EAAE,EAAE;IACdG,cAAc,CAACI,IAAI,IAAK,IAAGjB,oBAAW,CAAC3B,SAAS,CAACgC,OAAO,CAACK,EAAE,CAAE,EAAC;EAChE;EACA,IAAIL,OAAO,CAACqB,KAAK,EAAE;IACjBb,cAAc,CAACa,KAAK,GAAGrB,OAAO,CAACqB,KAAK;EACtC;EACA,OAAO,IAAInB,OAAO,CAAC,CAACtB,OAAO,EAAEC,MAAM,KAAK;IACtC,MAAMyC,GAAG,GAAGhB,MAAM,CAACiB,OAAO,CAACf,cAAc,EAAE7B,YAAY,CAACC,OAAO,EAAEC,MAAM,EAAEmB,OAAO,CAAC,CAAC;IAClF,IAAIA,OAAO,CAAC7C,IAAI,EAAE;MAChBmE,GAAG,CAACE,KAAK,CAACxB,OAAO,CAAC7C,IAAI,CAAC;IACzB;IACAmE,GAAG,CAACvC,EAAE,CAAC,OAAO,EAAEc,KAAK,IAAI;MACvBhB,MAAM,CAACgB,KAAK,CAAC;IACf,CAAC,CAAC;IACFyB,GAAG,CAACG,GAAG,EAAE;EACX,CAAC,CAAC;AACJ;AACAC,MAAM,CAACC,OAAO,GAAG5B,WAAW;AAC5B2B,MAAM,CAACC,OAAO,CAACvC,UAAU,GAAGA,UAAU;AACtCsC,MAAM,CAACC,OAAO,CAAC3E,YAAY,GAAGA,YAAY"}
|
package/lib/requiredParameter.js
CHANGED
|
@@ -4,10 +4,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _default = errorMessage => {
|
|
9
8
|
throw errorMessage;
|
|
10
9
|
};
|
|
11
|
-
|
|
12
10
|
exports.default = _default;
|
|
13
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJlcnJvck1lc3NhZ2UiXSwic291cmNlcyI6WyIuLi9zcmMvcmVxdWlyZWRQYXJhbWV0ZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBmbG93ICovXG5leHBvcnQgZGVmYXVsdCAoZXJyb3JNZXNzYWdlOiBzdHJpbmcpOiBhbnkgPT4ge1xuICB0aHJvdyBlcnJvck1lc3NhZ2U7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7ZUFDZ0JBLFlBQW9CLElBQVU7RUFDNUMsTUFBTUEsWUFBWTtBQUNwQixDQUFDO0FBQUEifQ==
|
package/lib/rest.js
CHANGED
|
@@ -8,25 +8,21 @@
|
|
|
8
8
|
// This means that one of these handlers can support multiple
|
|
9
9
|
// routes. That's useful for the routes that do really similar
|
|
10
10
|
// things.
|
|
11
|
-
var Parse = require('parse/node').Parse;
|
|
12
11
|
|
|
12
|
+
var Parse = require('parse/node').Parse;
|
|
13
13
|
var RestQuery = require('./RestQuery');
|
|
14
|
-
|
|
15
14
|
var RestWrite = require('./RestWrite');
|
|
16
|
-
|
|
17
15
|
var triggers = require('./triggers');
|
|
18
|
-
|
|
19
16
|
function checkTriggers(className, config, types) {
|
|
20
17
|
return types.some(triggerType => {
|
|
21
18
|
return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);
|
|
22
19
|
});
|
|
23
20
|
}
|
|
24
|
-
|
|
25
21
|
function checkLiveQuery(className, config) {
|
|
26
22
|
return config.liveQueryController && config.liveQueryController.hasLiveQuery(className);
|
|
27
|
-
}
|
|
28
|
-
|
|
23
|
+
}
|
|
29
24
|
|
|
25
|
+
// Returns a promise for an object with optional keys 'results' and 'count'.
|
|
30
26
|
function find(config, auth, className, restWhere, restOptions, clientSDK, context) {
|
|
31
27
|
enforceRoleSecurity('find', className, auth);
|
|
32
28
|
return triggers.maybeRunQueryTrigger(triggers.Types.beforeFind, className, restWhere, restOptions, config, auth, context).then(result => {
|
|
@@ -35,9 +31,9 @@ function find(config, auth, className, restWhere, restOptions, clientSDK, contex
|
|
|
35
31
|
const query = new RestQuery(config, auth, className, restWhere, restOptions, clientSDK, true, context);
|
|
36
32
|
return query.execute();
|
|
37
33
|
});
|
|
38
|
-
}
|
|
39
|
-
|
|
34
|
+
}
|
|
40
35
|
|
|
36
|
+
// get is just like find but only queries an objectId.
|
|
41
37
|
const get = (config, auth, className, objectId, restOptions, clientSDK, context) => {
|
|
42
38
|
var restWhere = {
|
|
43
39
|
objectId
|
|
@@ -49,25 +45,22 @@ const get = (config, auth, className, objectId, restOptions, clientSDK, context)
|
|
|
49
45
|
const query = new RestQuery(config, auth, className, restWhere, restOptions, clientSDK, true, context);
|
|
50
46
|
return query.execute();
|
|
51
47
|
});
|
|
52
|
-
};
|
|
53
|
-
|
|
48
|
+
};
|
|
54
49
|
|
|
50
|
+
// Returns a promise that doesn't resolve to any useful value.
|
|
55
51
|
function del(config, auth, className, objectId, context) {
|
|
56
52
|
if (typeof objectId !== 'string') {
|
|
57
53
|
throw new Parse.Error(Parse.Error.INVALID_JSON, 'bad objectId');
|
|
58
54
|
}
|
|
59
|
-
|
|
60
55
|
if (className === '_User' && auth.isUnauthenticated()) {
|
|
61
56
|
throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');
|
|
62
57
|
}
|
|
63
|
-
|
|
64
58
|
enforceRoleSecurity('delete', className, auth);
|
|
65
59
|
let inflatedObject;
|
|
66
60
|
let schemaController;
|
|
67
61
|
return Promise.resolve().then(() => {
|
|
68
62
|
const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);
|
|
69
63
|
const hasLiveQuery = checkLiveQuery(className, config);
|
|
70
|
-
|
|
71
64
|
if (hasTriggers || hasLiveQuery || className == '_Session') {
|
|
72
65
|
return new RestQuery(config, auth, className, {
|
|
73
66
|
objectId
|
|
@@ -77,23 +70,19 @@ function del(config, auth, className, objectId, context) {
|
|
|
77
70
|
if (response && response.results && response.results.length) {
|
|
78
71
|
const firstResult = response.results[0];
|
|
79
72
|
firstResult.className = className;
|
|
80
|
-
|
|
81
73
|
if (className === '_Session' && !auth.isMaster) {
|
|
82
74
|
if (!auth.user || firstResult.user.objectId !== auth.user.id) {
|
|
83
75
|
throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
|
|
84
76
|
}
|
|
85
77
|
}
|
|
86
|
-
|
|
87
78
|
var cacheAdapter = config.cacheController;
|
|
88
79
|
cacheAdapter.user.del(firstResult.sessionToken);
|
|
89
80
|
inflatedObject = Parse.Object.fromJSON(firstResult);
|
|
90
81
|
return triggers.maybeRunTrigger(triggers.Types.beforeDelete, auth, inflatedObject, null, config, context);
|
|
91
82
|
}
|
|
92
|
-
|
|
93
83
|
throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found for delete.');
|
|
94
84
|
});
|
|
95
85
|
}
|
|
96
|
-
|
|
97
86
|
return Promise.resolve({});
|
|
98
87
|
}).then(() => {
|
|
99
88
|
if (!auth.isMaster) {
|
|
@@ -104,16 +93,13 @@ function del(config, auth, className, objectId, context) {
|
|
|
104
93
|
}).then(() => config.database.loadSchema()).then(s => {
|
|
105
94
|
schemaController = s;
|
|
106
95
|
const options = {};
|
|
107
|
-
|
|
108
96
|
if (!auth.isMaster) {
|
|
109
97
|
options.acl = ['*'];
|
|
110
|
-
|
|
111
98
|
if (auth.user) {
|
|
112
99
|
options.acl.push(auth.user.id);
|
|
113
100
|
options.acl = options.acl.concat(auth.userRoles);
|
|
114
101
|
}
|
|
115
102
|
}
|
|
116
|
-
|
|
117
103
|
return config.database.destroy(className, {
|
|
118
104
|
objectId: objectId
|
|
119
105
|
}, options, schemaController);
|
|
@@ -125,79 +111,71 @@ function del(config, auth, className, objectId, context) {
|
|
|
125
111
|
}).catch(error => {
|
|
126
112
|
handleSessionMissingError(error, className, auth);
|
|
127
113
|
});
|
|
128
|
-
}
|
|
129
|
-
|
|
114
|
+
}
|
|
130
115
|
|
|
116
|
+
// Returns a promise for a {response, status, location} object.
|
|
131
117
|
function create(config, auth, className, restObject, clientSDK, context) {
|
|
132
118
|
enforceRoleSecurity('create', className, auth);
|
|
133
119
|
var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);
|
|
134
120
|
return write.execute();
|
|
135
|
-
}
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
// Returns a promise that contains the fields of the update that the
|
|
136
124
|
// REST API is supposed to return.
|
|
137
125
|
// Usually, this is just updatedAt.
|
|
138
|
-
|
|
139
|
-
|
|
140
126
|
function update(config, auth, className, restWhere, restObject, clientSDK, context) {
|
|
141
127
|
enforceRoleSecurity('update', className, auth);
|
|
142
128
|
return Promise.resolve().then(() => {
|
|
143
129
|
const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);
|
|
144
130
|
const hasLiveQuery = checkLiveQuery(className, config);
|
|
145
|
-
|
|
146
131
|
if (hasTriggers || hasLiveQuery) {
|
|
147
132
|
// Do not use find, as it runs the before finds
|
|
148
133
|
return new RestQuery(config, auth, className, restWhere, undefined, undefined, false, context).execute({
|
|
149
134
|
op: 'update'
|
|
150
135
|
});
|
|
151
136
|
}
|
|
152
|
-
|
|
153
137
|
return Promise.resolve({});
|
|
154
138
|
}).then(({
|
|
155
139
|
results
|
|
156
140
|
}) => {
|
|
157
141
|
var originalRestObject;
|
|
158
|
-
|
|
159
142
|
if (results && results.length) {
|
|
160
143
|
originalRestObject = results[0];
|
|
161
144
|
}
|
|
162
|
-
|
|
163
145
|
return new RestWrite(config, auth, className, restWhere, restObject, originalRestObject, clientSDK, context, 'update').execute();
|
|
164
146
|
}).catch(error => {
|
|
165
147
|
handleSessionMissingError(error, className, auth);
|
|
166
148
|
});
|
|
167
149
|
}
|
|
168
|
-
|
|
169
150
|
function handleSessionMissingError(error, className, auth) {
|
|
170
151
|
// If we're trying to update a user without / with bad session token
|
|
171
152
|
if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster) {
|
|
172
153
|
throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth.');
|
|
173
154
|
}
|
|
174
|
-
|
|
175
155
|
throw error;
|
|
176
156
|
}
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
157
|
+
const classesWithMasterOnlyAccess = ['_JobStatus', '_PushStatus', '_Hooks', '_GlobalConfig', '_JobSchedule', '_Idempotency'];
|
|
158
|
+
// Disallowing access to the _Role collection except by master key
|
|
180
159
|
function enforceRoleSecurity(method, className, auth) {
|
|
181
160
|
if (className === '_Installation' && !auth.isMaster) {
|
|
182
161
|
if (method === 'delete' || method === 'find') {
|
|
183
162
|
const error = `Clients aren't allowed to perform the ${method} operation on the installation collection.`;
|
|
184
163
|
throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
|
|
185
164
|
}
|
|
186
|
-
}
|
|
187
|
-
|
|
165
|
+
}
|
|
188
166
|
|
|
167
|
+
//all volatileClasses are masterKey only
|
|
189
168
|
if (classesWithMasterOnlyAccess.indexOf(className) >= 0 && !auth.isMaster) {
|
|
190
169
|
const error = `Clients aren't allowed to perform the ${method} operation on the ${className} collection.`;
|
|
191
170
|
throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
|
|
192
|
-
}
|
|
193
|
-
|
|
171
|
+
}
|
|
194
172
|
|
|
173
|
+
// readOnly masterKey is not allowed
|
|
195
174
|
if (auth.isReadOnly && (method === 'delete' || method === 'create' || method === 'update')) {
|
|
196
175
|
const error = `read-only masterKey isn't allowed to perform the ${method} operation.`;
|
|
197
176
|
throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
|
|
198
177
|
}
|
|
199
178
|
}
|
|
200
|
-
|
|
201
179
|
module.exports = {
|
|
202
180
|
create,
|
|
203
181
|
del,
|
|
@@ -205,4 +183,4 @@ module.exports = {
|
|
|
205
183
|
get,
|
|
206
184
|
update
|
|
207
185
|
};
|
|
208
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/rest.js"],"names":["Parse","require","RestQuery","RestWrite","triggers","checkTriggers","className","config","types","some","triggerType","getTrigger","Types","applicationId","checkLiveQuery","liveQueryController","hasLiveQuery","find","auth","restWhere","restOptions","clientSDK","context","enforceRoleSecurity","maybeRunQueryTrigger","beforeFind","then","result","query","execute","get","objectId","del","Error","INVALID_JSON","isUnauthenticated","SESSION_MISSING","inflatedObject","schemaController","Promise","resolve","hasTriggers","op","response","results","length","firstResult","isMaster","user","id","INVALID_SESSION_TOKEN","cacheAdapter","cacheController","sessionToken","Object","fromJSON","maybeRunTrigger","beforeDelete","OBJECT_NOT_FOUND","getUserRoles","database","loadSchema","s","options","acl","push","concat","userRoles","destroy","perms","getClassLevelPermissions","onAfterDelete","afterDelete","catch","error","handleSessionMissingError","create","restObject","write","update","undefined","originalRestObject","code","classesWithMasterOnlyAccess","method","OPERATION_FORBIDDEN","indexOf","isReadOnly","module","exports"],"mappings":"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","sourcesContent":["// This file contains helpers for running operations in REST format.\n// The goal is that handlers that explicitly handle an express route\n// should just be shallow wrappers around things in this file, but\n// these functions should not explicitly depend on the request\n// object.\n// This means that one of these handlers can support multiple\n// routes. That's useful for the routes that do really similar\n// things.\n\nvar Parse = require('parse/node').Parse;\n\nvar RestQuery = require('./RestQuery');\nvar RestWrite = require('./RestWrite');\nvar triggers = require('./triggers');\n\nfunction checkTriggers(className, config, types) {\n  return types.some(triggerType => {\n    return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);\n  });\n}\n\nfunction checkLiveQuery(className, config) {\n  return config.liveQueryController && config.liveQueryController.hasLiveQuery(className);\n}\n\n// Returns a promise for an object with optional keys 'results' and 'count'.\nfunction find(config, auth, className, restWhere, restOptions, clientSDK, context) {\n  enforceRoleSecurity('find', className, auth);\n  return triggers\n    .maybeRunQueryTrigger(\n      triggers.Types.beforeFind,\n      className,\n      restWhere,\n      restOptions,\n      config,\n      auth,\n      context\n    )\n    .then(result => {\n      restWhere = result.restWhere || restWhere;\n      restOptions = result.restOptions || restOptions;\n      const query = new RestQuery(\n        config,\n        auth,\n        className,\n        restWhere,\n        restOptions,\n        clientSDK,\n        true,\n        context\n      );\n      return query.execute();\n    });\n}\n\n// get is just like find but only queries an objectId.\nconst get = (config, auth, className, objectId, restOptions, clientSDK, context) => {\n  var restWhere = { objectId };\n  enforceRoleSecurity('get', className, auth);\n  return triggers\n    .maybeRunQueryTrigger(\n      triggers.Types.beforeFind,\n      className,\n      restWhere,\n      restOptions,\n      config,\n      auth,\n      context,\n      true\n    )\n    .then(result => {\n      restWhere = result.restWhere || restWhere;\n      restOptions = result.restOptions || restOptions;\n      const query = new RestQuery(\n        config,\n        auth,\n        className,\n        restWhere,\n        restOptions,\n        clientSDK,\n        true,\n        context\n      );\n      return query.execute();\n    });\n};\n\n// Returns a promise that doesn't resolve to any useful value.\nfunction del(config, auth, className, objectId, context) {\n  if (typeof objectId !== 'string') {\n    throw new Parse.Error(Parse.Error.INVALID_JSON, 'bad objectId');\n  }\n\n  if (className === '_User' && auth.isUnauthenticated()) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');\n  }\n\n  enforceRoleSecurity('delete', className, auth);\n\n  let inflatedObject;\n  let schemaController;\n\n  return Promise.resolve()\n    .then(() => {\n      const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery || className == '_Session') {\n        return new RestQuery(config, auth, className, { objectId })\n          .execute({ op: 'delete' })\n          .then(response => {\n            if (response && response.results && response.results.length) {\n              const firstResult = response.results[0];\n              firstResult.className = className;\n              if (className === '_Session' && !auth.isMaster) {\n                if (!auth.user || firstResult.user.objectId !== auth.user.id) {\n                  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n                }\n              }\n              var cacheAdapter = config.cacheController;\n              cacheAdapter.user.del(firstResult.sessionToken);\n              inflatedObject = Parse.Object.fromJSON(firstResult);\n              return triggers.maybeRunTrigger(\n                triggers.Types.beforeDelete,\n                auth,\n                inflatedObject,\n                null,\n                config,\n                context\n              );\n            }\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found for delete.');\n          });\n      }\n      return Promise.resolve({});\n    })\n    .then(() => {\n      if (!auth.isMaster) {\n        return auth.getUserRoles();\n      } else {\n        return;\n      }\n    })\n    .then(() => config.database.loadSchema())\n    .then(s => {\n      schemaController = s;\n      const options = {};\n      if (!auth.isMaster) {\n        options.acl = ['*'];\n        if (auth.user) {\n          options.acl.push(auth.user.id);\n          options.acl = options.acl.concat(auth.userRoles);\n        }\n      }\n\n      return config.database.destroy(\n        className,\n        {\n          objectId: objectId,\n        },\n        options,\n        schemaController\n      );\n    })\n    .then(() => {\n      // Notify LiveQuery server if possible\n      const perms = schemaController.getClassLevelPermissions(className);\n      config.liveQueryController.onAfterDelete(className, inflatedObject, null, perms);\n      return triggers.maybeRunTrigger(\n        triggers.Types.afterDelete,\n        auth,\n        inflatedObject,\n        null,\n        config,\n        context\n      );\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\n// Returns a promise for a {response, status, location} object.\nfunction create(config, auth, className, restObject, clientSDK, context) {\n  enforceRoleSecurity('create', className, auth);\n  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);\n  return write.execute();\n}\n\n// Returns a promise that contains the fields of the update that the\n// REST API is supposed to return.\n// Usually, this is just updatedAt.\nfunction update(config, auth, className, restWhere, restObject, clientSDK, context) {\n  enforceRoleSecurity('update', className, auth);\n\n  return Promise.resolve()\n    .then(() => {\n      const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery) {\n        // Do not use find, as it runs the before finds\n        return new RestQuery(\n          config,\n          auth,\n          className,\n          restWhere,\n          undefined,\n          undefined,\n          false,\n          context\n        ).execute({\n          op: 'update',\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(({ results }) => {\n      var originalRestObject;\n      if (results && results.length) {\n        originalRestObject = results[0];\n      }\n      return new RestWrite(\n        config,\n        auth,\n        className,\n        restWhere,\n        restObject,\n        originalRestObject,\n        clientSDK,\n        context,\n        'update'\n      ).execute();\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\nfunction handleSessionMissingError(error, className, auth) {\n  // If we're trying to update a user without / with bad session token\n  if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth.');\n  }\n  throw error;\n}\n\nconst classesWithMasterOnlyAccess = [\n  '_JobStatus',\n  '_PushStatus',\n  '_Hooks',\n  '_GlobalConfig',\n  '_JobSchedule',\n  '_Idempotency',\n];\n// Disallowing access to the _Role collection except by master key\nfunction enforceRoleSecurity(method, className, auth) {\n  if (className === '_Installation' && !auth.isMaster) {\n    if (method === 'delete' || method === 'find') {\n      const error = `Clients aren't allowed to perform the ${method} operation on the installation collection.`;\n      throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n    }\n  }\n\n  //all volatileClasses are masterKey only\n  if (classesWithMasterOnlyAccess.indexOf(className) >= 0 && !auth.isMaster) {\n    const error = `Clients aren't allowed to perform the ${method} operation on the ${className} collection.`;\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n  }\n\n  // readOnly masterKey is not allowed\n  if (auth.isReadOnly && (method === 'delete' || method === 'create' || method === 'update')) {\n    const error = `read-only masterKey isn't allowed to perform the ${method} operation.`;\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n  }\n}\n\nmodule.exports = {\n  create,\n  del,\n  find,\n  get,\n  update,\n};\n"]}
|
|
186
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","RestQuery","RestWrite","triggers","checkTriggers","className","config","types","some","triggerType","getTrigger","Types","applicationId","checkLiveQuery","liveQueryController","hasLiveQuery","find","auth","restWhere","restOptions","clientSDK","context","enforceRoleSecurity","maybeRunQueryTrigger","beforeFind","then","result","query","execute","get","objectId","del","Error","INVALID_JSON","isUnauthenticated","SESSION_MISSING","inflatedObject","schemaController","Promise","resolve","hasTriggers","op","response","results","length","firstResult","isMaster","user","id","INVALID_SESSION_TOKEN","cacheAdapter","cacheController","sessionToken","Object","fromJSON","maybeRunTrigger","beforeDelete","OBJECT_NOT_FOUND","getUserRoles","database","loadSchema","s","options","acl","push","concat","userRoles","destroy","perms","getClassLevelPermissions","onAfterDelete","afterDelete","catch","error","handleSessionMissingError","create","restObject","write","update","undefined","originalRestObject","code","classesWithMasterOnlyAccess","method","OPERATION_FORBIDDEN","indexOf","isReadOnly","module","exports"],"sources":["../src/rest.js"],"sourcesContent":["// This file contains helpers for running operations in REST format.\n// The goal is that handlers that explicitly handle an express route\n// should just be shallow wrappers around things in this file, but\n// these functions should not explicitly depend on the request\n// object.\n// This means that one of these handlers can support multiple\n// routes. That's useful for the routes that do really similar\n// things.\n\nvar Parse = require('parse/node').Parse;\n\nvar RestQuery = require('./RestQuery');\nvar RestWrite = require('./RestWrite');\nvar triggers = require('./triggers');\n\nfunction checkTriggers(className, config, types) {\n  return types.some(triggerType => {\n    return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);\n  });\n}\n\nfunction checkLiveQuery(className, config) {\n  return config.liveQueryController && config.liveQueryController.hasLiveQuery(className);\n}\n\n// Returns a promise for an object with optional keys 'results' and 'count'.\nfunction find(config, auth, className, restWhere, restOptions, clientSDK, context) {\n  enforceRoleSecurity('find', className, auth);\n  return triggers\n    .maybeRunQueryTrigger(\n      triggers.Types.beforeFind,\n      className,\n      restWhere,\n      restOptions,\n      config,\n      auth,\n      context\n    )\n    .then(result => {\n      restWhere = result.restWhere || restWhere;\n      restOptions = result.restOptions || restOptions;\n      const query = new RestQuery(\n        config,\n        auth,\n        className,\n        restWhere,\n        restOptions,\n        clientSDK,\n        true,\n        context\n      );\n      return query.execute();\n    });\n}\n\n// get is just like find but only queries an objectId.\nconst get = (config, auth, className, objectId, restOptions, clientSDK, context) => {\n  var restWhere = { objectId };\n  enforceRoleSecurity('get', className, auth);\n  return triggers\n    .maybeRunQueryTrigger(\n      triggers.Types.beforeFind,\n      className,\n      restWhere,\n      restOptions,\n      config,\n      auth,\n      context,\n      true\n    )\n    .then(result => {\n      restWhere = result.restWhere || restWhere;\n      restOptions = result.restOptions || restOptions;\n      const query = new RestQuery(\n        config,\n        auth,\n        className,\n        restWhere,\n        restOptions,\n        clientSDK,\n        true,\n        context\n      );\n      return query.execute();\n    });\n};\n\n// Returns a promise that doesn't resolve to any useful value.\nfunction del(config, auth, className, objectId, context) {\n  if (typeof objectId !== 'string') {\n    throw new Parse.Error(Parse.Error.INVALID_JSON, 'bad objectId');\n  }\n\n  if (className === '_User' && auth.isUnauthenticated()) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');\n  }\n\n  enforceRoleSecurity('delete', className, auth);\n\n  let inflatedObject;\n  let schemaController;\n\n  return Promise.resolve()\n    .then(() => {\n      const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery || className == '_Session') {\n        return new RestQuery(config, auth, className, { objectId })\n          .execute({ op: 'delete' })\n          .then(response => {\n            if (response && response.results && response.results.length) {\n              const firstResult = response.results[0];\n              firstResult.className = className;\n              if (className === '_Session' && !auth.isMaster) {\n                if (!auth.user || firstResult.user.objectId !== auth.user.id) {\n                  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n                }\n              }\n              var cacheAdapter = config.cacheController;\n              cacheAdapter.user.del(firstResult.sessionToken);\n              inflatedObject = Parse.Object.fromJSON(firstResult);\n              return triggers.maybeRunTrigger(\n                triggers.Types.beforeDelete,\n                auth,\n                inflatedObject,\n                null,\n                config,\n                context\n              );\n            }\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found for delete.');\n          });\n      }\n      return Promise.resolve({});\n    })\n    .then(() => {\n      if (!auth.isMaster) {\n        return auth.getUserRoles();\n      } else {\n        return;\n      }\n    })\n    .then(() => config.database.loadSchema())\n    .then(s => {\n      schemaController = s;\n      const options = {};\n      if (!auth.isMaster) {\n        options.acl = ['*'];\n        if (auth.user) {\n          options.acl.push(auth.user.id);\n          options.acl = options.acl.concat(auth.userRoles);\n        }\n      }\n\n      return config.database.destroy(\n        className,\n        {\n          objectId: objectId,\n        },\n        options,\n        schemaController\n      );\n    })\n    .then(() => {\n      // Notify LiveQuery server if possible\n      const perms = schemaController.getClassLevelPermissions(className);\n      config.liveQueryController.onAfterDelete(className, inflatedObject, null, perms);\n      return triggers.maybeRunTrigger(\n        triggers.Types.afterDelete,\n        auth,\n        inflatedObject,\n        null,\n        config,\n        context\n      );\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\n// Returns a promise for a {response, status, location} object.\nfunction create(config, auth, className, restObject, clientSDK, context) {\n  enforceRoleSecurity('create', className, auth);\n  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);\n  return write.execute();\n}\n\n// Returns a promise that contains the fields of the update that the\n// REST API is supposed to return.\n// Usually, this is just updatedAt.\nfunction update(config, auth, className, restWhere, restObject, clientSDK, context) {\n  enforceRoleSecurity('update', className, auth);\n\n  return Promise.resolve()\n    .then(() => {\n      const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery) {\n        // Do not use find, as it runs the before finds\n        return new RestQuery(\n          config,\n          auth,\n          className,\n          restWhere,\n          undefined,\n          undefined,\n          false,\n          context\n        ).execute({\n          op: 'update',\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(({ results }) => {\n      var originalRestObject;\n      if (results && results.length) {\n        originalRestObject = results[0];\n      }\n      return new RestWrite(\n        config,\n        auth,\n        className,\n        restWhere,\n        restObject,\n        originalRestObject,\n        clientSDK,\n        context,\n        'update'\n      ).execute();\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\nfunction handleSessionMissingError(error, className, auth) {\n  // If we're trying to update a user without / with bad session token\n  if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth.');\n  }\n  throw error;\n}\n\nconst classesWithMasterOnlyAccess = [\n  '_JobStatus',\n  '_PushStatus',\n  '_Hooks',\n  '_GlobalConfig',\n  '_JobSchedule',\n  '_Idempotency',\n];\n// Disallowing access to the _Role collection except by master key\nfunction enforceRoleSecurity(method, className, auth) {\n  if (className === '_Installation' && !auth.isMaster) {\n    if (method === 'delete' || method === 'find') {\n      const error = `Clients aren't allowed to perform the ${method} operation on the installation collection.`;\n      throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n    }\n  }\n\n  //all volatileClasses are masterKey only\n  if (classesWithMasterOnlyAccess.indexOf(className) >= 0 && !auth.isMaster) {\n    const error = `Clients aren't allowed to perform the ${method} operation on the ${className} collection.`;\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n  }\n\n  // readOnly masterKey is not allowed\n  if (auth.isReadOnly && (method === 'delete' || method === 'create' || method === 'update')) {\n    const error = `read-only masterKey isn't allowed to perform the ${method} operation.`;\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n  }\n}\n\nmodule.exports = {\n  create,\n  del,\n  find,\n  get,\n  update,\n};\n"],"mappings":";;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,IAAIA,KAAK,GAAGC,OAAO,CAAC,YAAY,CAAC,CAACD,KAAK;AAEvC,IAAIE,SAAS,GAAGD,OAAO,CAAC,aAAa,CAAC;AACtC,IAAIE,SAAS,GAAGF,OAAO,CAAC,aAAa,CAAC;AACtC,IAAIG,QAAQ,GAAGH,OAAO,CAAC,YAAY,CAAC;AAEpC,SAASI,aAAa,CAACC,SAAS,EAAEC,MAAM,EAAEC,KAAK,EAAE;EAC/C,OAAOA,KAAK,CAACC,IAAI,CAACC,WAAW,IAAI;IAC/B,OAAON,QAAQ,CAACO,UAAU,CAACL,SAAS,EAAEF,QAAQ,CAACQ,KAAK,CAACF,WAAW,CAAC,EAAEH,MAAM,CAACM,aAAa,CAAC;EAC1F,CAAC,CAAC;AACJ;AAEA,SAASC,cAAc,CAACR,SAAS,EAAEC,MAAM,EAAE;EACzC,OAAOA,MAAM,CAACQ,mBAAmB,IAAIR,MAAM,CAACQ,mBAAmB,CAACC,YAAY,CAACV,SAAS,CAAC;AACzF;;AAEA;AACA,SAASW,IAAI,CAACV,MAAM,EAAEW,IAAI,EAAEZ,SAAS,EAAEa,SAAS,EAAEC,WAAW,EAAEC,SAAS,EAAEC,OAAO,EAAE;EACjFC,mBAAmB,CAAC,MAAM,EAAEjB,SAAS,EAAEY,IAAI,CAAC;EAC5C,OAAOd,QAAQ,CACZoB,oBAAoB,CACnBpB,QAAQ,CAACQ,KAAK,CAACa,UAAU,EACzBnB,SAAS,EACTa,SAAS,EACTC,WAAW,EACXb,MAAM,EACNW,IAAI,EACJI,OAAO,CACR,CACAI,IAAI,CAACC,MAAM,IAAI;IACdR,SAAS,GAAGQ,MAAM,CAACR,SAAS,IAAIA,SAAS;IACzCC,WAAW,GAAGO,MAAM,CAACP,WAAW,IAAIA,WAAW;IAC/C,MAAMQ,KAAK,GAAG,IAAI1B,SAAS,CACzBK,MAAM,EACNW,IAAI,EACJZ,SAAS,EACTa,SAAS,EACTC,WAAW,EACXC,SAAS,EACT,IAAI,EACJC,OAAO,CACR;IACD,OAAOM,KAAK,CAACC,OAAO,EAAE;EACxB,CAAC,CAAC;AACN;;AAEA;AACA,MAAMC,GAAG,GAAG,CAACvB,MAAM,EAAEW,IAAI,EAAEZ,SAAS,EAAEyB,QAAQ,EAAEX,WAAW,EAAEC,SAAS,EAAEC,OAAO,KAAK;EAClF,IAAIH,SAAS,GAAG;IAAEY;EAAS,CAAC;EAC5BR,mBAAmB,CAAC,KAAK,EAAEjB,SAAS,EAAEY,IAAI,CAAC;EAC3C,OAAOd,QAAQ,CACZoB,oBAAoB,CACnBpB,QAAQ,CAACQ,KAAK,CAACa,UAAU,EACzBnB,SAAS,EACTa,SAAS,EACTC,WAAW,EACXb,MAAM,EACNW,IAAI,EACJI,OAAO,EACP,IAAI,CACL,CACAI,IAAI,CAACC,MAAM,IAAI;IACdR,SAAS,GAAGQ,MAAM,CAACR,SAAS,IAAIA,SAAS;IACzCC,WAAW,GAAGO,MAAM,CAACP,WAAW,IAAIA,WAAW;IAC/C,MAAMQ,KAAK,GAAG,IAAI1B,SAAS,CACzBK,MAAM,EACNW,IAAI,EACJZ,SAAS,EACTa,SAAS,EACTC,WAAW,EACXC,SAAS,EACT,IAAI,EACJC,OAAO,CACR;IACD,OAAOM,KAAK,CAACC,OAAO,EAAE;EACxB,CAAC,CAAC;AACN,CAAC;;AAED;AACA,SAASG,GAAG,CAACzB,MAAM,EAAEW,IAAI,EAAEZ,SAAS,EAAEyB,QAAQ,EAAET,OAAO,EAAE;EACvD,IAAI,OAAOS,QAAQ,KAAK,QAAQ,EAAE;IAChC,MAAM,IAAI/B,KAAK,CAACiC,KAAK,CAACjC,KAAK,CAACiC,KAAK,CAACC,YAAY,EAAE,cAAc,CAAC;EACjE;EAEA,IAAI5B,SAAS,KAAK,OAAO,IAAIY,IAAI,CAACiB,iBAAiB,EAAE,EAAE;IACrD,MAAM,IAAInC,KAAK,CAACiC,KAAK,CAACjC,KAAK,CAACiC,KAAK,CAACG,eAAe,EAAE,kCAAkC,CAAC;EACxF;EAEAb,mBAAmB,CAAC,QAAQ,EAAEjB,SAAS,EAAEY,IAAI,CAAC;EAE9C,IAAImB,cAAc;EAClB,IAAIC,gBAAgB;EAEpB,OAAOC,OAAO,CAACC,OAAO,EAAE,CACrBd,IAAI,CAAC,MAAM;IACV,MAAMe,WAAW,GAAGpC,aAAa,CAACC,SAAS,EAAEC,MAAM,EAAE,CAAC,cAAc,EAAE,aAAa,CAAC,CAAC;IACrF,MAAMS,YAAY,GAAGF,cAAc,CAACR,SAAS,EAAEC,MAAM,CAAC;IACtD,IAAIkC,WAAW,IAAIzB,YAAY,IAAIV,SAAS,IAAI,UAAU,EAAE;MAC1D,OAAO,IAAIJ,SAAS,CAACK,MAAM,EAAEW,IAAI,EAAEZ,SAAS,EAAE;QAAEyB;MAAS,CAAC,CAAC,CACxDF,OAAO,CAAC;QAAEa,EAAE,EAAE;MAAS,CAAC,CAAC,CACzBhB,IAAI,CAACiB,QAAQ,IAAI;QAChB,IAAIA,QAAQ,IAAIA,QAAQ,CAACC,OAAO,IAAID,QAAQ,CAACC,OAAO,CAACC,MAAM,EAAE;UAC3D,MAAMC,WAAW,GAAGH,QAAQ,CAACC,OAAO,CAAC,CAAC,CAAC;UACvCE,WAAW,CAACxC,SAAS,GAAGA,SAAS;UACjC,IAAIA,SAAS,KAAK,UAAU,IAAI,CAACY,IAAI,CAAC6B,QAAQ,EAAE;YAC9C,IAAI,CAAC7B,IAAI,CAAC8B,IAAI,IAAIF,WAAW,CAACE,IAAI,CAACjB,QAAQ,KAAKb,IAAI,CAAC8B,IAAI,CAACC,EAAE,EAAE;cAC5D,MAAM,IAAIjD,KAAK,CAACiC,KAAK,CAACjC,KAAK,CAACiC,KAAK,CAACiB,qBAAqB,EAAE,uBAAuB,CAAC;YACnF;UACF;UACA,IAAIC,YAAY,GAAG5C,MAAM,CAAC6C,eAAe;UACzCD,YAAY,CAACH,IAAI,CAAChB,GAAG,CAACc,WAAW,CAACO,YAAY,CAAC;UAC/ChB,cAAc,GAAGrC,KAAK,CAACsD,MAAM,CAACC,QAAQ,CAACT,WAAW,CAAC;UACnD,OAAO1C,QAAQ,CAACoD,eAAe,CAC7BpD,QAAQ,CAACQ,KAAK,CAAC6C,YAAY,EAC3BvC,IAAI,EACJmB,cAAc,EACd,IAAI,EACJ9B,MAAM,EACNe,OAAO,CACR;QACH;QACA,MAAM,IAAItB,KAAK,CAACiC,KAAK,CAACjC,KAAK,CAACiC,KAAK,CAACyB,gBAAgB,EAAE,8BAA8B,CAAC;MACrF,CAAC,CAAC;IACN;IACA,OAAOnB,OAAO,CAACC,OAAO,CAAC,CAAC,CAAC,CAAC;EAC5B,CAAC,CAAC,CACDd,IAAI,CAAC,MAAM;IACV,IAAI,CAACR,IAAI,CAAC6B,QAAQ,EAAE;MAClB,OAAO7B,IAAI,CAACyC,YAAY,EAAE;IAC5B,CAAC,MAAM;MACL;IACF;EACF,CAAC,CAAC,CACDjC,IAAI,CAAC,MAAMnB,MAAM,CAACqD,QAAQ,CAACC,UAAU,EAAE,CAAC,CACxCnC,IAAI,CAACoC,CAAC,IAAI;IACTxB,gBAAgB,GAAGwB,CAAC;IACpB,MAAMC,OAAO,GAAG,CAAC,CAAC;IAClB,IAAI,CAAC7C,IAAI,CAAC6B,QAAQ,EAAE;MAClBgB,OAAO,CAACC,GAAG,GAAG,CAAC,GAAG,CAAC;MACnB,IAAI9C,IAAI,CAAC8B,IAAI,EAAE;QACbe,OAAO,CAACC,GAAG,CAACC,IAAI,CAAC/C,IAAI,CAAC8B,IAAI,CAACC,EAAE,CAAC;QAC9Bc,OAAO,CAACC,GAAG,GAAGD,OAAO,CAACC,GAAG,CAACE,MAAM,CAAChD,IAAI,CAACiD,SAAS,CAAC;MAClD;IACF;IAEA,OAAO5D,MAAM,CAACqD,QAAQ,CAACQ,OAAO,CAC5B9D,SAAS,EACT;MACEyB,QAAQ,EAAEA;IACZ,CAAC,EACDgC,OAAO,EACPzB,gBAAgB,CACjB;EACH,CAAC,CAAC,CACDZ,IAAI,CAAC,MAAM;IACV;IACA,MAAM2C,KAAK,GAAG/B,gBAAgB,CAACgC,wBAAwB,CAAChE,SAAS,CAAC;IAClEC,MAAM,CAACQ,mBAAmB,CAACwD,aAAa,CAACjE,SAAS,EAAE+B,cAAc,EAAE,IAAI,EAAEgC,KAAK,CAAC;IAChF,OAAOjE,QAAQ,CAACoD,eAAe,CAC7BpD,QAAQ,CAACQ,KAAK,CAAC4D,WAAW,EAC1BtD,IAAI,EACJmB,cAAc,EACd,IAAI,EACJ9B,MAAM,EACNe,OAAO,CACR;EACH,CAAC,CAAC,CACDmD,KAAK,CAACC,KAAK,IAAI;IACdC,yBAAyB,CAACD,KAAK,EAAEpE,SAAS,EAAEY,IAAI,CAAC;EACnD,CAAC,CAAC;AACN;;AAEA;AACA,SAAS0D,MAAM,CAACrE,MAAM,EAAEW,IAAI,EAAEZ,SAAS,EAAEuE,UAAU,EAAExD,SAAS,EAAEC,OAAO,EAAE;EACvEC,mBAAmB,CAAC,QAAQ,EAAEjB,SAAS,EAAEY,IAAI,CAAC;EAC9C,IAAI4D,KAAK,GAAG,IAAI3E,SAAS,CAACI,MAAM,EAAEW,IAAI,EAAEZ,SAAS,EAAE,IAAI,EAAEuE,UAAU,EAAE,IAAI,EAAExD,SAAS,EAAEC,OAAO,CAAC;EAC9F,OAAOwD,KAAK,CAACjD,OAAO,EAAE;AACxB;;AAEA;AACA;AACA;AACA,SAASkD,MAAM,CAACxE,MAAM,EAAEW,IAAI,EAAEZ,SAAS,EAAEa,SAAS,EAAE0D,UAAU,EAAExD,SAAS,EAAEC,OAAO,EAAE;EAClFC,mBAAmB,CAAC,QAAQ,EAAEjB,SAAS,EAAEY,IAAI,CAAC;EAE9C,OAAOqB,OAAO,CAACC,OAAO,EAAE,CACrBd,IAAI,CAAC,MAAM;IACV,MAAMe,WAAW,GAAGpC,aAAa,CAACC,SAAS,EAAEC,MAAM,EAAE,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;IACjF,MAAMS,YAAY,GAAGF,cAAc,CAACR,SAAS,EAAEC,MAAM,CAAC;IACtD,IAAIkC,WAAW,IAAIzB,YAAY,EAAE;MAC/B;MACA,OAAO,IAAId,SAAS,CAClBK,MAAM,EACNW,IAAI,EACJZ,SAAS,EACTa,SAAS,EACT6D,SAAS,EACTA,SAAS,EACT,KAAK,EACL1D,OAAO,CACR,CAACO,OAAO,CAAC;QACRa,EAAE,EAAE;MACN,CAAC,CAAC;IACJ;IACA,OAAOH,OAAO,CAACC,OAAO,CAAC,CAAC,CAAC,CAAC;EAC5B,CAAC,CAAC,CACDd,IAAI,CAAC,CAAC;IAAEkB;EAAQ,CAAC,KAAK;IACrB,IAAIqC,kBAAkB;IACtB,IAAIrC,OAAO,IAAIA,OAAO,CAACC,MAAM,EAAE;MAC7BoC,kBAAkB,GAAGrC,OAAO,CAAC,CAAC,CAAC;IACjC;IACA,OAAO,IAAIzC,SAAS,CAClBI,MAAM,EACNW,IAAI,EACJZ,SAAS,EACTa,SAAS,EACT0D,UAAU,EACVI,kBAAkB,EAClB5D,SAAS,EACTC,OAAO,EACP,QAAQ,CACT,CAACO,OAAO,EAAE;EACb,CAAC,CAAC,CACD4C,KAAK,CAACC,KAAK,IAAI;IACdC,yBAAyB,CAACD,KAAK,EAAEpE,SAAS,EAAEY,IAAI,CAAC;EACnD,CAAC,CAAC;AACN;AAEA,SAASyD,yBAAyB,CAACD,KAAK,EAAEpE,SAAS,EAAEY,IAAI,EAAE;EACzD;EACA,IAAIZ,SAAS,KAAK,OAAO,IAAIoE,KAAK,CAACQ,IAAI,KAAKlF,KAAK,CAACiC,KAAK,CAACyB,gBAAgB,IAAI,CAACxC,IAAI,CAAC6B,QAAQ,EAAE;IAC1F,MAAM,IAAI/C,KAAK,CAACiC,KAAK,CAACjC,KAAK,CAACiC,KAAK,CAACG,eAAe,EAAE,oBAAoB,CAAC;EAC1E;EACA,MAAMsC,KAAK;AACb;AAEA,MAAMS,2BAA2B,GAAG,CAClC,YAAY,EACZ,aAAa,EACb,QAAQ,EACR,eAAe,EACf,cAAc,EACd,cAAc,CACf;AACD;AACA,SAAS5D,mBAAmB,CAAC6D,MAAM,EAAE9E,SAAS,EAAEY,IAAI,EAAE;EACpD,IAAIZ,SAAS,KAAK,eAAe,IAAI,CAACY,IAAI,CAAC6B,QAAQ,EAAE;IACnD,IAAIqC,MAAM,KAAK,QAAQ,IAAIA,MAAM,KAAK,MAAM,EAAE;MAC5C,MAAMV,KAAK,GAAI,yCAAwCU,MAAO,4CAA2C;MACzG,MAAM,IAAIpF,KAAK,CAACiC,KAAK,CAACjC,KAAK,CAACiC,KAAK,CAACoD,mBAAmB,EAAEX,KAAK,CAAC;IAC/D;EACF;;EAEA;EACA,IAAIS,2BAA2B,CAACG,OAAO,CAAChF,SAAS,CAAC,IAAI,CAAC,IAAI,CAACY,IAAI,CAAC6B,QAAQ,EAAE;IACzE,MAAM2B,KAAK,GAAI,yCAAwCU,MAAO,qBAAoB9E,SAAU,cAAa;IACzG,MAAM,IAAIN,KAAK,CAACiC,KAAK,CAACjC,KAAK,CAACiC,KAAK,CAACoD,mBAAmB,EAAEX,KAAK,CAAC;EAC/D;;EAEA;EACA,IAAIxD,IAAI,CAACqE,UAAU,KAAKH,MAAM,KAAK,QAAQ,IAAIA,MAAM,KAAK,QAAQ,IAAIA,MAAM,KAAK,QAAQ,CAAC,EAAE;IAC1F,MAAMV,KAAK,GAAI,oDAAmDU,MAAO,aAAY;IACrF,MAAM,IAAIpF,KAAK,CAACiC,KAAK,CAACjC,KAAK,CAACiC,KAAK,CAACoD,mBAAmB,EAAEX,KAAK,CAAC;EAC/D;AACF;AAEAc,MAAM,CAACC,OAAO,GAAG;EACfb,MAAM;EACN5C,GAAG;EACHf,IAAI;EACJa,GAAG;EACHiD;AACF,CAAC"}
|