parse-server 8.5.0-alpha.15 → 8.5.0-alpha.16

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/lib/Error.js CHANGED
@@ -15,14 +15,14 @@ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e
15
15
  * @param {string} detailedMessage - The detailed error message to log server-side
16
16
  * @returns {Parse.Error} A Parse.Error with sanitized message
17
17
  */
18
- function createSanitizedError(errorCode, detailedMessage) {
18
+ function createSanitizedError(errorCode, detailedMessage, config) {
19
19
  // On testing we need to add a prefix to the message to allow to find the correct call in the TestUtils.js file
20
20
  if (process.env.TESTING) {
21
21
  _logger.default.error('Sanitized error:', detailedMessage);
22
22
  } else {
23
23
  _logger.default.error(detailedMessage);
24
24
  }
25
- return new Parse.Error(errorCode, 'Permission denied');
25
+ return new Parse.Error(errorCode, config?.enableSanitizedErrorResponse !== false ? 'Permission denied' : detailedMessage);
26
26
  }
27
27
 
28
28
  /**
@@ -33,7 +33,7 @@ function createSanitizedError(errorCode, detailedMessage) {
33
33
  * @param {string} detailedMessage - The detailed error message to log server-side
34
34
  * @returns {Error} An Error with sanitized message
35
35
  */
36
- function createSanitizedHttpError(statusCode, detailedMessage) {
36
+ function createSanitizedHttpError(statusCode, detailedMessage, config) {
37
37
  // On testing we need to add a prefix to the message to allow to find the correct call in the TestUtils.js file
38
38
  if (process.env.TESTING) {
39
39
  _logger.default.error('Sanitized error:', detailedMessage);
@@ -42,7 +42,7 @@ function createSanitizedHttpError(statusCode, detailedMessage) {
42
42
  }
43
43
  const error = new Error();
44
44
  error.status = statusCode;
45
- error.message = 'Permission denied';
45
+ error.message = config?.enableSanitizedErrorResponse !== false ? 'Permission denied' : detailedMessage;
46
46
  return error;
47
47
  }
48
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbG9nZ2VyIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJjcmVhdGVTYW5pdGl6ZWRFcnJvciIsImVycm9yQ29kZSIsImRldGFpbGVkTWVzc2FnZSIsInByb2Nlc3MiLCJlbnYiLCJURVNUSU5HIiwiZGVmYXVsdExvZ2dlciIsImVycm9yIiwiUGFyc2UiLCJFcnJvciIsImNyZWF0ZVNhbml0aXplZEh0dHBFcnJvciIsInN0YXR1c0NvZGUiLCJzdGF0dXMiLCJtZXNzYWdlIl0sInNvdXJjZXMiOlsiLi4vc3JjL0Vycm9yLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkZWZhdWx0TG9nZ2VyIGZyb20gJy4vbG9nZ2VyJztcblxuLyoqXG4gKiBDcmVhdGVzIGEgc2FuaXRpemVkIGVycm9yIHRoYXQgaGlkZXMgZGV0YWlsZWQgaW5mb3JtYXRpb24gZnJvbSBjbGllbnRzXG4gKiB3aGlsZSBsb2dnaW5nIHRoZSBkZXRhaWxlZCBtZXNzYWdlIHNlcnZlci1zaWRlLlxuICpcbiAqIEBwYXJhbSB7bnVtYmVyfSBlcnJvckNvZGUgLSBUaGUgUGFyc2UuRXJyb3IgY29kZSAoZS5nLiwgUGFyc2UuRXJyb3IuT1BFUkFUSU9OX0ZPUkJJRERFTilcbiAqIEBwYXJhbSB7c3RyaW5nfSBkZXRhaWxlZE1lc3NhZ2UgLSBUaGUgZGV0YWlsZWQgZXJyb3IgbWVzc2FnZSB0byBsb2cgc2VydmVyLXNpZGVcbiAqIEByZXR1cm5zIHtQYXJzZS5FcnJvcn0gQSBQYXJzZS5FcnJvciB3aXRoIHNhbml0aXplZCBtZXNzYWdlXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVNhbml0aXplZEVycm9yKGVycm9yQ29kZSwgZGV0YWlsZWRNZXNzYWdlKSB7XG4gIC8vIE9uIHRlc3Rpbmcgd2UgbmVlZCB0byBhZGQgYSBwcmVmaXggdG8gdGhlIG1lc3NhZ2UgdG8gYWxsb3cgdG8gZmluZCB0aGUgY29ycmVjdCBjYWxsIGluIHRoZSBUZXN0VXRpbHMuanMgZmlsZVxuICBpZiAocHJvY2Vzcy5lbnYuVEVTVElORykge1xuICAgIGRlZmF1bHRMb2dnZXIuZXJyb3IoJ1Nhbml0aXplZCBlcnJvcjonLCBkZXRhaWxlZE1lc3NhZ2UpO1xuICB9IGVsc2Uge1xuICAgIGRlZmF1bHRMb2dnZXIuZXJyb3IoZGV0YWlsZWRNZXNzYWdlKTtcbiAgfVxuXG4gIHJldHVybiBuZXcgUGFyc2UuRXJyb3IoZXJyb3JDb2RlLCAnUGVybWlzc2lvbiBkZW5pZWQnKTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgc2FuaXRpemVkIGVycm9yIGZyb20gYSByZWd1bGFyIEVycm9yIG9iamVjdFxuICogVXNlZCBmb3Igbm9uLVBhcnNlLkVycm9yIGVycm9ycyAoZS5nLiwgRXhwcmVzcyBlcnJvcnMpXG4gKlxuICogQHBhcmFtIHtudW1iZXJ9IHN0YXR1c0NvZGUgLSBIVFRQIHN0YXR1cyBjb2RlIChlLmcuLCA0MDMpXG4gKiBAcGFyYW0ge3N0cmluZ30gZGV0YWlsZWRNZXNzYWdlIC0gVGhlIGRldGFpbGVkIGVycm9yIG1lc3NhZ2UgdG8gbG9nIHNlcnZlci1zaWRlXG4gKiBAcmV0dXJucyB7RXJyb3J9IEFuIEVycm9yIHdpdGggc2FuaXRpemVkIG1lc3NhZ2VcbiAqL1xuZnVuY3Rpb24gY3JlYXRlU2FuaXRpemVkSHR0cEVycm9yKHN0YXR1c0NvZGUsIGRldGFpbGVkTWVzc2FnZSkge1xuICAvLyBPbiB0ZXN0aW5nIHdlIG5lZWQgdG8gYWRkIGEgcHJlZml4IHRvIHRoZSBtZXNzYWdlIHRvIGFsbG93IHRvIGZpbmQgdGhlIGNvcnJlY3QgY2FsbCBpbiB0aGUgVGVzdFV0aWxzLmpzIGZpbGVcbiAgaWYgKHByb2Nlc3MuZW52LlRFU1RJTkcpIHtcbiAgICBkZWZhdWx0TG9nZ2VyLmVycm9yKCdTYW5pdGl6ZWQgZXJyb3I6JywgZGV0YWlsZWRNZXNzYWdlKTtcbiAgfSBlbHNlIHtcbiAgICBkZWZhdWx0TG9nZ2VyLmVycm9yKGRldGFpbGVkTWVzc2FnZSk7XG4gIH1cblxuICBjb25zdCBlcnJvciA9IG5ldyBFcnJvcigpO1xuICBlcnJvci5zdGF0dXMgPSBzdGF0dXNDb2RlO1xuICBlcnJvci5tZXNzYWdlID0gJ1Blcm1pc3Npb24gZGVuaWVkJztcbiAgcmV0dXJuIGVycm9yO1xufVxuXG5leHBvcnQgeyBjcmVhdGVTYW5pdGl6ZWRFcnJvciwgY3JlYXRlU2FuaXRpemVkSHR0cEVycm9yIH07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxPQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBcUMsU0FBQUQsdUJBQUFFLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFFckM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVNHLG9CQUFvQkEsQ0FBQ0MsU0FBUyxFQUFFQyxlQUFlLEVBQUU7RUFDeEQ7RUFDQSxJQUFJQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsT0FBTyxFQUFFO0lBQ3ZCQyxlQUFhLENBQUNDLEtBQUssQ0FBQyxrQkFBa0IsRUFBRUwsZUFBZSxDQUFDO0VBQzFELENBQUMsTUFBTTtJQUNMSSxlQUFhLENBQUNDLEtBQUssQ0FBQ0wsZUFBZSxDQUFDO0VBQ3RDO0VBRUEsT0FBTyxJQUFJTSxLQUFLLENBQUNDLEtBQUssQ0FBQ1IsU0FBUyxFQUFFLG1CQUFtQixDQUFDO0FBQ3hEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTUyx3QkFBd0JBLENBQUNDLFVBQVUsRUFBRVQsZUFBZSxFQUFFO0VBQzdEO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLE9BQU8sRUFBRTtJQUN2QkMsZUFBYSxDQUFDQyxLQUFLLENBQUMsa0JBQWtCLEVBQUVMLGVBQWUsQ0FBQztFQUMxRCxDQUFDLE1BQU07SUFDTEksZUFBYSxDQUFDQyxLQUFLLENBQUNMLGVBQWUsQ0FBQztFQUN0QztFQUVBLE1BQU1LLEtBQUssR0FBRyxJQUFJRSxLQUFLLENBQUMsQ0FBQztFQUN6QkYsS0FBSyxDQUFDSyxNQUFNLEdBQUdELFVBQVU7RUFDekJKLEtBQUssQ0FBQ00sT0FBTyxHQUFHLG1CQUFtQjtFQUNuQyxPQUFPTixLQUFLO0FBQ2QiLCJpZ25vcmVMaXN0IjpbXX0=
48
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbG9nZ2VyIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJjcmVhdGVTYW5pdGl6ZWRFcnJvciIsImVycm9yQ29kZSIsImRldGFpbGVkTWVzc2FnZSIsImNvbmZpZyIsInByb2Nlc3MiLCJlbnYiLCJURVNUSU5HIiwiZGVmYXVsdExvZ2dlciIsImVycm9yIiwiUGFyc2UiLCJFcnJvciIsImVuYWJsZVNhbml0aXplZEVycm9yUmVzcG9uc2UiLCJjcmVhdGVTYW5pdGl6ZWRIdHRwRXJyb3IiLCJzdGF0dXNDb2RlIiwic3RhdHVzIiwibWVzc2FnZSJdLCJzb3VyY2VzIjpbIi4uL3NyYy9FcnJvci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZGVmYXVsdExvZ2dlciBmcm9tICcuL2xvZ2dlcic7XG5cbi8qKlxuICogQ3JlYXRlcyBhIHNhbml0aXplZCBlcnJvciB0aGF0IGhpZGVzIGRldGFpbGVkIGluZm9ybWF0aW9uIGZyb20gY2xpZW50c1xuICogd2hpbGUgbG9nZ2luZyB0aGUgZGV0YWlsZWQgbWVzc2FnZSBzZXJ2ZXItc2lkZS5cbiAqXG4gKiBAcGFyYW0ge251bWJlcn0gZXJyb3JDb2RlIC0gVGhlIFBhcnNlLkVycm9yIGNvZGUgKGUuZy4sIFBhcnNlLkVycm9yLk9QRVJBVElPTl9GT1JCSURERU4pXG4gKiBAcGFyYW0ge3N0cmluZ30gZGV0YWlsZWRNZXNzYWdlIC0gVGhlIGRldGFpbGVkIGVycm9yIG1lc3NhZ2UgdG8gbG9nIHNlcnZlci1zaWRlXG4gKiBAcmV0dXJucyB7UGFyc2UuRXJyb3J9IEEgUGFyc2UuRXJyb3Igd2l0aCBzYW5pdGl6ZWQgbWVzc2FnZVxuICovXG5mdW5jdGlvbiBjcmVhdGVTYW5pdGl6ZWRFcnJvcihlcnJvckNvZGUsIGRldGFpbGVkTWVzc2FnZSwgY29uZmlnKSB7XG4gIC8vIE9uIHRlc3Rpbmcgd2UgbmVlZCB0byBhZGQgYSBwcmVmaXggdG8gdGhlIG1lc3NhZ2UgdG8gYWxsb3cgdG8gZmluZCB0aGUgY29ycmVjdCBjYWxsIGluIHRoZSBUZXN0VXRpbHMuanMgZmlsZVxuICBpZiAocHJvY2Vzcy5lbnYuVEVTVElORykge1xuICAgIGRlZmF1bHRMb2dnZXIuZXJyb3IoJ1Nhbml0aXplZCBlcnJvcjonLCBkZXRhaWxlZE1lc3NhZ2UpO1xuICB9IGVsc2Uge1xuICAgIGRlZmF1bHRMb2dnZXIuZXJyb3IoZGV0YWlsZWRNZXNzYWdlKTtcbiAgfVxuXG4gIHJldHVybiBuZXcgUGFyc2UuRXJyb3IoZXJyb3JDb2RlLCBjb25maWc/LmVuYWJsZVNhbml0aXplZEVycm9yUmVzcG9uc2UgIT09IGZhbHNlID8gJ1Blcm1pc3Npb24gZGVuaWVkJyA6IGRldGFpbGVkTWVzc2FnZSk7XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIHNhbml0aXplZCBlcnJvciBmcm9tIGEgcmVndWxhciBFcnJvciBvYmplY3RcbiAqIFVzZWQgZm9yIG5vbi1QYXJzZS5FcnJvciBlcnJvcnMgKGUuZy4sIEV4cHJlc3MgZXJyb3JzKVxuICpcbiAqIEBwYXJhbSB7bnVtYmVyfSBzdGF0dXNDb2RlIC0gSFRUUCBzdGF0dXMgY29kZSAoZS5nLiwgNDAzKVxuICogQHBhcmFtIHtzdHJpbmd9IGRldGFpbGVkTWVzc2FnZSAtIFRoZSBkZXRhaWxlZCBlcnJvciBtZXNzYWdlIHRvIGxvZyBzZXJ2ZXItc2lkZVxuICogQHJldHVybnMge0Vycm9yfSBBbiBFcnJvciB3aXRoIHNhbml0aXplZCBtZXNzYWdlXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVNhbml0aXplZEh0dHBFcnJvcihzdGF0dXNDb2RlLCBkZXRhaWxlZE1lc3NhZ2UsIGNvbmZpZykge1xuICAvLyBPbiB0ZXN0aW5nIHdlIG5lZWQgdG8gYWRkIGEgcHJlZml4IHRvIHRoZSBtZXNzYWdlIHRvIGFsbG93IHRvIGZpbmQgdGhlIGNvcnJlY3QgY2FsbCBpbiB0aGUgVGVzdFV0aWxzLmpzIGZpbGVcbiAgaWYgKHByb2Nlc3MuZW52LlRFU1RJTkcpIHtcbiAgICBkZWZhdWx0TG9nZ2VyLmVycm9yKCdTYW5pdGl6ZWQgZXJyb3I6JywgZGV0YWlsZWRNZXNzYWdlKTtcbiAgfSBlbHNlIHtcbiAgICBkZWZhdWx0TG9nZ2VyLmVycm9yKGRldGFpbGVkTWVzc2FnZSk7XG4gIH1cblxuICBjb25zdCBlcnJvciA9IG5ldyBFcnJvcigpO1xuICBlcnJvci5zdGF0dXMgPSBzdGF0dXNDb2RlO1xuICBlcnJvci5tZXNzYWdlID0gY29uZmlnPy5lbmFibGVTYW5pdGl6ZWRFcnJvclJlc3BvbnNlICE9PSBmYWxzZSA/ICdQZXJtaXNzaW9uIGRlbmllZCcgOiBkZXRhaWxlZE1lc3NhZ2U7XG4gIHJldHVybiBlcnJvcjtcbn1cblxuZXhwb3J0IHsgY3JlYXRlU2FuaXRpemVkRXJyb3IsIGNyZWF0ZVNhbml0aXplZEh0dHBFcnJvciB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsT0FBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQXFDLFNBQUFELHVCQUFBRSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRXJDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTRyxvQkFBb0JBLENBQUNDLFNBQVMsRUFBRUMsZUFBZSxFQUFFQyxNQUFNLEVBQUU7RUFDaEU7RUFDQSxJQUFJQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsT0FBTyxFQUFFO0lBQ3ZCQyxlQUFhLENBQUNDLEtBQUssQ0FBQyxrQkFBa0IsRUFBRU4sZUFBZSxDQUFDO0VBQzFELENBQUMsTUFBTTtJQUNMSyxlQUFhLENBQUNDLEtBQUssQ0FBQ04sZUFBZSxDQUFDO0VBQ3RDO0VBRUEsT0FBTyxJQUFJTyxLQUFLLENBQUNDLEtBQUssQ0FBQ1QsU0FBUyxFQUFFRSxNQUFNLEVBQUVRLDRCQUE0QixLQUFLLEtBQUssR0FBRyxtQkFBbUIsR0FBR1QsZUFBZSxDQUFDO0FBQzNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTVSx3QkFBd0JBLENBQUNDLFVBQVUsRUFBRVgsZUFBZSxFQUFFQyxNQUFNLEVBQUU7RUFDckU7RUFDQSxJQUFJQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsT0FBTyxFQUFFO0lBQ3ZCQyxlQUFhLENBQUNDLEtBQUssQ0FBQyxrQkFBa0IsRUFBRU4sZUFBZSxDQUFDO0VBQzFELENBQUMsTUFBTTtJQUNMSyxlQUFhLENBQUNDLEtBQUssQ0FBQ04sZUFBZSxDQUFDO0VBQ3RDO0VBRUEsTUFBTU0sS0FBSyxHQUFHLElBQUlFLEtBQUssQ0FBQyxDQUFDO0VBQ3pCRixLQUFLLENBQUNNLE1BQU0sR0FBR0QsVUFBVTtFQUN6QkwsS0FBSyxDQUFDTyxPQUFPLEdBQUdaLE1BQU0sRUFBRVEsNEJBQTRCLEtBQUssS0FBSyxHQUFHLG1CQUFtQixHQUFHVCxlQUFlO0VBQ3RHLE9BQU9NLEtBQUs7QUFDZCIsImlnbm9yZUxpc3QiOltdfQ==
@@ -42,9 +42,9 @@ const load = parseGraphQLSchema => {
42
42
  config,
43
43
  auth
44
44
  } = context;
45
- (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth);
45
+ (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth, config);
46
46
  if (auth.isReadOnly) {
47
- throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to create a schema.");
47
+ throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to create a schema.", config);
48
48
  }
49
49
  const schema = await config.database.loadSchema({
50
50
  clearCache: true
@@ -90,9 +90,9 @@ const load = parseGraphQLSchema => {
90
90
  config,
91
91
  auth
92
92
  } = context;
93
- (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth);
93
+ (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth, config);
94
94
  if (auth.isReadOnly) {
95
- throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to update a schema.");
95
+ throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to update a schema.", config);
96
96
  }
97
97
  const schema = await config.database.loadSchema({
98
98
  clearCache: true
@@ -134,9 +134,9 @@ const load = parseGraphQLSchema => {
134
134
  config,
135
135
  auth
136
136
  } = context;
137
- (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth);
137
+ (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth, config);
138
138
  if (auth.isReadOnly) {
139
- throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to delete a schema.");
139
+ throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to delete a schema.", config);
140
140
  }
141
141
  const schema = await config.database.loadSchema({
142
142
  clearCache: true
@@ -159,4 +159,4 @@ const load = parseGraphQLSchema => {
159
159
  parseGraphQLSchema.addGraphQLMutation('deleteClass', deleteClassMutation, true, true);
160
160
  };
161
161
  exports.load = load;
162
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_graphql","_deepcopy","_graphqlRelay","schemaTypes","_interopRequireWildcard","_schemaFields","_parseGraphQLUtils","_schemaQueries","_Error","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","load","parseGraphQLSchema","createClassMutation","mutationWithClientMutationId","name","description","inputFields","CLASS_NAME_ATT","schemaFields","type","SCHEMA_FIELDS_INPUT","outputFields","class","GraphQLNonNull","CLASS","mutateAndGetPayload","args","context","deepcopy","config","auth","enforceMasterKeyAccess","isReadOnly","createSanitizedError","Parse","Error","OPERATION_FORBIDDEN","schema","database","loadSchema","clearCache","parseClass","addClassIfNotExists","transformToParse","className","transformToGraphQL","fields","handleError","addGraphQLType","input","ofType","addGraphQLMutation","updateClassMutation","existingParseClass","getClass","updateClass","undefined","deleteClassMutation","deleteSchema","exports"],"sources":["../../../src/GraphQL/loaders/schemaMutations.js"],"sourcesContent":["import Parse from 'parse/node';\nimport { GraphQLNonNull } from 'graphql';\nimport deepcopy from 'deepcopy';\nimport { mutationWithClientMutationId } from 'graphql-relay';\nimport * as schemaTypes from './schemaTypes';\nimport { transformToParse, transformToGraphQL } from '../transformers/schemaFields';\nimport { enforceMasterKeyAccess } from '../parseGraphQLUtils';\nimport { getClass } from './schemaQueries';\nimport { createSanitizedError } from '../../Error';\n\nconst load = parseGraphQLSchema => {\n  const createClassMutation = mutationWithClientMutationId({\n    name: 'CreateClass',\n    description:\n      'The createClass mutation can be used to create the schema for a new object class.',\n    inputFields: {\n      name: schemaTypes.CLASS_NAME_ATT,\n      schemaFields: {\n        description: \"These are the schema's fields of the object class.\",\n        type: schemaTypes.SCHEMA_FIELDS_INPUT,\n      },\n    },\n    outputFields: {\n      class: {\n        description: 'This is the created class.',\n        type: new GraphQLNonNull(schemaTypes.CLASS),\n      },\n    },\n    mutateAndGetPayload: async (args, context) => {\n      try {\n        const { name, schemaFields } = deepcopy(args);\n        const { config, auth } = context;\n\n        enforceMasterKeyAccess(auth);\n\n        if (auth.isReadOnly) {\n          throw createSanitizedError(\n            Parse.Error.OPERATION_FORBIDDEN,\n            \"read-only masterKey isn't allowed to create a schema.\",\n          );\n        }\n\n        const schema = await config.database.loadSchema({ clearCache: true });\n        const parseClass = await schema.addClassIfNotExists(name, transformToParse(schemaFields));\n        return {\n          class: {\n            name: parseClass.className,\n            schemaFields: transformToGraphQL(parseClass.fields),\n          },\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(createClassMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(createClassMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('createClass', createClassMutation, true, true);\n\n  const updateClassMutation = mutationWithClientMutationId({\n    name: 'UpdateClass',\n    description:\n      'The updateClass mutation can be used to update the schema for an existing object class.',\n    inputFields: {\n      name: schemaTypes.CLASS_NAME_ATT,\n      schemaFields: {\n        description: \"These are the schema's fields of the object class.\",\n        type: schemaTypes.SCHEMA_FIELDS_INPUT,\n      },\n    },\n    outputFields: {\n      class: {\n        description: 'This is the updated class.',\n        type: new GraphQLNonNull(schemaTypes.CLASS),\n      },\n    },\n    mutateAndGetPayload: async (args, context) => {\n      try {\n        const { name, schemaFields } = deepcopy(args);\n        const { config, auth } = context;\n\n        enforceMasterKeyAccess(auth);\n\n        if (auth.isReadOnly) {\n          throw createSanitizedError(\n            Parse.Error.OPERATION_FORBIDDEN,\n            \"read-only masterKey isn't allowed to update a schema.\"\n          );\n        }\n\n        const schema = await config.database.loadSchema({ clearCache: true });\n        const existingParseClass = await getClass(name, schema);\n        const parseClass = await schema.updateClass(\n          name,\n          transformToParse(schemaFields, existingParseClass.fields),\n          undefined,\n          undefined,\n          config.database\n        );\n        return {\n          class: {\n            name: parseClass.className,\n            schemaFields: transformToGraphQL(parseClass.fields),\n          },\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(updateClassMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(updateClassMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('updateClass', updateClassMutation, true, true);\n\n  const deleteClassMutation = mutationWithClientMutationId({\n    name: 'DeleteClass',\n    description: 'The deleteClass mutation can be used to delete an existing object class.',\n    inputFields: {\n      name: schemaTypes.CLASS_NAME_ATT,\n    },\n    outputFields: {\n      class: {\n        description: 'This is the deleted class.',\n        type: new GraphQLNonNull(schemaTypes.CLASS),\n      },\n    },\n    mutateAndGetPayload: async (args, context) => {\n      try {\n        const { name } = deepcopy(args);\n        const { config, auth } = context;\n\n        enforceMasterKeyAccess(auth);\n\n        if (auth.isReadOnly) {\n          throw createSanitizedError(\n            Parse.Error.OPERATION_FORBIDDEN,\n            \"read-only masterKey isn't allowed to delete a schema.\",\n          );\n        }\n\n        const schema = await config.database.loadSchema({ clearCache: true });\n        const existingParseClass = await getClass(name, schema);\n        await config.database.deleteSchema(name);\n        return {\n          class: {\n            name: existingParseClass.className,\n            schemaFields: transformToGraphQL(existingParseClass.fields),\n          },\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(deleteClassMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(deleteClassMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('deleteClass', deleteClassMutation, true, true);\n};\n\nexport { load };\n"],"mappings":"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","ignoreList":[]}
162
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_graphql","_deepcopy","_graphqlRelay","schemaTypes","_interopRequireWildcard","_schemaFields","_parseGraphQLUtils","_schemaQueries","_Error","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","load","parseGraphQLSchema","createClassMutation","mutationWithClientMutationId","name","description","inputFields","CLASS_NAME_ATT","schemaFields","type","SCHEMA_FIELDS_INPUT","outputFields","class","GraphQLNonNull","CLASS","mutateAndGetPayload","args","context","deepcopy","config","auth","enforceMasterKeyAccess","isReadOnly","createSanitizedError","Parse","Error","OPERATION_FORBIDDEN","schema","database","loadSchema","clearCache","parseClass","addClassIfNotExists","transformToParse","className","transformToGraphQL","fields","handleError","addGraphQLType","input","ofType","addGraphQLMutation","updateClassMutation","existingParseClass","getClass","updateClass","undefined","deleteClassMutation","deleteSchema","exports"],"sources":["../../../src/GraphQL/loaders/schemaMutations.js"],"sourcesContent":["import Parse from 'parse/node';\nimport { GraphQLNonNull } from 'graphql';\nimport deepcopy from 'deepcopy';\nimport { mutationWithClientMutationId } from 'graphql-relay';\nimport * as schemaTypes from './schemaTypes';\nimport { transformToParse, transformToGraphQL } from '../transformers/schemaFields';\nimport { enforceMasterKeyAccess } from '../parseGraphQLUtils';\nimport { getClass } from './schemaQueries';\nimport { createSanitizedError } from '../../Error';\n\nconst load = parseGraphQLSchema => {\n  const createClassMutation = mutationWithClientMutationId({\n    name: 'CreateClass',\n    description:\n      'The createClass mutation can be used to create the schema for a new object class.',\n    inputFields: {\n      name: schemaTypes.CLASS_NAME_ATT,\n      schemaFields: {\n        description: \"These are the schema's fields of the object class.\",\n        type: schemaTypes.SCHEMA_FIELDS_INPUT,\n      },\n    },\n    outputFields: {\n      class: {\n        description: 'This is the created class.',\n        type: new GraphQLNonNull(schemaTypes.CLASS),\n      },\n    },\n    mutateAndGetPayload: async (args, context) => {\n      try {\n        const { name, schemaFields } = deepcopy(args);\n        const { config, auth } = context;\n\n        enforceMasterKeyAccess(auth, config);\n\n        if (auth.isReadOnly) {\n          throw createSanitizedError(\n            Parse.Error.OPERATION_FORBIDDEN,\n            \"read-only masterKey isn't allowed to create a schema.\",\n            config\n          );\n        }\n\n        const schema = await config.database.loadSchema({ clearCache: true });\n        const parseClass = await schema.addClassIfNotExists(name, transformToParse(schemaFields));\n        return {\n          class: {\n            name: parseClass.className,\n            schemaFields: transformToGraphQL(parseClass.fields),\n          },\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(createClassMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(createClassMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('createClass', createClassMutation, true, true);\n\n  const updateClassMutation = mutationWithClientMutationId({\n    name: 'UpdateClass',\n    description:\n      'The updateClass mutation can be used to update the schema for an existing object class.',\n    inputFields: {\n      name: schemaTypes.CLASS_NAME_ATT,\n      schemaFields: {\n        description: \"These are the schema's fields of the object class.\",\n        type: schemaTypes.SCHEMA_FIELDS_INPUT,\n      },\n    },\n    outputFields: {\n      class: {\n        description: 'This is the updated class.',\n        type: new GraphQLNonNull(schemaTypes.CLASS),\n      },\n    },\n    mutateAndGetPayload: async (args, context) => {\n      try {\n        const { name, schemaFields } = deepcopy(args);\n        const { config, auth } = context;\n\n        enforceMasterKeyAccess(auth, config);\n\n        if (auth.isReadOnly) {\n          throw createSanitizedError(\n            Parse.Error.OPERATION_FORBIDDEN,\n            \"read-only masterKey isn't allowed to update a schema.\",\n            config\n          );\n        }\n\n        const schema = await config.database.loadSchema({ clearCache: true });\n        const existingParseClass = await getClass(name, schema);\n        const parseClass = await schema.updateClass(\n          name,\n          transformToParse(schemaFields, existingParseClass.fields),\n          undefined,\n          undefined,\n          config.database\n        );\n        return {\n          class: {\n            name: parseClass.className,\n            schemaFields: transformToGraphQL(parseClass.fields),\n          },\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(updateClassMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(updateClassMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('updateClass', updateClassMutation, true, true);\n\n  const deleteClassMutation = mutationWithClientMutationId({\n    name: 'DeleteClass',\n    description: 'The deleteClass mutation can be used to delete an existing object class.',\n    inputFields: {\n      name: schemaTypes.CLASS_NAME_ATT,\n    },\n    outputFields: {\n      class: {\n        description: 'This is the deleted class.',\n        type: new GraphQLNonNull(schemaTypes.CLASS),\n      },\n    },\n    mutateAndGetPayload: async (args, context) => {\n      try {\n        const { name } = deepcopy(args);\n        const { config, auth } = context;\n\n        enforceMasterKeyAccess(auth, config);\n\n        if (auth.isReadOnly) {\n          throw createSanitizedError(\n            Parse.Error.OPERATION_FORBIDDEN,\n            \"read-only masterKey isn't allowed to delete a schema.\",\n            config\n          );\n        }\n\n        const schema = await config.database.loadSchema({ clearCache: true });\n        const existingParseClass = await getClass(name, schema);\n        await config.database.deleteSchema(name);\n        return {\n          class: {\n            name: existingParseClass.className,\n            schemaFields: transformToGraphQL(existingParseClass.fields),\n          },\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(deleteClassMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(deleteClassMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('deleteClass', deleteClassMutation, true, true);\n};\n\nexport { load };\n"],"mappings":"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","ignoreList":[]}
@@ -40,7 +40,7 @@ const load = parseGraphQLSchema => {
40
40
  config,
41
41
  auth
42
42
  } = context;
43
- (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth);
43
+ (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth, config);
44
44
  const schema = await config.database.loadSchema({
45
45
  clearCache: true
46
46
  });
@@ -63,7 +63,7 @@ const load = parseGraphQLSchema => {
63
63
  config,
64
64
  auth
65
65
  } = context;
66
- (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth);
66
+ (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth, config);
67
67
  const schema = await config.database.loadSchema({
68
68
  clearCache: true
69
69
  });
@@ -78,4 +78,4 @@ const load = parseGraphQLSchema => {
78
78
  }, true, true);
79
79
  };
80
80
  exports.load = load;
81
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_deepcopy","_graphql","_schemaFields","schemaTypes","_interopRequireWildcard","_parseGraphQLUtils","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","getClass","name","schema","getOneSchema","undefined","Parse","Error","INVALID_CLASS_NAME","INTERNAL_SERVER_ERROR","exports","load","parseGraphQLSchema","addGraphQLQuery","description","args","CLASS_NAME_ATT","type","GraphQLNonNull","CLASS","resolve","_source","context","deepcopy","config","auth","enforceMasterKeyAccess","database","loadSchema","clearCache","parseClass","className","schemaFields","transformToGraphQL","fields","handleError","GraphQLList","_args","getAllClasses","map"],"sources":["../../../src/GraphQL/loaders/schemaQueries.js"],"sourcesContent":["import Parse from 'parse/node';\nimport deepcopy from 'deepcopy';\nimport { GraphQLNonNull, GraphQLList } from 'graphql';\nimport { transformToGraphQL } from '../transformers/schemaFields';\nimport * as schemaTypes from './schemaTypes';\nimport { enforceMasterKeyAccess } from '../parseGraphQLUtils';\n\nconst getClass = async (name, schema) => {\n  try {\n    return await schema.getOneSchema(name, true);\n  } catch (e) {\n    if (e === undefined) {\n      throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, `Class ${name} does not exist.`);\n    } else {\n      throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Database adapter error.');\n    }\n  }\n};\n\nconst load = parseGraphQLSchema => {\n  parseGraphQLSchema.addGraphQLQuery(\n    'class',\n    {\n      description: 'The class query can be used to retrieve an existing object class.',\n      args: {\n        name: schemaTypes.CLASS_NAME_ATT,\n      },\n      type: new GraphQLNonNull(schemaTypes.CLASS),\n      resolve: async (_source, args, context) => {\n        try {\n          const { name } = deepcopy(args);\n          const { config, auth } = context;\n\n          enforceMasterKeyAccess(auth);\n\n          const schema = await config.database.loadSchema({ clearCache: true });\n          const parseClass = await getClass(name, schema);\n          return {\n            name: parseClass.className,\n            schemaFields: transformToGraphQL(parseClass.fields),\n          };\n        } catch (e) {\n          parseGraphQLSchema.handleError(e);\n        }\n      },\n    },\n    true,\n    true\n  );\n\n  parseGraphQLSchema.addGraphQLQuery(\n    'classes',\n    {\n      description: 'The classes query can be used to retrieve the existing object classes.',\n      type: new GraphQLNonNull(new GraphQLList(new GraphQLNonNull(schemaTypes.CLASS))),\n      resolve: async (_source, _args, context) => {\n        try {\n          const { config, auth } = context;\n\n          enforceMasterKeyAccess(auth);\n\n          const schema = await config.database.loadSchema({ clearCache: true });\n          return (await schema.getAllClasses(true)).map(parseClass => ({\n            name: parseClass.className,\n            schemaFields: transformToGraphQL(parseClass.fields),\n          }));\n        } catch (e) {\n          parseGraphQLSchema.handleError(e);\n        }\n      },\n    },\n    true,\n    true\n  );\n};\n\nexport { getClass, load };\n"],"mappings":"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","ignoreList":[]}
81
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_deepcopy","_graphql","_schemaFields","schemaTypes","_interopRequireWildcard","_parseGraphQLUtils","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","getClass","name","schema","getOneSchema","undefined","Parse","Error","INVALID_CLASS_NAME","INTERNAL_SERVER_ERROR","exports","load","parseGraphQLSchema","addGraphQLQuery","description","args","CLASS_NAME_ATT","type","GraphQLNonNull","CLASS","resolve","_source","context","deepcopy","config","auth","enforceMasterKeyAccess","database","loadSchema","clearCache","parseClass","className","schemaFields","transformToGraphQL","fields","handleError","GraphQLList","_args","getAllClasses","map"],"sources":["../../../src/GraphQL/loaders/schemaQueries.js"],"sourcesContent":["import Parse from 'parse/node';\nimport deepcopy from 'deepcopy';\nimport { GraphQLNonNull, GraphQLList } from 'graphql';\nimport { transformToGraphQL } from '../transformers/schemaFields';\nimport * as schemaTypes from './schemaTypes';\nimport { enforceMasterKeyAccess } from '../parseGraphQLUtils';\n\nconst getClass = async (name, schema) => {\n  try {\n    return await schema.getOneSchema(name, true);\n  } catch (e) {\n    if (e === undefined) {\n      throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, `Class ${name} does not exist.`);\n    } else {\n      throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Database adapter error.');\n    }\n  }\n};\n\nconst load = parseGraphQLSchema => {\n  parseGraphQLSchema.addGraphQLQuery(\n    'class',\n    {\n      description: 'The class query can be used to retrieve an existing object class.',\n      args: {\n        name: schemaTypes.CLASS_NAME_ATT,\n      },\n      type: new GraphQLNonNull(schemaTypes.CLASS),\n      resolve: async (_source, args, context) => {\n        try {\n          const { name } = deepcopy(args);\n          const { config, auth } = context;\n\n          enforceMasterKeyAccess(auth, config);\n\n          const schema = await config.database.loadSchema({ clearCache: true });\n          const parseClass = await getClass(name, schema);\n          return {\n            name: parseClass.className,\n            schemaFields: transformToGraphQL(parseClass.fields),\n          };\n        } catch (e) {\n          parseGraphQLSchema.handleError(e);\n        }\n      },\n    },\n    true,\n    true\n  );\n\n  parseGraphQLSchema.addGraphQLQuery(\n    'classes',\n    {\n      description: 'The classes query can be used to retrieve the existing object classes.',\n      type: new GraphQLNonNull(new GraphQLList(new GraphQLNonNull(schemaTypes.CLASS))),\n      resolve: async (_source, _args, context) => {\n        try {\n          const { config, auth } = context;\n\n          enforceMasterKeyAccess(auth, config);\n\n          const schema = await config.database.loadSchema({ clearCache: true });\n          return (await schema.getAllClasses(true)).map(parseClass => ({\n            name: parseClass.className,\n            schemaFields: transformToGraphQL(parseClass.fields),\n          }));\n        } catch (e) {\n          parseGraphQLSchema.handleError(e);\n        }\n      },\n    },\n    true,\n    true\n  );\n};\n\nexport { getClass, load };\n"],"mappings":"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","ignoreList":[]}
@@ -18,7 +18,7 @@ const getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) =
18
18
  config
19
19
  } = context;
20
20
  if (!info || !info.sessionToken) {
21
- throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
21
+ throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);
22
22
  }
23
23
  const sessionToken = info.sessionToken;
24
24
  const selectedFields = (0, _graphqlListFields.default)(queryInfo).filter(field => field.startsWith(keysPrefix)).map(field => field.replace(keysPrefix, ''));
@@ -60,7 +60,7 @@ const getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) =
60
60
  objectId: context.auth.user.id
61
61
  }, options, info.clientVersion, info.context);
62
62
  if (!response.results || response.results.length == 0) {
63
- throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
63
+ throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);
64
64
  } else {
65
65
  const user = response.results[0];
66
66
  return {
@@ -87,4 +87,4 @@ const load = parseGraphQLSchema => {
87
87
  }, true, true);
88
88
  };
89
89
  exports.load = load;
90
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlListFields","_interopRequireDefault","_node","_rest","_parseClassTypes","_Auth","_Error","e","__esModule","default","getUserFromSessionToken","context","queryInfo","keysPrefix","userId","info","config","sessionToken","createSanitizedError","Parse","Error","INVALID_SESSION_TOKEN","selectedFields","getFieldNames","filter","field","startsWith","map","replace","keysAndInclude","extractKeysAndInclude","keys","include","auth","Auth","isMaster","user","id","options","split","key","join","included","response","rest","find","objectId","clientVersion","results","length","exports","load","parseGraphQLSchema","isUsersClassDisabled","addGraphQLQuery","description","type","GraphQLNonNull","viewerType","resolve","_source","_args","handleError"],"sources":["../../../src/GraphQL/loaders/usersQueries.js"],"sourcesContent":["import { GraphQLNonNull } from 'graphql';\nimport getFieldNames from 'graphql-list-fields';\nimport Parse from 'parse/node';\nimport rest from '../../rest';\nimport { extractKeysAndInclude } from './parseClassTypes';\nimport { Auth } from '../../Auth';\nimport { createSanitizedError } from '../../Error';\n\nconst getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) => {\n  const { info, config } = context;\n  if (!info || !info.sessionToken) {\n    throw  createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const sessionToken = info.sessionToken;\n  const selectedFields = getFieldNames(queryInfo)\n    .filter(field => field.startsWith(keysPrefix))\n    .map(field => field.replace(keysPrefix, ''));\n\n  const keysAndInclude = extractKeysAndInclude(selectedFields);\n  const { keys } = keysAndInclude;\n  let { include } = keysAndInclude;\n\n  if (userId && !keys && !include) {\n    return {\n      sessionToken,\n    };\n  } else if (keys && !include) {\n    include = 'user';\n  }\n\n  if (userId) {\n    // We need to re create the auth context\n    // to avoid security breach if userId is provided\n    context.auth = new Auth({\n      config,\n      isMaster: context.auth.isMaster,\n      user: { id: userId },\n    });\n  }\n\n  const options = {};\n  if (keys) {\n    options.keys = keys\n      .split(',')\n      .map(key => `${key}`)\n      .join(',');\n  }\n  if (include) {\n    options.include = include\n      .split(',')\n      .map(included => `${included}`)\n      .join(',');\n  }\n\n  const response = await rest.find(\n    config,\n    context.auth,\n    '_User',\n    // Get the user it self from auth object\n    { objectId: context.auth.user.id },\n    options,\n    info.clientVersion,\n    info.context\n  );\n  if (!response.results || response.results.length == 0) {\n    throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  } else {\n    const user = response.results[0];\n    return {\n      sessionToken,\n      user,\n    };\n  }\n};\n\nconst load = parseGraphQLSchema => {\n  if (parseGraphQLSchema.isUsersClassDisabled) {\n    return;\n  }\n\n  parseGraphQLSchema.addGraphQLQuery(\n    'viewer',\n    {\n      description: 'The viewer query can be used to return the current user data.',\n      type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      async resolve(_source, _args, context, queryInfo) {\n        try {\n          return await getUserFromSessionToken(context, queryInfo, 'user.', false);\n        } catch (e) {\n          parseGraphQLSchema.handleError(e);\n        }\n      },\n    },\n    true,\n    true\n  );\n};\n\nexport { load, getUserFromSessionToken };\n"],"mappings":"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","ignoreList":[]}
90
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlListFields","_interopRequireDefault","_node","_rest","_parseClassTypes","_Auth","_Error","e","__esModule","default","getUserFromSessionToken","context","queryInfo","keysPrefix","userId","info","config","sessionToken","createSanitizedError","Parse","Error","INVALID_SESSION_TOKEN","selectedFields","getFieldNames","filter","field","startsWith","map","replace","keysAndInclude","extractKeysAndInclude","keys","include","auth","Auth","isMaster","user","id","options","split","key","join","included","response","rest","find","objectId","clientVersion","results","length","exports","load","parseGraphQLSchema","isUsersClassDisabled","addGraphQLQuery","description","type","GraphQLNonNull","viewerType","resolve","_source","_args","handleError"],"sources":["../../../src/GraphQL/loaders/usersQueries.js"],"sourcesContent":["import { GraphQLNonNull } from 'graphql';\nimport getFieldNames from 'graphql-list-fields';\nimport Parse from 'parse/node';\nimport rest from '../../rest';\nimport { extractKeysAndInclude } from './parseClassTypes';\nimport { Auth } from '../../Auth';\nimport { createSanitizedError } from '../../Error';\n\nconst getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) => {\n  const { info, config } = context;\n  if (!info || !info.sessionToken) {\n    throw  createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);\n  }\n  const sessionToken = info.sessionToken;\n  const selectedFields = getFieldNames(queryInfo)\n    .filter(field => field.startsWith(keysPrefix))\n    .map(field => field.replace(keysPrefix, ''));\n\n  const keysAndInclude = extractKeysAndInclude(selectedFields);\n  const { keys } = keysAndInclude;\n  let { include } = keysAndInclude;\n\n  if (userId && !keys && !include) {\n    return {\n      sessionToken,\n    };\n  } else if (keys && !include) {\n    include = 'user';\n  }\n\n  if (userId) {\n    // We need to re create the auth context\n    // to avoid security breach if userId is provided\n    context.auth = new Auth({\n      config,\n      isMaster: context.auth.isMaster,\n      user: { id: userId },\n    });\n  }\n\n  const options = {};\n  if (keys) {\n    options.keys = keys\n      .split(',')\n      .map(key => `${key}`)\n      .join(',');\n  }\n  if (include) {\n    options.include = include\n      .split(',')\n      .map(included => `${included}`)\n      .join(',');\n  }\n\n  const response = await rest.find(\n    config,\n    context.auth,\n    '_User',\n    // Get the user it self from auth object\n    { objectId: context.auth.user.id },\n    options,\n    info.clientVersion,\n    info.context\n  );\n  if (!response.results || response.results.length == 0) {\n    throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);\n  } else {\n    const user = response.results[0];\n    return {\n      sessionToken,\n      user,\n    };\n  }\n};\n\nconst load = parseGraphQLSchema => {\n  if (parseGraphQLSchema.isUsersClassDisabled) {\n    return;\n  }\n\n  parseGraphQLSchema.addGraphQLQuery(\n    'viewer',\n    {\n      description: 'The viewer query can be used to return the current user data.',\n      type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      async resolve(_source, _args, context, queryInfo) {\n        try {\n          return await getUserFromSessionToken(context, queryInfo, 'user.', false);\n        } catch (e) {\n          parseGraphQLSchema.handleError(e);\n        }\n      },\n    },\n    true,\n    true\n  );\n};\n\nexport { load, getUserFromSessionToken };\n"],"mappings":"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","ignoreList":[]}
@@ -10,9 +10,9 @@ var _node = _interopRequireDefault(require("parse/node"));
10
10
  var _graphql = require("graphql");
11
11
  var _Error = require("../Error");
12
12
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
- function enforceMasterKeyAccess(auth) {
13
+ function enforceMasterKeyAccess(auth, config) {
14
14
  if (!auth.isMaster) {
15
- throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, 'unauthorized: master key is required');
15
+ throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, 'unauthorized: master key is required', config);
16
16
  }
17
17
  }
18
18
  function toGraphQLError(error) {
@@ -60,4 +60,4 @@ const getParseClassMutationConfig = function (parseClassConfig) {
60
60
  return parseClassConfig && parseClassConfig.mutation || {};
61
61
  };
62
62
  exports.getParseClassMutationConfig = getParseClassMutationConfig;
63
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbm9kZSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX2dyYXBocWwiLCJfRXJyb3IiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJlbmZvcmNlTWFzdGVyS2V5QWNjZXNzIiwiYXV0aCIsImlzTWFzdGVyIiwiY3JlYXRlU2FuaXRpemVkRXJyb3IiLCJQYXJzZSIsIkVycm9yIiwiT1BFUkFUSU9OX0ZPUkJJRERFTiIsInRvR3JhcGhRTEVycm9yIiwiZXJyb3IiLCJjb2RlIiwibWVzc2FnZSIsIklOVEVSTkFMX1NFUlZFUl9FUlJPUiIsIkdyYXBoUUxFcnJvciIsImV4dGVuc2lvbnMiLCJleHRyYWN0S2V5c0FuZEluY2x1ZGUiLCJzZWxlY3RlZEZpZWxkcyIsImZpbHRlciIsImZpZWxkIiwiaW5jbHVkZXMiLCJtYXAiLCJlbmRzV2l0aCIsInN1YnN0cmluZyIsImxhc3RJbmRleE9mIiwia2V5cyIsInVuZGVmaW5lZCIsImluY2x1ZGUiLCJsZW5ndGgiLCJTZXQiLCJqb2luIiwiaW5kZXhPZiIsImV4cG9ydHMiLCJnZXRQYXJzZUNsYXNzTXV0YXRpb25Db25maWciLCJwYXJzZUNsYXNzQ29uZmlnIiwibXV0YXRpb24iXSwic291cmNlcyI6WyIuLi8uLi9zcmMvR3JhcGhRTC9wYXJzZUdyYXBoUUxVdGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUGFyc2UgZnJvbSAncGFyc2Uvbm9kZSc7XG5pbXBvcnQgeyBHcmFwaFFMRXJyb3IgfSBmcm9tICdncmFwaHFsJztcbmltcG9ydCB7IGNyZWF0ZVNhbml0aXplZEVycm9yIH0gZnJvbSAnLi4vRXJyb3InO1xuXG5leHBvcnQgZnVuY3Rpb24gZW5mb3JjZU1hc3RlcktleUFjY2VzcyhhdXRoKSB7XG4gIGlmICghYXV0aC5pc01hc3Rlcikge1xuICAgIHRocm93IGNyZWF0ZVNhbml0aXplZEVycm9yKFxuICAgICAgUGFyc2UuRXJyb3IuT1BFUkFUSU9OX0ZPUkJJRERFTixcbiAgICAgICd1bmF1dGhvcml6ZWQ6IG1hc3RlciBrZXkgaXMgcmVxdWlyZWQnLFxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRvR3JhcGhRTEVycm9yKGVycm9yKSB7XG4gIGxldCBjb2RlLCBtZXNzYWdlO1xuICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBQYXJzZS5FcnJvcikge1xuICAgIGNvZGUgPSBlcnJvci5jb2RlO1xuICAgIG1lc3NhZ2UgPSBlcnJvci5tZXNzYWdlO1xuICB9IGVsc2Uge1xuICAgIGNvZGUgPSBQYXJzZS5FcnJvci5JTlRFUk5BTF9TRVJWRVJfRVJST1I7XG4gICAgbWVzc2FnZSA9ICdJbnRlcm5hbCBzZXJ2ZXIgZXJyb3InO1xuICB9XG4gIHJldHVybiBuZXcgR3JhcGhRTEVycm9yKG1lc3NhZ2UsIHsgZXh0ZW5zaW9uczogeyBjb2RlIH0gfSk7XG59XG5cbmV4cG9ydCBjb25zdCBleHRyYWN0S2V5c0FuZEluY2x1ZGUgPSBzZWxlY3RlZEZpZWxkcyA9PiB7XG4gIHNlbGVjdGVkRmllbGRzID0gc2VsZWN0ZWRGaWVsZHMuZmlsdGVyKGZpZWxkID0+ICFmaWVsZC5pbmNsdWRlcygnX190eXBlbmFtZScpKTtcbiAgLy8gSGFuZGxlcyBcImlkXCIgZmllbGQgZm9yIGJvdGggY3VycmVudCBhbmQgaW5jbHVkZWQgb2JqZWN0c1xuICBzZWxlY3RlZEZpZWxkcyA9IHNlbGVjdGVkRmllbGRzLm1hcChmaWVsZCA9PiB7XG4gICAgaWYgKGZpZWxkID09PSAnaWQnKSB7IHJldHVybiAnb2JqZWN0SWQnOyB9XG4gICAgcmV0dXJuIGZpZWxkLmVuZHNXaXRoKCcuaWQnKVxuICAgICAgPyBgJHtmaWVsZC5zdWJzdHJpbmcoMCwgZmllbGQubGFzdEluZGV4T2YoJy5pZCcpKX0ub2JqZWN0SWRgXG4gICAgICA6IGZpZWxkO1xuICB9KTtcbiAgbGV0IGtleXMgPSB1bmRlZmluZWQ7XG4gIGxldCBpbmNsdWRlID0gdW5kZWZpbmVkO1xuXG4gIGlmIChzZWxlY3RlZEZpZWxkcy5sZW5ndGggPiAwKSB7XG4gICAga2V5cyA9IFsuLi5uZXcgU2V0KHNlbGVjdGVkRmllbGRzKV0uam9pbignLCcpO1xuICAgIC8vIFdlIGNhbiB1c2UgdGhpcyBzaG9ydGN1dCBzaW5jZSBvcHRpbWl6YXRpb24gaXMgaGFuZGxlZFxuICAgIC8vIGxhdGVyIG9uIFJlc3RRdWVyeSwgYXZvaWQgb3ZlcmhlYWQgaGVyZS5cbiAgICBpbmNsdWRlID0ga2V5cztcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgLy8gSWYgYXV0aERhdGEgaXMgZGV0ZWN0ZWQga2V5cyB3aWxsIG5vdCB3b3JrIHByb3Blcmx5XG4gICAgLy8gc2luY2UgYXV0aERhdGEgaGFzIGEgc3BlY2lhbCBzdG9yYWdlIGJlaGF2aW9yXG4gICAgLy8gc28gd2UgbmVlZCB0byBza2lwIGtleXMgY3VycmVudGx5XG4gICAga2V5czoga2V5cyAmJiBrZXlzLmluZGV4T2YoJ2F1dGhEYXRhJykgPT09IC0xID8ga2V5cyA6IHVuZGVmaW5lZCxcbiAgICBpbmNsdWRlLFxuICB9O1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFBhcnNlQ2xhc3NNdXRhdGlvbkNvbmZpZyA9IGZ1bmN0aW9uIChwYXJzZUNsYXNzQ29uZmlnKSB7XG4gIHJldHVybiAocGFyc2VDbGFzc0NvbmZpZyAmJiBwYXJzZUNsYXNzQ29uZmlnLm11dGF0aW9uKSB8fCB7fTtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsSUFBQUEsS0FBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsUUFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsTUFBQSxHQUFBRixPQUFBO0FBQWdELFNBQUFELHVCQUFBSSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRXpDLFNBQVNHLHNCQUFzQkEsQ0FBQ0MsSUFBSSxFQUFFO0VBQzNDLElBQUksQ0FBQ0EsSUFBSSxDQUFDQyxRQUFRLEVBQUU7SUFDbEIsTUFBTSxJQUFBQywyQkFBb0IsRUFDeEJDLGFBQUssQ0FBQ0MsS0FBSyxDQUFDQyxtQkFBbUIsRUFDL0Isc0NBQ0YsQ0FBQztFQUNIO0FBQ0Y7QUFFTyxTQUFTQyxjQUFjQSxDQUFDQyxLQUFLLEVBQUU7RUFDcEMsSUFBSUMsSUFBSSxFQUFFQyxPQUFPO0VBQ2pCLElBQUlGLEtBQUssWUFBWUosYUFBSyxDQUFDQyxLQUFLLEVBQUU7SUFDaENJLElBQUksR0FBR0QsS0FBSyxDQUFDQyxJQUFJO0lBQ2pCQyxPQUFPLEdBQUdGLEtBQUssQ0FBQ0UsT0FBTztFQUN6QixDQUFDLE1BQU07SUFDTEQsSUFBSSxHQUFHTCxhQUFLLENBQUNDLEtBQUssQ0FBQ00scUJBQXFCO0lBQ3hDRCxPQUFPLEdBQUcsdUJBQXVCO0VBQ25DO0VBQ0EsT0FBTyxJQUFJRSxxQkFBWSxDQUFDRixPQUFPLEVBQUU7SUFBRUcsVUFBVSxFQUFFO01BQUVKO0lBQUs7RUFBRSxDQUFDLENBQUM7QUFDNUQ7QUFFTyxNQUFNSyxxQkFBcUIsR0FBR0MsY0FBYyxJQUFJO0VBQ3JEQSxjQUFjLEdBQUdBLGNBQWMsQ0FBQ0MsTUFBTSxDQUFDQyxLQUFLLElBQUksQ0FBQ0EsS0FBSyxDQUFDQyxRQUFRLENBQUMsWUFBWSxDQUFDLENBQUM7RUFDOUU7RUFDQUgsY0FBYyxHQUFHQSxjQUFjLENBQUNJLEdBQUcsQ0FBQ0YsS0FBSyxJQUFJO0lBQzNDLElBQUlBLEtBQUssS0FBSyxJQUFJLEVBQUU7TUFBRSxPQUFPLFVBQVU7SUFBRTtJQUN6QyxPQUFPQSxLQUFLLENBQUNHLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FDeEIsR0FBR0gsS0FBSyxDQUFDSSxTQUFTLENBQUMsQ0FBQyxFQUFFSixLQUFLLENBQUNLLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxXQUFXLEdBQzFETCxLQUFLO0VBQ1gsQ0FBQyxDQUFDO0VBQ0YsSUFBSU0sSUFBSSxHQUFHQyxTQUFTO0VBQ3BCLElBQUlDLE9BQU8sR0FBR0QsU0FBUztFQUV2QixJQUFJVCxjQUFjLENBQUNXLE1BQU0sR0FBRyxDQUFDLEVBQUU7SUFDN0JILElBQUksR0FBRyxDQUFDLEdBQUcsSUFBSUksR0FBRyxDQUFDWixjQUFjLENBQUMsQ0FBQyxDQUFDYSxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQzdDO0lBQ0E7SUFDQUgsT0FBTyxHQUFHRixJQUFJO0VBQ2hCO0VBRUEsT0FBTztJQUNMO0lBQ0E7SUFDQTtJQUNBQSxJQUFJLEVBQUVBLElBQUksSUFBSUEsSUFBSSxDQUFDTSxPQUFPLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUdOLElBQUksR0FBR0MsU0FBUztJQUNoRUM7RUFDRixDQUFDO0FBQ0gsQ0FBQztBQUFDSyxPQUFBLENBQUFoQixxQkFBQSxHQUFBQSxxQkFBQTtBQUVLLE1BQU1pQiwyQkFBMkIsR0FBRyxTQUFBQSxDQUFVQyxnQkFBZ0IsRUFBRTtFQUNyRSxPQUFRQSxnQkFBZ0IsSUFBSUEsZ0JBQWdCLENBQUNDLFFBQVEsSUFBSyxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUFDSCxPQUFBLENBQUFDLDJCQUFBLEdBQUFBLDJCQUFBIiwiaWdub3JlTGlzdCI6W119
63
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbm9kZSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX2dyYXBocWwiLCJfRXJyb3IiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJlbmZvcmNlTWFzdGVyS2V5QWNjZXNzIiwiYXV0aCIsImNvbmZpZyIsImlzTWFzdGVyIiwiY3JlYXRlU2FuaXRpemVkRXJyb3IiLCJQYXJzZSIsIkVycm9yIiwiT1BFUkFUSU9OX0ZPUkJJRERFTiIsInRvR3JhcGhRTEVycm9yIiwiZXJyb3IiLCJjb2RlIiwibWVzc2FnZSIsIklOVEVSTkFMX1NFUlZFUl9FUlJPUiIsIkdyYXBoUUxFcnJvciIsImV4dGVuc2lvbnMiLCJleHRyYWN0S2V5c0FuZEluY2x1ZGUiLCJzZWxlY3RlZEZpZWxkcyIsImZpbHRlciIsImZpZWxkIiwiaW5jbHVkZXMiLCJtYXAiLCJlbmRzV2l0aCIsInN1YnN0cmluZyIsImxhc3RJbmRleE9mIiwia2V5cyIsInVuZGVmaW5lZCIsImluY2x1ZGUiLCJsZW5ndGgiLCJTZXQiLCJqb2luIiwiaW5kZXhPZiIsImV4cG9ydHMiLCJnZXRQYXJzZUNsYXNzTXV0YXRpb25Db25maWciLCJwYXJzZUNsYXNzQ29uZmlnIiwibXV0YXRpb24iXSwic291cmNlcyI6WyIuLi8uLi9zcmMvR3JhcGhRTC9wYXJzZUdyYXBoUUxVdGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUGFyc2UgZnJvbSAncGFyc2Uvbm9kZSc7XG5pbXBvcnQgeyBHcmFwaFFMRXJyb3IgfSBmcm9tICdncmFwaHFsJztcbmltcG9ydCB7IGNyZWF0ZVNhbml0aXplZEVycm9yIH0gZnJvbSAnLi4vRXJyb3InO1xuXG5leHBvcnQgZnVuY3Rpb24gZW5mb3JjZU1hc3RlcktleUFjY2VzcyhhdXRoLCBjb25maWcpIHtcbiAgaWYgKCFhdXRoLmlzTWFzdGVyKSB7XG4gICAgdGhyb3cgY3JlYXRlU2FuaXRpemVkRXJyb3IoXG4gICAgICBQYXJzZS5FcnJvci5PUEVSQVRJT05fRk9SQklEREVOLFxuICAgICAgJ3VuYXV0aG9yaXplZDogbWFzdGVyIGtleSBpcyByZXF1aXJlZCcsXG4gICAgICBjb25maWdcbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b0dyYXBoUUxFcnJvcihlcnJvcikge1xuICBsZXQgY29kZSwgbWVzc2FnZTtcbiAgaWYgKGVycm9yIGluc3RhbmNlb2YgUGFyc2UuRXJyb3IpIHtcbiAgICBjb2RlID0gZXJyb3IuY29kZTtcbiAgICBtZXNzYWdlID0gZXJyb3IubWVzc2FnZTtcbiAgfSBlbHNlIHtcbiAgICBjb2RlID0gUGFyc2UuRXJyb3IuSU5URVJOQUxfU0VSVkVSX0VSUk9SO1xuICAgIG1lc3NhZ2UgPSAnSW50ZXJuYWwgc2VydmVyIGVycm9yJztcbiAgfVxuICByZXR1cm4gbmV3IEdyYXBoUUxFcnJvcihtZXNzYWdlLCB7IGV4dGVuc2lvbnM6IHsgY29kZSB9IH0pO1xufVxuXG5leHBvcnQgY29uc3QgZXh0cmFjdEtleXNBbmRJbmNsdWRlID0gc2VsZWN0ZWRGaWVsZHMgPT4ge1xuICBzZWxlY3RlZEZpZWxkcyA9IHNlbGVjdGVkRmllbGRzLmZpbHRlcihmaWVsZCA9PiAhZmllbGQuaW5jbHVkZXMoJ19fdHlwZW5hbWUnKSk7XG4gIC8vIEhhbmRsZXMgXCJpZFwiIGZpZWxkIGZvciBib3RoIGN1cnJlbnQgYW5kIGluY2x1ZGVkIG9iamVjdHNcbiAgc2VsZWN0ZWRGaWVsZHMgPSBzZWxlY3RlZEZpZWxkcy5tYXAoZmllbGQgPT4ge1xuICAgIGlmIChmaWVsZCA9PT0gJ2lkJykgeyByZXR1cm4gJ29iamVjdElkJzsgfVxuICAgIHJldHVybiBmaWVsZC5lbmRzV2l0aCgnLmlkJylcbiAgICAgID8gYCR7ZmllbGQuc3Vic3RyaW5nKDAsIGZpZWxkLmxhc3RJbmRleE9mKCcuaWQnKSl9Lm9iamVjdElkYFxuICAgICAgOiBmaWVsZDtcbiAgfSk7XG4gIGxldCBrZXlzID0gdW5kZWZpbmVkO1xuICBsZXQgaW5jbHVkZSA9IHVuZGVmaW5lZDtcblxuICBpZiAoc2VsZWN0ZWRGaWVsZHMubGVuZ3RoID4gMCkge1xuICAgIGtleXMgPSBbLi4ubmV3IFNldChzZWxlY3RlZEZpZWxkcyldLmpvaW4oJywnKTtcbiAgICAvLyBXZSBjYW4gdXNlIHRoaXMgc2hvcnRjdXQgc2luY2Ugb3B0aW1pemF0aW9uIGlzIGhhbmRsZWRcbiAgICAvLyBsYXRlciBvbiBSZXN0UXVlcnksIGF2b2lkIG92ZXJoZWFkIGhlcmUuXG4gICAgaW5jbHVkZSA9IGtleXM7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIC8vIElmIGF1dGhEYXRhIGlzIGRldGVjdGVkIGtleXMgd2lsbCBub3Qgd29yayBwcm9wZXJseVxuICAgIC8vIHNpbmNlIGF1dGhEYXRhIGhhcyBhIHNwZWNpYWwgc3RvcmFnZSBiZWhhdmlvclxuICAgIC8vIHNvIHdlIG5lZWQgdG8gc2tpcCBrZXlzIGN1cnJlbnRseVxuICAgIGtleXM6IGtleXMgJiYga2V5cy5pbmRleE9mKCdhdXRoRGF0YScpID09PSAtMSA/IGtleXMgOiB1bmRlZmluZWQsXG4gICAgaW5jbHVkZSxcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYXJzZUNsYXNzTXV0YXRpb25Db25maWcgPSBmdW5jdGlvbiAocGFyc2VDbGFzc0NvbmZpZykge1xuICByZXR1cm4gKHBhcnNlQ2xhc3NDb25maWcgJiYgcGFyc2VDbGFzc0NvbmZpZy5tdXRhdGlvbikgfHwge307XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBLElBQUFBLEtBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLFFBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLE1BQUEsR0FBQUYsT0FBQTtBQUFnRCxTQUFBRCx1QkFBQUksQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUV6QyxTQUFTRyxzQkFBc0JBLENBQUNDLElBQUksRUFBRUMsTUFBTSxFQUFFO0VBQ25ELElBQUksQ0FBQ0QsSUFBSSxDQUFDRSxRQUFRLEVBQUU7SUFDbEIsTUFBTSxJQUFBQywyQkFBb0IsRUFDeEJDLGFBQUssQ0FBQ0MsS0FBSyxDQUFDQyxtQkFBbUIsRUFDL0Isc0NBQXNDLEVBQ3RDTCxNQUNGLENBQUM7RUFDSDtBQUNGO0FBRU8sU0FBU00sY0FBY0EsQ0FBQ0MsS0FBSyxFQUFFO0VBQ3BDLElBQUlDLElBQUksRUFBRUMsT0FBTztFQUNqQixJQUFJRixLQUFLLFlBQVlKLGFBQUssQ0FBQ0MsS0FBSyxFQUFFO0lBQ2hDSSxJQUFJLEdBQUdELEtBQUssQ0FBQ0MsSUFBSTtJQUNqQkMsT0FBTyxHQUFHRixLQUFLLENBQUNFLE9BQU87RUFDekIsQ0FBQyxNQUFNO0lBQ0xELElBQUksR0FBR0wsYUFBSyxDQUFDQyxLQUFLLENBQUNNLHFCQUFxQjtJQUN4Q0QsT0FBTyxHQUFHLHVCQUF1QjtFQUNuQztFQUNBLE9BQU8sSUFBSUUscUJBQVksQ0FBQ0YsT0FBTyxFQUFFO0lBQUVHLFVBQVUsRUFBRTtNQUFFSjtJQUFLO0VBQUUsQ0FBQyxDQUFDO0FBQzVEO0FBRU8sTUFBTUsscUJBQXFCLEdBQUdDLGNBQWMsSUFBSTtFQUNyREEsY0FBYyxHQUFHQSxjQUFjLENBQUNDLE1BQU0sQ0FBQ0MsS0FBSyxJQUFJLENBQUNBLEtBQUssQ0FBQ0MsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO0VBQzlFO0VBQ0FILGNBQWMsR0FBR0EsY0FBYyxDQUFDSSxHQUFHLENBQUNGLEtBQUssSUFBSTtJQUMzQyxJQUFJQSxLQUFLLEtBQUssSUFBSSxFQUFFO01BQUUsT0FBTyxVQUFVO0lBQUU7SUFDekMsT0FBT0EsS0FBSyxDQUFDRyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQ3hCLEdBQUdILEtBQUssQ0FBQ0ksU0FBUyxDQUFDLENBQUMsRUFBRUosS0FBSyxDQUFDSyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUMsV0FBVyxHQUMxREwsS0FBSztFQUNYLENBQUMsQ0FBQztFQUNGLElBQUlNLElBQUksR0FBR0MsU0FBUztFQUNwQixJQUFJQyxPQUFPLEdBQUdELFNBQVM7RUFFdkIsSUFBSVQsY0FBYyxDQUFDVyxNQUFNLEdBQUcsQ0FBQyxFQUFFO0lBQzdCSCxJQUFJLEdBQUcsQ0FBQyxHQUFHLElBQUlJLEdBQUcsQ0FBQ1osY0FBYyxDQUFDLENBQUMsQ0FBQ2EsSUFBSSxDQUFDLEdBQUcsQ0FBQztJQUM3QztJQUNBO0lBQ0FILE9BQU8sR0FBR0YsSUFBSTtFQUNoQjtFQUVBLE9BQU87SUFDTDtJQUNBO0lBQ0E7SUFDQUEsSUFBSSxFQUFFQSxJQUFJLElBQUlBLElBQUksQ0FBQ00sT0FBTyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHTixJQUFJLEdBQUdDLFNBQVM7SUFDaEVDO0VBQ0YsQ0FBQztBQUNILENBQUM7QUFBQ0ssT0FBQSxDQUFBaEIscUJBQUEsR0FBQUEscUJBQUE7QUFFSyxNQUFNaUIsMkJBQTJCLEdBQUcsU0FBQUEsQ0FBVUMsZ0JBQWdCLEVBQUU7RUFDckUsT0FBUUEsZ0JBQWdCLElBQUlBLGdCQUFnQixDQUFDQyxRQUFRLElBQUssQ0FBQyxDQUFDO0FBQzlELENBQUM7QUFBQ0gsT0FBQSxDQUFBQywyQkFBQSxHQUFBQSwyQkFBQSIsImlnbm9yZUxpc3QiOltdfQ==