parse-server 8.5.0-alpha.9 → 8.6.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -2
  2. package/lib/Adapters/Auth/AuthAdapter.js +2 -2
  3. package/lib/Adapters/Auth/apple.js +2 -2
  4. package/lib/Adapters/Auth/facebook.js +2 -2
  5. package/lib/Adapters/Cache/CacheAdapter.js +2 -2
  6. package/lib/Adapters/Email/MailAdapter.js +2 -2
  7. package/lib/Adapters/Files/FilesAdapter.js +2 -2
  8. package/lib/Adapters/Files/GridFSBucketAdapter.js +2 -2
  9. package/lib/Adapters/Logger/LoggerAdapter.js +2 -2
  10. package/lib/Adapters/Logger/WinstonLogger.js +3 -3
  11. package/lib/Adapters/PubSub/PubSubAdapter.js +2 -2
  12. package/lib/Adapters/Push/PushAdapter.js +2 -3
  13. package/lib/Adapters/Storage/Mongo/MongoTransform.js +2 -2
  14. package/lib/Adapters/WebSocketServer/WSAdapter.js +2 -2
  15. package/lib/Adapters/WebSocketServer/WSSAdapter.js +2 -2
  16. package/lib/Controllers/HooksController.js +2 -2
  17. package/lib/Controllers/SchemaController.js +7 -5
  18. package/lib/Controllers/index.js +2 -2
  19. package/lib/Deprecator/Deprecator.js +3 -2
  20. package/lib/Error.js +48 -0
  21. package/lib/GraphQL/ParseGraphQLSchema.js +4 -3
  22. package/lib/GraphQL/loaders/configMutations.js +87 -0
  23. package/lib/GraphQL/loaders/configQueries.js +79 -0
  24. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +3 -1
  25. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +3 -1
  26. package/lib/GraphQL/loaders/filesMutations.js +2 -2
  27. package/lib/GraphQL/loaders/schemaMutations.js +8 -7
  28. package/lib/GraphQL/loaders/schemaQueries.js +3 -3
  29. package/lib/GraphQL/loaders/usersQueries.js +4 -3
  30. package/lib/GraphQL/parseGraphQLUtils.js +4 -3
  31. package/lib/Options/Definitions.js +11 -3
  32. package/lib/Options/docs.js +3 -2
  33. package/lib/Options/index.js +1 -1
  34. package/lib/Options/parsers.js +2 -2
  35. package/lib/RestQuery.js +8 -5
  36. package/lib/RestWrite.js +6 -6
  37. package/lib/Routers/ClassesRouter.js +4 -3
  38. package/lib/Routers/FilesRouter.js +4 -5
  39. package/lib/Routers/GlobalConfigRouter.js +3 -2
  40. package/lib/Routers/GraphQLRouter.js +3 -2
  41. package/lib/Routers/PagesRouter.js +4 -4
  42. package/lib/Routers/PurgeRouter.js +3 -2
  43. package/lib/Routers/PushRouter.js +3 -2
  44. package/lib/Routers/SchemasRouter.js +5 -4
  45. package/lib/Routers/UsersRouter.js +39 -7
  46. package/lib/SharedRest.js +9 -8
  47. package/lib/TestUtils.js +1 -1
  48. package/lib/Utils.js +27 -2
  49. package/lib/batch.js +2 -2
  50. package/lib/cli/utils/runner.js +2 -2
  51. package/lib/cloud-code/Parse.Cloud.js +43 -1
  52. package/lib/middlewares.js +9 -10
  53. package/lib/password.js +2 -2
  54. package/lib/request.js +2 -2
  55. package/lib/rest.js +14 -11
  56. package/lib/triggers.js +5 -4
  57. package/package.json +5 -8
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.load = exports.cloudConfig = void 0;
7
+ var _graphql = require("graphql");
8
+ var _node = _interopRequireDefault(require("parse/node"));
9
+ var _Error = require("../../Error");
10
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
11
+ const cloudConfig = async (context, paramName) => {
12
+ const {
13
+ config,
14
+ auth
15
+ } = context;
16
+ if (!auth.isMaster) {
17
+ throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, 'Master Key is required to access GlobalConfig.');
18
+ }
19
+ const results = await config.database.find('_GlobalConfig', {
20
+ objectId: '1'
21
+ }, {
22
+ limit: 1
23
+ });
24
+ if (results.length !== 1) {
25
+ return {
26
+ value: null,
27
+ isMasterKeyOnly: null
28
+ };
29
+ }
30
+ const globalConfig = results[0];
31
+ const params = globalConfig.params || {};
32
+ const masterKeyOnly = globalConfig.masterKeyOnly || {};
33
+ if (params[paramName] !== undefined) {
34
+ return {
35
+ value: params[paramName],
36
+ isMasterKeyOnly: masterKeyOnly[paramName] ?? null
37
+ };
38
+ }
39
+ return {
40
+ value: null,
41
+ isMasterKeyOnly: null
42
+ };
43
+ };
44
+ exports.cloudConfig = cloudConfig;
45
+ const load = parseGraphQLSchema => {
46
+ if (!parseGraphQLSchema.cloudConfigType) {
47
+ const cloudConfigType = new _graphql.GraphQLObjectType({
48
+ name: 'ConfigValue',
49
+ fields: {
50
+ value: {
51
+ type: _graphql.GraphQLString
52
+ },
53
+ isMasterKeyOnly: {
54
+ type: _graphql.GraphQLBoolean
55
+ }
56
+ }
57
+ });
58
+ parseGraphQLSchema.addGraphQLType(cloudConfigType, true, true);
59
+ parseGraphQLSchema.cloudConfigType = cloudConfigType;
60
+ }
61
+ parseGraphQLSchema.addGraphQLQuery('cloudConfig', {
62
+ description: 'Returns the value of a specific parameter from GlobalConfig.',
63
+ args: {
64
+ paramName: {
65
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
66
+ }
67
+ },
68
+ type: new _graphql.GraphQLNonNull(parseGraphQLSchema.cloudConfigType),
69
+ async resolve(_source, args, context) {
70
+ try {
71
+ return await cloudConfig(context, args.paramName);
72
+ } catch (e) {
73
+ parseGraphQLSchema.handleError(e);
74
+ }
75
+ }
76
+ }, false, true);
77
+ };
78
+ exports.load = load;
79
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZ3JhcGhxbCIsInJlcXVpcmUiLCJfbm9kZSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJfRXJyb3IiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJjbG91ZENvbmZpZyIsImNvbnRleHQiLCJwYXJhbU5hbWUiLCJjb25maWciLCJhdXRoIiwiaXNNYXN0ZXIiLCJjcmVhdGVTYW5pdGl6ZWRFcnJvciIsIlBhcnNlIiwiRXJyb3IiLCJPUEVSQVRJT05fRk9SQklEREVOIiwicmVzdWx0cyIsImRhdGFiYXNlIiwiZmluZCIsIm9iamVjdElkIiwibGltaXQiLCJsZW5ndGgiLCJ2YWx1ZSIsImlzTWFzdGVyS2V5T25seSIsImdsb2JhbENvbmZpZyIsInBhcmFtcyIsIm1hc3RlcktleU9ubHkiLCJ1bmRlZmluZWQiLCJleHBvcnRzIiwibG9hZCIsInBhcnNlR3JhcGhRTFNjaGVtYSIsImNsb3VkQ29uZmlnVHlwZSIsIkdyYXBoUUxPYmplY3RUeXBlIiwibmFtZSIsImZpZWxkcyIsInR5cGUiLCJHcmFwaFFMU3RyaW5nIiwiR3JhcGhRTEJvb2xlYW4iLCJhZGRHcmFwaFFMVHlwZSIsImFkZEdyYXBoUUxRdWVyeSIsImRlc2NyaXB0aW9uIiwiYXJncyIsIkdyYXBoUUxOb25OdWxsIiwicmVzb2x2ZSIsIl9zb3VyY2UiLCJoYW5kbGVFcnJvciJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9HcmFwaFFML2xvYWRlcnMvY29uZmlnUXVlcmllcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHcmFwaFFMTm9uTnVsbCwgR3JhcGhRTFN0cmluZywgR3JhcGhRTEJvb2xlYW4sIEdyYXBoUUxPYmplY3RUeXBlIH0gZnJvbSAnZ3JhcGhxbCc7XG5pbXBvcnQgUGFyc2UgZnJvbSAncGFyc2Uvbm9kZSc7XG5pbXBvcnQgeyBjcmVhdGVTYW5pdGl6ZWRFcnJvciB9IGZyb20gJy4uLy4uL0Vycm9yJztcblxuY29uc3QgY2xvdWRDb25maWcgPSBhc3luYyAoY29udGV4dCwgcGFyYW1OYW1lKSA9PiB7XG4gIGNvbnN0IHsgY29uZmlnLCBhdXRoIH0gPSBjb250ZXh0O1xuXG4gIGlmICghYXV0aC5pc01hc3Rlcikge1xuICAgIHRocm93IGNyZWF0ZVNhbml0aXplZEVycm9yKFxuICAgICAgUGFyc2UuRXJyb3IuT1BFUkFUSU9OX0ZPUkJJRERFTixcbiAgICAgICdNYXN0ZXIgS2V5IGlzIHJlcXVpcmVkIHRvIGFjY2VzcyBHbG9iYWxDb25maWcuJ1xuICAgICk7XG4gIH1cblxuICBjb25zdCByZXN1bHRzID0gYXdhaXQgY29uZmlnLmRhdGFiYXNlLmZpbmQoJ19HbG9iYWxDb25maWcnLCB7IG9iamVjdElkOiAnMScgfSwgeyBsaW1pdDogMSB9KTtcblxuICBpZiAocmVzdWx0cy5sZW5ndGggIT09IDEpIHtcbiAgICByZXR1cm4geyB2YWx1ZTogbnVsbCwgaXNNYXN0ZXJLZXlPbmx5OiBudWxsIH07XG4gIH1cblxuICBjb25zdCBnbG9iYWxDb25maWcgPSByZXN1bHRzWzBdO1xuICBjb25zdCBwYXJhbXMgPSBnbG9iYWxDb25maWcucGFyYW1zIHx8IHt9O1xuICBjb25zdCBtYXN0ZXJLZXlPbmx5ID0gZ2xvYmFsQ29uZmlnLm1hc3RlcktleU9ubHkgfHwge307XG5cbiAgaWYgKHBhcmFtc1twYXJhbU5hbWVdICE9PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4geyB2YWx1ZTogcGFyYW1zW3BhcmFtTmFtZV0sIGlzTWFzdGVyS2V5T25seTogbWFzdGVyS2V5T25seVtwYXJhbU5hbWVdID8/IG51bGwgfTtcbiAgfVxuXG4gIHJldHVybiB7IHZhbHVlOiBudWxsLCBpc01hc3RlcktleU9ubHk6IG51bGwgfTtcbn07XG5cbmNvbnN0IGxvYWQgPSAocGFyc2VHcmFwaFFMU2NoZW1hKSA9PiB7XG4gIGlmICghcGFyc2VHcmFwaFFMU2NoZW1hLmNsb3VkQ29uZmlnVHlwZSkge1xuICAgIGNvbnN0IGNsb3VkQ29uZmlnVHlwZSA9IG5ldyBHcmFwaFFMT2JqZWN0VHlwZSh7XG4gICAgICBuYW1lOiAnQ29uZmlnVmFsdWUnLFxuICAgICAgZmllbGRzOiB7XG4gICAgICAgIHZhbHVlOiB7IHR5cGU6IEdyYXBoUUxTdHJpbmcgfSxcbiAgICAgICAgaXNNYXN0ZXJLZXlPbmx5OiB7IHR5cGU6IEdyYXBoUUxCb29sZWFuIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHBhcnNlR3JhcGhRTFNjaGVtYS5hZGRHcmFwaFFMVHlwZShjbG91ZENvbmZpZ1R5cGUsIHRydWUsIHRydWUpO1xuICAgIHBhcnNlR3JhcGhRTFNjaGVtYS5jbG91ZENvbmZpZ1R5cGUgPSBjbG91ZENvbmZpZ1R5cGU7XG4gIH1cblxuICBwYXJzZUdyYXBoUUxTY2hlbWEuYWRkR3JhcGhRTFF1ZXJ5KCdjbG91ZENvbmZpZycsIHtcbiAgICBkZXNjcmlwdGlvbjogJ1JldHVybnMgdGhlIHZhbHVlIG9mIGEgc3BlY2lmaWMgcGFyYW1ldGVyIGZyb20gR2xvYmFsQ29uZmlnLicsXG4gICAgYXJnczoge1xuICAgICAgcGFyYW1OYW1lOiB7IHR5cGU6IG5ldyBHcmFwaFFMTm9uTnVsbChHcmFwaFFMU3RyaW5nKSB9LFxuICAgIH0sXG4gICAgdHlwZTogbmV3IEdyYXBoUUxOb25OdWxsKHBhcnNlR3JhcGhRTFNjaGVtYS5jbG91ZENvbmZpZ1R5cGUpLFxuICAgIGFzeW5jIHJlc29sdmUoX3NvdXJjZSwgYXJncywgY29udGV4dCkge1xuICAgICAgdHJ5IHtcbiAgICAgICAgcmV0dXJuIGF3YWl0IGNsb3VkQ29uZmlnKGNvbnRleHQsIGFyZ3MucGFyYW1OYW1lKTtcbiAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgcGFyc2VHcmFwaFFMU2NoZW1hLmhhbmRsZUVycm9yKGUpO1xuICAgICAgfVxuICAgIH0sXG4gIH0sIGZhbHNlLCB0cnVlKTtcbn07XG5cbmV4cG9ydCB7IGxvYWQsIGNsb3VkQ29uZmlnIH07XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLFFBQUEsR0FBQUMsT0FBQTtBQUNBLElBQUFDLEtBQUEs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
@@ -8,12 +8,14 @@ var filesMutations = _interopRequireWildcard(require("./filesMutations"));
8
8
  var usersMutations = _interopRequireWildcard(require("./usersMutations"));
9
9
  var functionsMutations = _interopRequireWildcard(require("./functionsMutations"));
10
10
  var schemaMutations = _interopRequireWildcard(require("./schemaMutations"));
11
+ var configMutations = _interopRequireWildcard(require("./configMutations"));
11
12
  function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
12
13
  const load = parseGraphQLSchema => {
13
14
  filesMutations.load(parseGraphQLSchema);
14
15
  usersMutations.load(parseGraphQLSchema);
15
16
  functionsMutations.load(parseGraphQLSchema);
16
17
  schemaMutations.load(parseGraphQLSchema);
18
+ configMutations.load(parseGraphQLSchema);
17
19
  };
18
20
  exports.load = load;
19
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmaWxlc011dGF0aW9ucyIsIl9pbnRlcm9wUmVxdWlyZVdpbGRjYXJkIiwicmVxdWlyZSIsInVzZXJzTXV0YXRpb25zIiwiZnVuY3Rpb25zTXV0YXRpb25zIiwic2NoZW1hTXV0YXRpb25zIiwiZSIsInQiLCJXZWFrTWFwIiwiciIsIm4iLCJfX2VzTW9kdWxlIiwibyIsImkiLCJmIiwiX19wcm90b19fIiwiZGVmYXVsdCIsImhhcyIsImdldCIsInNldCIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwibG9hZCIsInBhcnNlR3JhcGhRTFNjaGVtYSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvR3JhcGhRTC9sb2FkZXJzL2RlZmF1bHRHcmFwaFFMTXV0YXRpb25zLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZpbGVzTXV0YXRpb25zIGZyb20gJy4vZmlsZXNNdXRhdGlvbnMnO1xuaW1wb3J0ICogYXMgdXNlcnNNdXRhdGlvbnMgZnJvbSAnLi91c2Vyc011dGF0aW9ucyc7XG5pbXBvcnQgKiBhcyBmdW5jdGlvbnNNdXRhdGlvbnMgZnJvbSAnLi9mdW5jdGlvbnNNdXRhdGlvbnMnO1xuaW1wb3J0ICogYXMgc2NoZW1hTXV0YXRpb25zIGZyb20gJy4vc2NoZW1hTXV0YXRpb25zJztcblxuY29uc3QgbG9hZCA9IHBhcnNlR3JhcGhRTFNjaGVtYSA9PiB7XG4gIGZpbGVzTXV0YXRpb25zLmxvYWQocGFyc2VHcmFwaFFMU2NoZW1hKTtcbiAgdXNlcnNNdXRhdGlvbnMubG9hZChwYXJzZUdyYXBoUUxTY2hlbWEpO1xuICBmdW5jdGlvbnNNdXRhdGlvbnMubG9hZChwYXJzZUdyYXBoUUxTY2hlbWEpO1xuICBzY2hlbWFNdXRhdGlvbnMubG9hZChwYXJzZUdyYXBoUUxTY2hlbWEpO1xufTtcblxuZXhwb3J0IHsgbG9hZCB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxjQUFBLEdBQUFDLHVCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxjQUFBLEdBQUFGLHVCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBRSxrQkFBQSxHQUFBSCx1QkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUcsZUFBQSxHQUFBSix1QkFBQSxDQUFBQyxPQUFBO0FBQXFELFNBQUFELHdCQUFBSyxDQUFBLEVBQUFDLENBQUEsNkJBQUFDLE9BQUEsTUFBQUMsQ0FBQSxPQUFBRCxPQUFBLElBQUFFLENBQUEsT0FBQUYsT0FBQSxZQUFBUCx1QkFBQSxZQUFBQSxDQUFBSyxDQUFBLEVBQUFDLENBQUEsU0FBQUEsQ0FBQSxJQUFBRCxDQUFBLElBQUFBLENBQUEsQ0FBQUssVUFBQSxTQUFBTCxDQUFBLE1BQUFNLENBQUEsRUFBQUMsQ0FBQSxFQUFBQyxDQUFBLEtBQUFDLFNBQUEsUUFBQUMsT0FBQSxFQUFBVixDQUFBLGlCQUFBQSxDQUFBLHVCQUFBQSxDQUFBLHlCQUFBQSxDQUFBLFNBQUFRLENBQUEsTUFBQUYsQ0FBQSxHQUFBTCxDQUFBLEdBQUFHLENBQUEsR0FBQUQsQ0FBQSxRQUFBRyxDQUFBLENBQUFLLEdBQUEsQ0FBQVgsQ0FBQSxVQUFBTSxDQUFBLENBQUFNLEdBQUEsQ0FBQVosQ0FBQSxHQUFBTSxDQUFBLENBQUFPLEdBQUEsQ0FBQWIsQ0FBQSxFQUFBUSxDQUFBLGdCQUFBUCxDQUFBLElBQUFELENBQUEsZ0JBQUFDLENBQUEsT0FBQWEsY0FBQSxDQUFBQyxJQUFBLENBQUFmLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLElBQUFELENBQUEsR0FBQVUsTUFBQSxDQUFBQyxjQUFBLEtBQUFELE1BQUEsQ0FBQUUsd0JBQUEsQ0FBQWxCLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLENBQUFLLEdBQUEsSUFBQUwsQ0FBQSxDQUFBTSxHQUFBLElBQUFQLENBQUEsQ0FBQUUsQ0FBQSxFQUFBUCxDQUFBLEVBQUFNLENBQUEsSUFBQUMsQ0FBQSxDQUFBUCxDQUFBLElBQUFELENBQUEsQ0FBQUMsQ0FBQSxXQUFBTyxDQUFBLEtBQUFSLENBQUEsRUFBQUMsQ0FBQTtBQUVyRCxNQUFNa0IsSUFBSSxHQUFHQyxrQkFBa0IsSUFBSTtFQUNqQzFCLGNBQWMsQ0FBQ3lCLElBQUksQ0FBQ0Msa0JBQWtCLENBQUM7RUFDdkN2QixjQUFjLENBQUNzQixJQUFJLENBQUNDLGtCQUFrQixDQUFDO0VBQ3ZDdEIsa0JBQWtCLENBQUNxQixJQUFJLENBQUNDLGtCQUFrQixDQUFDO0VBQzNDckIsZUFBZSxDQUFDb0IsSUFBSSxDQUFDQyxrQkFBa0IsQ0FBQztBQUMxQyxDQUFDO0FBQUNDLE9BQUEsQ0FBQUYsSUFBQSxHQUFBQSxJQUFBIiwiaWdub3JlTGlzdCI6W119
21
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmaWxlc011dGF0aW9ucyIsIl9pbnRlcm9wUmVxdWlyZVdpbGRjYXJkIiwicmVxdWlyZSIsInVzZXJzTXV0YXRpb25zIiwiZnVuY3Rpb25zTXV0YXRpb25zIiwic2NoZW1hTXV0YXRpb25zIiwiY29uZmlnTXV0YXRpb25zIiwiZSIsInQiLCJXZWFrTWFwIiwiciIsIm4iLCJfX2VzTW9kdWxlIiwibyIsImkiLCJmIiwiX19wcm90b19fIiwiZGVmYXVsdCIsImhhcyIsImdldCIsInNldCIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwibG9hZCIsInBhcnNlR3JhcGhRTFNjaGVtYSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvR3JhcGhRTC9sb2FkZXJzL2RlZmF1bHRHcmFwaFFMTXV0YXRpb25zLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZpbGVzTXV0YXRpb25zIGZyb20gJy4vZmlsZXNNdXRhdGlvbnMnO1xuaW1wb3J0ICogYXMgdXNlcnNNdXRhdGlvbnMgZnJvbSAnLi91c2Vyc011dGF0aW9ucyc7XG5pbXBvcnQgKiBhcyBmdW5jdGlvbnNNdXRhdGlvbnMgZnJvbSAnLi9mdW5jdGlvbnNNdXRhdGlvbnMnO1xuaW1wb3J0ICogYXMgc2NoZW1hTXV0YXRpb25zIGZyb20gJy4vc2NoZW1hTXV0YXRpb25zJztcbmltcG9ydCAqIGFzIGNvbmZpZ011dGF0aW9ucyBmcm9tICcuL2NvbmZpZ011dGF0aW9ucyc7XG5cbmNvbnN0IGxvYWQgPSBwYXJzZUdyYXBoUUxTY2hlbWEgPT4ge1xuICBmaWxlc011dGF0aW9ucy5sb2FkKHBhcnNlR3JhcGhRTFNjaGVtYSk7XG4gIHVzZXJzTXV0YXRpb25zLmxvYWQocGFyc2VHcmFwaFFMU2NoZW1hKTtcbiAgZnVuY3Rpb25zTXV0YXRpb25zLmxvYWQocGFyc2VHcmFwaFFMU2NoZW1hKTtcbiAgc2NoZW1hTXV0YXRpb25zLmxvYWQocGFyc2VHcmFwaFFMU2NoZW1hKTtcbiAgY29uZmlnTXV0YXRpb25zLmxvYWQocGFyc2VHcmFwaFFMU2NoZW1hKTtcbn07XG5cbmV4cG9ydCB7IGxvYWQgfTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsY0FBQSxHQUFBQyx1QkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsY0FBQSxHQUFBRix1QkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUUsa0JBQUEsR0FBQUgsdUJBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFHLGVBQUEsR0FBQUosdUJBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFJLGVBQUEsR0FBQUwsdUJBQUEsQ0FBQUMsT0FBQTtBQUFxRCxTQUFBRCx3QkFBQU0sQ0FBQSxFQUFBQyxDQUFBLDZCQUFBQyxPQUFBLE1BQUFDLENBQUEsT0FBQUQsT0FBQSxJQUFBRSxDQUFBLE9BQUFGLE9BQUEsWUFBQVIsdUJBQUEsWUFBQUEsQ0FBQU0sQ0FBQSxFQUFBQyxDQUFBLFNBQUFBLENBQUEsSUFBQUQsQ0FBQSxJQUFBQSxDQUFBLENBQUFLLFVBQUEsU0FBQUwsQ0FBQSxNQUFBTSxDQUFBLEVBQUFDLENBQUEsRUFBQUMsQ0FBQSxLQUFBQyxTQUFBLFFBQUFDLE9BQUEsRUFBQVYsQ0FBQSxpQkFBQUEsQ0FBQSx1QkFBQUEsQ0FBQSx5QkFBQUEsQ0FBQSxTQUFBUSxDQUFBLE1BQUFGLENBQUEsR0FBQUwsQ0FBQSxHQUFBRyxDQUFBLEdBQUFELENBQUEsUUFBQUcsQ0FBQSxDQUFBSyxHQUFBLENBQUFYLENBQUEsVUFBQU0sQ0FBQSxDQUFBTSxHQUFBLENBQUFaLENBQUEsR0FBQU0sQ0FBQSxDQUFBTyxHQUFBLENBQUFiLENBQUEsRUFBQVEsQ0FBQSxnQkFBQVAsQ0FBQSxJQUFBRCxDQUFBLGdCQUFBQyxDQUFBLE9BQUFhLGNBQUEsQ0FBQUMsSUFBQSxDQUFBZixDQUFBLEVBQUFDLENBQUEsT0FBQU0sQ0FBQSxJQUFBRCxDQUFBLEdBQUFVLE1BQUEsQ0FBQUMsY0FBQSxLQUFBRCxNQUFBLENBQUFFLHdCQUFBLENBQUFsQixDQUFBLEVBQUFDLENBQUEsT0FBQU0sQ0FBQSxDQUFBSyxHQUFBLElBQUFMLENBQUEsQ0FBQU0sR0FBQSxJQUFBUCxDQUFBLENBQUFFLENBQUEsRUFBQVAsQ0FBQSxFQUFBTSxDQUFBLElBQUFDLENBQUEsQ0FBQVAsQ0FBQSxJQUFBRCxDQUFBLENBQUFDLENBQUEsV0FBQU8sQ0FBQSxLQUFBUixDQUFBLEVBQUFDLENBQUE7QUFFckQsTUFBTWtCLElBQUksR0FBR0Msa0JBQWtCLElBQUk7RUFDakMzQixjQUFjLENBQUMwQixJQUFJLENBQUNDLGtCQUFrQixDQUFDO0VBQ3ZDeEIsY0FBYyxDQUFDdUIsSUFBSSxDQUFDQyxrQkFBa0IsQ0FBQztFQUN2Q3ZCLGtCQUFrQixDQUFDc0IsSUFBSSxDQUFDQyxrQkFBa0IsQ0FBQztFQUMzQ3RCLGVBQWUsQ0FBQ3FCLElBQUksQ0FBQ0Msa0JBQWtCLENBQUM7RUFDeENyQixlQUFlLENBQUNvQixJQUFJLENBQUNDLGtCQUFrQixDQUFDO0FBQzFDLENBQUM7QUFBQ0MsT0FBQSxDQUFBRixJQUFBLEdBQUFBLElBQUEiLCJpZ25vcmVMaXN0IjpbXX0=
@@ -7,6 +7,7 @@ exports.load = void 0;
7
7
  var _graphql = require("graphql");
8
8
  var usersQueries = _interopRequireWildcard(require("./usersQueries"));
9
9
  var schemaQueries = _interopRequireWildcard(require("./schemaQueries"));
10
+ var configQueries = _interopRequireWildcard(require("./configQueries"));
10
11
  function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
11
12
  const load = parseGraphQLSchema => {
12
13
  parseGraphQLSchema.addGraphQLQuery('health', {
@@ -16,6 +17,7 @@ const load = parseGraphQLSchema => {
16
17
  }, true, true);
17
18
  usersQueries.load(parseGraphQLSchema);
18
19
  schemaQueries.load(parseGraphQLSchema);
20
+ configQueries.load(parseGraphQLSchema);
19
21
  };
20
22
  exports.load = load;
21
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZ3JhcGhxbCIsInJlcXVpcmUiLCJ1c2Vyc1F1ZXJpZXMiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInNjaGVtYVF1ZXJpZXMiLCJlIiwidCIsIldlYWtNYXAiLCJyIiwibiIsIl9fZXNNb2R1bGUiLCJvIiwiaSIsImYiLCJfX3Byb3RvX18iLCJkZWZhdWx0IiwiaGFzIiwiZ2V0Iiwic2V0IiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJsb2FkIiwicGFyc2VHcmFwaFFMU2NoZW1hIiwiYWRkR3JhcGhRTFF1ZXJ5IiwiZGVzY3JpcHRpb24iLCJ0eXBlIiwiR3JhcGhRTE5vbk51bGwiLCJHcmFwaFFMQm9vbGVhbiIsInJlc29sdmUiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL0dyYXBoUUwvbG9hZGVycy9kZWZhdWx0R3JhcGhRTFF1ZXJpZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR3JhcGhRTE5vbk51bGwsIEdyYXBoUUxCb29sZWFuIH0gZnJvbSAnZ3JhcGhxbCc7XG5pbXBvcnQgKiBhcyB1c2Vyc1F1ZXJpZXMgZnJvbSAnLi91c2Vyc1F1ZXJpZXMnO1xuaW1wb3J0ICogYXMgc2NoZW1hUXVlcmllcyBmcm9tICcuL3NjaGVtYVF1ZXJpZXMnO1xuXG5jb25zdCBsb2FkID0gcGFyc2VHcmFwaFFMU2NoZW1hID0+IHtcbiAgcGFyc2VHcmFwaFFMU2NoZW1hLmFkZEdyYXBoUUxRdWVyeShcbiAgICAnaGVhbHRoJyxcbiAgICB7XG4gICAgICBkZXNjcmlwdGlvbjogJ1RoZSBoZWFsdGggcXVlcnkgY2FuIGJlIHVzZWQgdG8gY2hlY2sgaWYgdGhlIHNlcnZlciBpcyB1cCBhbmQgcnVubmluZy4nLFxuICAgICAgdHlwZTogbmV3IEdyYXBoUUxOb25OdWxsKEdyYXBoUUxCb29sZWFuKSxcbiAgICAgIHJlc29sdmU6ICgpID0+IHRydWUsXG4gICAgfSxcbiAgICB0cnVlLFxuICAgIHRydWVcbiAgKTtcblxuICB1c2Vyc1F1ZXJpZXMubG9hZChwYXJzZUdyYXBoUUxTY2hlbWEpO1xuICBzY2hlbWFRdWVyaWVzLmxvYWQocGFyc2VHcmFwaFFMU2NoZW1hKTtcbn07XG5cbmV4cG9ydCB7IGxvYWQgfTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsUUFBQSxHQUFBQyxPQUFBO0FBQ0EsSUFBQUMsWUFBQSxHQUFBQyx1QkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUcsYUFBQSxHQUFBRCx1QkFBQSxDQUFBRixPQUFBO0FBQWlELFNBQUFFLHdCQUFBRSxDQUFBLEVBQUFDLENBQUEsNkJBQUFDLE9BQUEsTUFBQUMsQ0FBQSxPQUFBRCxPQUFBLElBQUFFLENBQUEsT0FBQUYsT0FBQSxZQUFBSix1QkFBQSxZQUFBQSxDQUFBRSxDQUFBLEVBQUFDLENBQUEsU0FBQUEsQ0FBQSxJQUFBRCxDQUFBLElBQUFBLENBQUEsQ0FBQUssVUFBQSxTQUFBTCxDQUFBLE1BQUFNLENBQUEsRUFBQUMsQ0FBQSxFQUFBQyxDQUFBLEtBQUFDLFNBQUEsUUFBQUMsT0FBQSxFQUFBVixDQUFBLGlCQUFBQSxDQUFBLHVCQUFBQSxDQUFBLHlCQUFBQSxDQUFBLFNBQUFRLENBQUEsTUFBQUYsQ0FBQSxHQUFBTCxDQUFBLEdBQUFHLENBQUEsR0FBQUQsQ0FBQSxRQUFBRyxDQUFBLENBQUFLLEdBQUEsQ0FBQVgsQ0FBQSxVQUFBTSxDQUFBLENBQUFNLEdBQUEsQ0FBQVosQ0FBQSxHQUFBTSxDQUFBLENBQUFPLEdBQUEsQ0FBQWIsQ0FBQSxFQUFBUSxDQUFBLGdCQUFBUCxDQUFBLElBQUFELENBQUEsZ0JBQUFDLENBQUEsT0FBQWEsY0FBQSxDQUFBQyxJQUFBLENBQUFmLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLElBQUFELENBQUEsR0FBQVUsTUFBQSxDQUFBQyxjQUFBLEtBQUFELE1BQUEsQ0FBQUUsd0JBQUEsQ0FBQWxCLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLENBQUFLLEdBQUEsSUFBQUwsQ0FBQSxDQUFBTSxHQUFBLElBQUFQLENBQUEsQ0FBQUUsQ0FBQSxFQUFBUCxDQUFBLEVBQUFNLENBQUEsSUFBQUMsQ0FBQSxDQUFBUCxDQUFBLElBQUFELENBQUEsQ0FBQUMsQ0FBQSxXQUFBTyxDQUFBLEtBQUFSLENBQUEsRUFBQUMsQ0FBQTtBQUVqRCxNQUFNa0IsSUFBSSxHQUFHQyxrQkFBa0IsSUFBSTtFQUNqQ0Esa0JBQWtCLENBQUNDLGVBQWUsQ0FDaEMsUUFBUSxFQUNSO0lBQ0VDLFdBQVcsRUFBRSx3RUFBd0U7SUFDckZDLElBQUksRUFBRSxJQUFJQyx1QkFBYyxDQUFDQyx1QkFBYyxDQUFDO0lBQ3hDQyxPQUFPLEVBQUVBLENBQUEsS0FBTTtFQUNqQixDQUFDLEVBQ0QsSUFBSSxFQUNKLElBQ0YsQ0FBQztFQUVEN0IsWUFBWSxDQUFDc0IsSUFBSSxDQUFDQyxrQkFBa0IsQ0FBQztFQUNyQ3JCLGFBQWEsQ0FBQ29CLElBQUksQ0FBQ0Msa0JBQWtCLENBQUM7QUFDeEMsQ0FBQztBQUFDTyxPQUFBLENBQUFSLElBQUEsR0FBQUEsSUFBQSIsImlnbm9yZUxpc3QiOltdfQ==
23
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZ3JhcGhxbCIsInJlcXVpcmUiLCJ1c2Vyc1F1ZXJpZXMiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInNjaGVtYVF1ZXJpZXMiLCJjb25maWdRdWVyaWVzIiwiZSIsInQiLCJXZWFrTWFwIiwiciIsIm4iLCJfX2VzTW9kdWxlIiwibyIsImkiLCJmIiwiX19wcm90b19fIiwiZGVmYXVsdCIsImhhcyIsImdldCIsInNldCIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwibG9hZCIsInBhcnNlR3JhcGhRTFNjaGVtYSIsImFkZEdyYXBoUUxRdWVyeSIsImRlc2NyaXB0aW9uIiwidHlwZSIsIkdyYXBoUUxOb25OdWxsIiwiR3JhcGhRTEJvb2xlYW4iLCJyZXNvbHZlIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9HcmFwaFFML2xvYWRlcnMvZGVmYXVsdEdyYXBoUUxRdWVyaWVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdyYXBoUUxOb25OdWxsLCBHcmFwaFFMQm9vbGVhbiB9IGZyb20gJ2dyYXBocWwnO1xuaW1wb3J0ICogYXMgdXNlcnNRdWVyaWVzIGZyb20gJy4vdXNlcnNRdWVyaWVzJztcbmltcG9ydCAqIGFzIHNjaGVtYVF1ZXJpZXMgZnJvbSAnLi9zY2hlbWFRdWVyaWVzJztcbmltcG9ydCAqIGFzIGNvbmZpZ1F1ZXJpZXMgZnJvbSAnLi9jb25maWdRdWVyaWVzJztcblxuY29uc3QgbG9hZCA9IHBhcnNlR3JhcGhRTFNjaGVtYSA9PiB7XG4gIHBhcnNlR3JhcGhRTFNjaGVtYS5hZGRHcmFwaFFMUXVlcnkoXG4gICAgJ2hlYWx0aCcsXG4gICAge1xuICAgICAgZGVzY3JpcHRpb246ICdUaGUgaGVhbHRoIHF1ZXJ5IGNhbiBiZSB1c2VkIHRvIGNoZWNrIGlmIHRoZSBzZXJ2ZXIgaXMgdXAgYW5kIHJ1bm5pbmcuJyxcbiAgICAgIHR5cGU6IG5ldyBHcmFwaFFMTm9uTnVsbChHcmFwaFFMQm9vbGVhbiksXG4gICAgICByZXNvbHZlOiAoKSA9PiB0cnVlLFxuICAgIH0sXG4gICAgdHJ1ZSxcbiAgICB0cnVlXG4gICk7XG5cbiAgdXNlcnNRdWVyaWVzLmxvYWQocGFyc2VHcmFwaFFMU2NoZW1hKTtcbiAgc2NoZW1hUXVlcmllcy5sb2FkKHBhcnNlR3JhcGhRTFNjaGVtYSk7XG4gIGNvbmZpZ1F1ZXJpZXMubG9hZChwYXJzZUdyYXBoUUxTY2hlbWEpO1xufTtcblxuZXhwb3J0IHsgbG9hZCB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxRQUFBLEdBQUFDLE9BQUE7QUFDQSxJQUFBQyxZQUFBLEdBQUFDLHVCQUFBLENBQUFGLE9BQUE7QUFDQSxJQUFBRyxhQUFBLEdBQUFELHVCQUFBLENBQUFGLE9BQUE7QUFDQSxJQUFBSSxhQUFBLEdBQUFGLHVCQUFBLENBQUFGLE9BQUE7QUFBaUQsU0FBQUUsd0JBQUFHLENBQUEsRUFBQUMsQ0FBQSw2QkFBQUMsT0FBQSxNQUFBQyxDQUFBLE9BQUFELE9BQUEsSUFBQUUsQ0FBQSxPQUFBRixPQUFBLFlBQUFMLHVCQUFBLFlBQUFBLENBQUFHLENBQUEsRUFBQUMsQ0FBQSxTQUFBQSxDQUFBLElBQUFELENBQUEsSUFBQUEsQ0FBQSxDQUFBSyxVQUFBLFNBQUFMLENBQUEsTUFBQU0sQ0FBQSxFQUFBQyxDQUFBLEVBQUFDLENBQUEsS0FBQUMsU0FBQSxRQUFBQyxPQUFBLEVBQUFWLENBQUEsaUJBQUFBLENBQUEsdUJBQUFBLENBQUEseUJBQUFBLENBQUEsU0FBQVEsQ0FBQSxNQUFBRixDQUFBLEdBQUFMLENBQUEsR0FBQUcsQ0FBQSxHQUFBRCxDQUFBLFFBQUFHLENBQUEsQ0FBQUssR0FBQSxDQUFBWCxDQUFBLFVBQUFNLENBQUEsQ0FBQU0sR0FBQSxDQUFBWixDQUFBLEdBQUFNLENBQUEsQ0FBQU8sR0FBQSxDQUFBYixDQUFBLEVBQUFRLENBQUEsZ0JBQUFQLENBQUEsSUFBQUQsQ0FBQSxnQkFBQUMsQ0FBQSxPQUFBYSxjQUFBLENBQUFDLElBQUEsQ0FBQWYsQ0FBQSxFQUFBQyxDQUFBLE9BQUFNLENBQUEsSUFBQUQsQ0FBQSxHQUFBVSxNQUFBLENBQUFDLGNBQUEsS0FBQUQsTUFBQSxDQUFBRSx3QkFBQSxDQUFBbEIsQ0FBQSxFQUFBQyxDQUFBLE9BQUFNLENBQUEsQ0FBQUssR0FBQSxJQUFBTCxDQUFBLENBQUFNLEdBQUEsSUFBQVAsQ0FBQSxDQUFBRSxDQUFBLEVBQUFQLENBQUEsRUFBQU0sQ0FBQSxJQUFBQyxDQUFBLENBQUFQLENBQUEsSUFBQUQsQ0FBQSxDQUFBQyxDQUFBLFdBQUFPLENBQUEsS0FBQVIsQ0FBQSxFQUFBQyxDQUFBO0FBRWpELE1BQU1rQixJQUFJLEdBQUdDLGtCQUFrQixJQUFJO0VBQ2pDQSxrQkFBa0IsQ0FBQ0MsZUFBZSxDQUNoQyxRQUFRLEVBQ1I7SUFDRUMsV0FBVyxFQUFFLHdFQUF3RTtJQUNyRkMsSUFBSSxFQUFFLElBQUlDLHVCQUFjLENBQUNDLHVCQUFjLENBQUM7SUFDeENDLE9BQU8sRUFBRUEsQ0FBQSxLQUFNO0VBQ2pCLENBQUMsRUFDRCxJQUFJLEVBQ0osSUFDRixDQUFDO0VBRUQ5QixZQUFZLENBQUN1QixJQUFJLENBQUNDLGtCQUFrQixDQUFDO0VBQ3JDdEIsYUFBYSxDQUFDcUIsSUFBSSxDQUFDQyxrQkFBa0IsQ0FBQztFQUN0Q3JCLGFBQWEsQ0FBQ29CLElBQUksQ0FBQ0Msa0JBQWtCLENBQUM7QUFDeEMsQ0FBQztBQUFDTyxPQUFBLENBQUFSLElBQUEsR0FBQUEsSUFBQSIsImlnbm9yZUxpc3QiOltdfQ==
@@ -49,7 +49,7 @@ const handleUpload = async (upload, config) => {
49
49
  res.on('end', () => {
50
50
  try {
51
51
  resolve(JSON.parse(data));
52
- } catch (e) {
52
+ } catch {
53
53
  reject(new _node.default.Error(_node.default.error, data));
54
54
  }
55
55
  });
@@ -104,4 +104,4 @@ const load = parseGraphQLSchema => {
104
104
  parseGraphQLSchema.addGraphQLMutation('createFile', createMutation, true, true);
105
105
  };
106
106
  exports.load = load;
107
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_http","_graphqlRelay","_node","_interopRequireDefault","defaultGraphQLTypes","_interopRequireWildcard","_logger","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","handleUpload","upload","config","createReadStream","filename","mimetype","headers","stream","mime","ext","getExtension","fullFileName","endsWith","serverUrl","URL","serverURL","fileInfo","Promise","resolve","reject","req","request","hostname","port","path","pathname","method","res","data","on","chunk","JSON","parse","Parse","Error","error","pipe","end","destroy","logger","FILE_SAVE_ERROR","exports","load","parseGraphQLSchema","createMutation","mutationWithClientMutationId","name","description","inputFields","type","GraphQLNonNull","GraphQLUpload","outputFields","FILE_INFO","mutateAndGetPayload","args","context","handleError","addGraphQLType","input","ofType","addGraphQLMutation"],"sources":["../../../src/GraphQL/loaders/filesMutations.js"],"sourcesContent":["import { GraphQLNonNull } from 'graphql';\nimport { request } from 'http';\nimport { mutationWithClientMutationId } from 'graphql-relay';\nimport Parse from 'parse/node';\nimport * as defaultGraphQLTypes from './defaultGraphQLTypes';\nimport logger from '../../logger';\n\n// Handle GraphQL file upload and proxy file upload to GraphQL server url specified in config;\n// `createFile` is not directly called by Parse Server to leverage standard file upload mechanism\nconst handleUpload = async (upload, config) => {\n  const { createReadStream, filename, mimetype } = await upload;\n  const headers = { ...config.headers };\n  delete headers['accept-encoding'];\n  delete headers['accept'];\n  delete headers['connection'];\n  delete headers['host'];\n  delete headers['content-length'];\n  const stream = createReadStream();\n  const mime = (await import('mime')).default;\n  try {\n    const ext = mime.getExtension(mimetype);\n    const fullFileName = filename.endsWith(`.${ext}`) ? filename : `${filename}.${ext}`;\n    const serverUrl = new URL(config.serverURL);\n    const fileInfo = await new Promise((resolve, reject) => {\n      const req = request(\n        {\n          hostname: serverUrl.hostname,\n          port: serverUrl.port,\n          path: `${serverUrl.pathname}/files/${fullFileName}`,\n          method: 'POST',\n          headers,\n        },\n        res => {\n          let data = '';\n          res.on('data', chunk => {\n            data += chunk;\n          });\n          res.on('end', () => {\n            try {\n              resolve(JSON.parse(data));\n            } catch (e) {\n              reject(new Parse.Error(Parse.error, data));\n            }\n          });\n        }\n      );\n      stream.pipe(req);\n      stream.on('end', () => {\n        req.end();\n      });\n    });\n    return {\n      fileInfo,\n    };\n  } catch (e) {\n    stream.destroy();\n    logger.error('Error creating a file: ', e);\n    throw new Parse.Error(Parse.Error.FILE_SAVE_ERROR, `Could not store file: ${filename}.`);\n  }\n};\n\nconst load = parseGraphQLSchema => {\n  const createMutation = mutationWithClientMutationId({\n    name: 'CreateFile',\n    description: 'The createFile mutation can be used to create and upload a new file.',\n    inputFields: {\n      upload: {\n        description: 'This is the new file to be created and uploaded.',\n        type: new GraphQLNonNull(defaultGraphQLTypes.GraphQLUpload),\n      },\n    },\n    outputFields: {\n      fileInfo: {\n        description: 'This is the created file info.',\n        type: new GraphQLNonNull(defaultGraphQLTypes.FILE_INFO),\n      },\n    },\n    mutateAndGetPayload: async (args, context) => {\n      try {\n        const { upload } = args;\n        const { config } = context;\n        return handleUpload(upload, config);\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(createMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(createMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('createFile', createMutation, true, true);\n};\n\nexport { load, handleUpload };\n"],"mappings":"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","ignoreList":[]}
107
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_http","_graphqlRelay","_node","_interopRequireDefault","defaultGraphQLTypes","_interopRequireWildcard","_logger","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","handleUpload","upload","config","createReadStream","filename","mimetype","headers","stream","mime","ext","getExtension","fullFileName","endsWith","serverUrl","URL","serverURL","fileInfo","Promise","resolve","reject","req","request","hostname","port","path","pathname","method","res","data","on","chunk","JSON","parse","Parse","Error","error","pipe","end","destroy","logger","FILE_SAVE_ERROR","exports","load","parseGraphQLSchema","createMutation","mutationWithClientMutationId","name","description","inputFields","type","GraphQLNonNull","GraphQLUpload","outputFields","FILE_INFO","mutateAndGetPayload","args","context","handleError","addGraphQLType","input","ofType","addGraphQLMutation"],"sources":["../../../src/GraphQL/loaders/filesMutations.js"],"sourcesContent":["import { GraphQLNonNull } from 'graphql';\nimport { request } from 'http';\nimport { mutationWithClientMutationId } from 'graphql-relay';\nimport Parse from 'parse/node';\nimport * as defaultGraphQLTypes from './defaultGraphQLTypes';\nimport logger from '../../logger';\n\n// Handle GraphQL file upload and proxy file upload to GraphQL server url specified in config;\n// `createFile` is not directly called by Parse Server to leverage standard file upload mechanism\nconst handleUpload = async (upload, config) => {\n  const { createReadStream, filename, mimetype } = await upload;\n  const headers = { ...config.headers };\n  delete headers['accept-encoding'];\n  delete headers['accept'];\n  delete headers['connection'];\n  delete headers['host'];\n  delete headers['content-length'];\n  const stream = createReadStream();\n  const mime = (await import('mime')).default;\n  try {\n    const ext = mime.getExtension(mimetype);\n    const fullFileName = filename.endsWith(`.${ext}`) ? filename : `${filename}.${ext}`;\n    const serverUrl = new URL(config.serverURL);\n    const fileInfo = await new Promise((resolve, reject) => {\n      const req = request(\n        {\n          hostname: serverUrl.hostname,\n          port: serverUrl.port,\n          path: `${serverUrl.pathname}/files/${fullFileName}`,\n          method: 'POST',\n          headers,\n        },\n        res => {\n          let data = '';\n          res.on('data', chunk => {\n            data += chunk;\n          });\n          res.on('end', () => {\n            try {\n              resolve(JSON.parse(data));\n            } catch {\n              reject(new Parse.Error(Parse.error, data));\n            }\n          });\n        }\n      );\n      stream.pipe(req);\n      stream.on('end', () => {\n        req.end();\n      });\n    });\n    return {\n      fileInfo,\n    };\n  } catch (e) {\n    stream.destroy();\n    logger.error('Error creating a file: ', e);\n    throw new Parse.Error(Parse.Error.FILE_SAVE_ERROR, `Could not store file: ${filename}.`);\n  }\n};\n\nconst load = parseGraphQLSchema => {\n  const createMutation = mutationWithClientMutationId({\n    name: 'CreateFile',\n    description: 'The createFile mutation can be used to create and upload a new file.',\n    inputFields: {\n      upload: {\n        description: 'This is the new file to be created and uploaded.',\n        type: new GraphQLNonNull(defaultGraphQLTypes.GraphQLUpload),\n      },\n    },\n    outputFields: {\n      fileInfo: {\n        description: 'This is the created file info.',\n        type: new GraphQLNonNull(defaultGraphQLTypes.FILE_INFO),\n      },\n    },\n    mutateAndGetPayload: async (args, context) => {\n      try {\n        const { upload } = args;\n        const { config } = context;\n        return handleUpload(upload, config);\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(createMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(createMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('createFile', createMutation, true, true);\n};\n\nexport { load, handleUpload };\n"],"mappings":"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","ignoreList":[]}
@@ -12,6 +12,7 @@ var schemaTypes = _interopRequireWildcard(require("./schemaTypes"));
12
12
  var _schemaFields = require("../transformers/schemaFields");
13
13
  var _parseGraphQLUtils = require("../parseGraphQLUtils");
14
14
  var _schemaQueries = require("./schemaQueries");
15
+ var _Error = require("../../Error");
15
16
  function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
16
17
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
17
18
  const load = parseGraphQLSchema => {
@@ -41,9 +42,9 @@ const load = parseGraphQLSchema => {
41
42
  config,
42
43
  auth
43
44
  } = context;
44
- (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth);
45
+ (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth, config);
45
46
  if (auth.isReadOnly) {
46
- throw new _node.default.Error(_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);
47
48
  }
48
49
  const schema = await config.database.loadSchema({
49
50
  clearCache: true
@@ -89,9 +90,9 @@ const load = parseGraphQLSchema => {
89
90
  config,
90
91
  auth
91
92
  } = context;
92
- (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth);
93
+ (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth, config);
93
94
  if (auth.isReadOnly) {
94
- throw new _node.default.Error(_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);
95
96
  }
96
97
  const schema = await config.database.loadSchema({
97
98
  clearCache: true
@@ -133,9 +134,9 @@ const load = parseGraphQLSchema => {
133
134
  config,
134
135
  auth
135
136
  } = context;
136
- (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth);
137
+ (0, _parseGraphQLUtils.enforceMasterKeyAccess)(auth, config);
137
138
  if (auth.isReadOnly) {
138
- throw new _node.default.Error(_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);
139
140
  }
140
141
  const schema = await config.database.loadSchema({
141
142
  clearCache: true
@@ -158,4 +159,4 @@ const load = parseGraphQLSchema => {
158
159
  parseGraphQLSchema.addGraphQLMutation('deleteClass', deleteClassMutation, true, true);
159
160
  };
160
161
  exports.load = load;
161
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_graphql","_deepcopy","_graphqlRelay","schemaTypes","_interopRequireWildcard","_schemaFields","_parseGraphQLUtils","_schemaQueries","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","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';\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 new Parse.Error(\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 new Parse.Error(\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 new Parse.Error(\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":[]}
@@ -10,6 +10,7 @@ var _node = _interopRequireDefault(require("parse/node"));
10
10
  var _rest = _interopRequireDefault(require("../../rest"));
11
11
  var _parseClassTypes = require("./parseClassTypes");
12
12
  var _Auth = require("../../Auth");
13
+ var _Error = require("../../Error");
13
14
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
14
15
  const getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) => {
15
16
  const {
@@ -17,7 +18,7 @@ const getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) =
17
18
  config
18
19
  } = context;
19
20
  if (!info || !info.sessionToken) {
20
- throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
21
+ throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);
21
22
  }
22
23
  const sessionToken = info.sessionToken;
23
24
  const selectedFields = (0, _graphqlListFields.default)(queryInfo).filter(field => field.startsWith(keysPrefix)).map(field => field.replace(keysPrefix, ''));
@@ -59,7 +60,7 @@ const getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) =
59
60
  objectId: context.auth.user.id
60
61
  }, options, info.clientVersion, info.context);
61
62
  if (!response.results || response.results.length == 0) {
62
- throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
63
+ throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);
63
64
  } else {
64
65
  const user = response.results[0];
65
66
  return {
@@ -86,4 +87,4 @@ const load = parseGraphQLSchema => {
86
87
  }, true, true);
87
88
  };
88
89
  exports.load = load;
89
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlListFields","_interopRequireDefault","_node","_rest","_parseClassTypes","_Auth","e","__esModule","default","getUserFromSessionToken","context","queryInfo","keysPrefix","userId","info","config","sessionToken","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';\n\nconst getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) => {\n  const { info, config } = context;\n  if (!info || !info.sessionToken) {\n    throw new Parse.Error(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 new Parse.Error(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":[]}
@@ -8,10 +8,11 @@ exports.getParseClassMutationConfig = exports.extractKeysAndInclude = void 0;
8
8
  exports.toGraphQLError = toGraphQLError;
9
9
  var _node = _interopRequireDefault(require("parse/node"));
10
10
  var _graphql = require("graphql");
11
+ var _Error = require("../Error");
11
12
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
- function enforceMasterKeyAccess(auth) {
13
+ function enforceMasterKeyAccess(auth, config) {
13
14
  if (!auth.isMaster) {
14
- throw new _node.default.Error(_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);
15
16
  }
16
17
  }
17
18
  function toGraphQLError(error) {
@@ -59,4 +60,4 @@ const getParseClassMutationConfig = function (parseClassConfig) {
59
60
  return parseClassConfig && parseClassConfig.mutation || {};
60
61
  };
61
62
  exports.getParseClassMutationConfig = getParseClassMutationConfig;
62
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbm9kZSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX2dyYXBocWwiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJlbmZvcmNlTWFzdGVyS2V5QWNjZXNzIiwiYXV0aCIsImlzTWFzdGVyIiwiUGFyc2UiLCJFcnJvciIsIk9QRVJBVElPTl9GT1JCSURERU4iLCJ0b0dyYXBoUUxFcnJvciIsImVycm9yIiwiY29kZSIsIm1lc3NhZ2UiLCJJTlRFUk5BTF9TRVJWRVJfRVJST1IiLCJHcmFwaFFMRXJyb3IiLCJleHRlbnNpb25zIiwiZXh0cmFjdEtleXNBbmRJbmNsdWRlIiwic2VsZWN0ZWRGaWVsZHMiLCJmaWx0ZXIiLCJmaWVsZCIsImluY2x1ZGVzIiwibWFwIiwiZW5kc1dpdGgiLCJzdWJzdHJpbmciLCJsYXN0SW5kZXhPZiIsImtleXMiLCJ1bmRlZmluZWQiLCJpbmNsdWRlIiwibGVuZ3RoIiwiU2V0Iiwiam9pbiIsImluZGV4T2YiLCJleHBvcnRzIiwiZ2V0UGFyc2VDbGFzc011dGF0aW9uQ29uZmlnIiwicGFyc2VDbGFzc0NvbmZpZyIsIm11dGF0aW9uIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL0dyYXBoUUwvcGFyc2VHcmFwaFFMVXRpbHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFBhcnNlIGZyb20gJ3BhcnNlL25vZGUnO1xuaW1wb3J0IHsgR3JhcGhRTEVycm9yIH0gZnJvbSAnZ3JhcGhxbCc7XG5cbmV4cG9ydCBmdW5jdGlvbiBlbmZvcmNlTWFzdGVyS2V5QWNjZXNzKGF1dGgpIHtcbiAgaWYgKCFhdXRoLmlzTWFzdGVyKSB7XG4gICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFBhcnNlLkVycm9yLk9QRVJBVElPTl9GT1JCSURERU4sICd1bmF1dGhvcml6ZWQ6IG1hc3RlciBrZXkgaXMgcmVxdWlyZWQnKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gdG9HcmFwaFFMRXJyb3IoZXJyb3IpIHtcbiAgbGV0IGNvZGUsIG1lc3NhZ2U7XG4gIGlmIChlcnJvciBpbnN0YW5jZW9mIFBhcnNlLkVycm9yKSB7XG4gICAgY29kZSA9IGVycm9yLmNvZGU7XG4gICAgbWVzc2FnZSA9IGVycm9yLm1lc3NhZ2U7XG4gIH0gZWxzZSB7XG4gICAgY29kZSA9IFBhcnNlLkVycm9yLklOVEVSTkFMX1NFUlZFUl9FUlJPUjtcbiAgICBtZXNzYWdlID0gJ0ludGVybmFsIHNlcnZlciBlcnJvcic7XG4gIH1cbiAgcmV0dXJuIG5ldyBHcmFwaFFMRXJyb3IobWVzc2FnZSwgeyBleHRlbnNpb25zOiB7IGNvZGUgfSB9KTtcbn1cblxuZXhwb3J0IGNvbnN0IGV4dHJhY3RLZXlzQW5kSW5jbHVkZSA9IHNlbGVjdGVkRmllbGRzID0+IHtcbiAgc2VsZWN0ZWRGaWVsZHMgPSBzZWxlY3RlZEZpZWxkcy5maWx0ZXIoZmllbGQgPT4gIWZpZWxkLmluY2x1ZGVzKCdfX3R5cGVuYW1lJykpO1xuICAvLyBIYW5kbGVzIFwiaWRcIiBmaWVsZCBmb3IgYm90aCBjdXJyZW50IGFuZCBpbmNsdWRlZCBvYmplY3RzXG4gIHNlbGVjdGVkRmllbGRzID0gc2VsZWN0ZWRGaWVsZHMubWFwKGZpZWxkID0+IHtcbiAgICBpZiAoZmllbGQgPT09ICdpZCcpIHsgcmV0dXJuICdvYmplY3RJZCc7IH1cbiAgICByZXR1cm4gZmllbGQuZW5kc1dpdGgoJy5pZCcpXG4gICAgICA/IGAke2ZpZWxkLnN1YnN0cmluZygwLCBmaWVsZC5sYXN0SW5kZXhPZignLmlkJykpfS5vYmplY3RJZGBcbiAgICAgIDogZmllbGQ7XG4gIH0pO1xuICBsZXQga2V5cyA9IHVuZGVmaW5lZDtcbiAgbGV0IGluY2x1ZGUgPSB1bmRlZmluZWQ7XG5cbiAgaWYgKHNlbGVjdGVkRmllbGRzLmxlbmd0aCA+IDApIHtcbiAgICBrZXlzID0gWy4uLm5ldyBTZXQoc2VsZWN0ZWRGaWVsZHMpXS5qb2luKCcsJyk7XG4gICAgLy8gV2UgY2FuIHVzZSB0aGlzIHNob3J0Y3V0IHNpbmNlIG9wdGltaXphdGlvbiBpcyBoYW5kbGVkXG4gICAgLy8gbGF0ZXIgb24gUmVzdFF1ZXJ5LCBhdm9pZCBvdmVyaGVhZCBoZXJlLlxuICAgIGluY2x1ZGUgPSBrZXlzO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICAvLyBJZiBhdXRoRGF0YSBpcyBkZXRlY3RlZCBrZXlzIHdpbGwgbm90IHdvcmsgcHJvcGVybHlcbiAgICAvLyBzaW5jZSBhdXRoRGF0YSBoYXMgYSBzcGVjaWFsIHN0b3JhZ2UgYmVoYXZpb3JcbiAgICAvLyBzbyB3ZSBuZWVkIHRvIHNraXAga2V5cyBjdXJyZW50bHlcbiAgICBrZXlzOiBrZXlzICYmIGtleXMuaW5kZXhPZignYXV0aERhdGEnKSA9PT0gLTEgPyBrZXlzIDogdW5kZWZpbmVkLFxuICAgIGluY2x1ZGUsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0UGFyc2VDbGFzc011dGF0aW9uQ29uZmlnID0gZnVuY3Rpb24gKHBhcnNlQ2xhc3NDb25maWcpIHtcbiAgcmV0dXJuIChwYXJzZUNsYXNzQ29uZmlnICYmIHBhcnNlQ2xhc3NDb25maWcubXV0YXRpb24pIHx8IHt9O1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxJQUFBQSxLQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxRQUFBLEdBQUFELE9BQUE7QUFBdUMsU0FBQUQsdUJBQUFHLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFFaEMsU0FBU0csc0JBQXNCQSxDQUFDQyxJQUFJLEVBQUU7RUFDM0MsSUFBSSxDQUFDQSxJQUFJLENBQUNDLFFBQVEsRUFBRTtJQUNsQixNQUFNLElBQUlDLGFBQUssQ0FBQ0MsS0FBSyxDQUFDRCxhQUFLLENBQUNDLEtBQUssQ0FBQ0MsbUJBQW1CLEVBQUUsc0NBQXNDLENBQUM7RUFDaEc7QUFDRjtBQUVPLFNBQVNDLGNBQWNBLENBQUNDLEtBQUssRUFBRTtFQUNwQyxJQUFJQyxJQUFJLEVBQUVDLE9BQU87RUFDakIsSUFBSUYsS0FBSyxZQUFZSixhQUFLLENBQUNDLEtBQUssRUFBRTtJQUNoQ0ksSUFBSSxHQUFHRCxLQUFLLENBQUNDLElBQUk7SUFDakJDLE9BQU8sR0FBR0YsS0FBSyxDQUFDRSxPQUFPO0VBQ3pCLENBQUMsTUFBTTtJQUNMRCxJQUFJLEdBQUdMLGFBQUssQ0FBQ0MsS0FBSyxDQUFDTSxxQkFBcUI7SUFDeENELE9BQU8sR0FBRyx1QkFBdUI7RUFDbkM7RUFDQSxPQUFPLElBQUlFLHFCQUFZLENBQUNGLE9BQU8sRUFBRTtJQUFFRyxVQUFVLEVBQUU7TUFBRUo7SUFBSztFQUFFLENBQUMsQ0FBQztBQUM1RDtBQUVPLE1BQU1LLHFCQUFxQixHQUFHQyxjQUFjLElBQUk7RUFDckRBLGNBQWMsR0FBR0EsY0FBYyxDQUFDQyxNQUFNLENBQUNDLEtBQUssSUFBSSxDQUFDQSxLQUFLLENBQUNDLFFBQVEsQ0FBQyxZQUFZLENBQUMsQ0FBQztFQUM5RTtFQUNBSCxjQUFjLEdBQUdBLGNBQWMsQ0FBQ0ksR0FBRyxDQUFDRixLQUFLLElBQUk7SUFDM0MsSUFBSUEsS0FBSyxLQUFLLElBQUksRUFBRTtNQUFFLE9BQU8sVUFBVTtJQUFFO0lBQ3pDLE9BQU9BLEtBQUssQ0FBQ0csUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUN4QixHQUFHSCxLQUFLLENBQUNJLFNBQVMsQ0FBQyxDQUFDLEVBQUVKLEtBQUssQ0FBQ0ssV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLFdBQVcsR0FDMURMLEtBQUs7RUFDWCxDQUFDLENBQUM7RUFDRixJQUFJTSxJQUFJLEdBQUdDLFNBQVM7RUFDcEIsSUFBSUMsT0FBTyxHQUFHRCxTQUFTO0VBRXZCLElBQUlULGNBQWMsQ0FBQ1csTUFBTSxHQUFHLENBQUMsRUFBRTtJQUM3QkgsSUFBSSxHQUFHLENBQUMsR0FBRyxJQUFJSSxHQUFHLENBQUNaLGNBQWMsQ0FBQyxDQUFDLENBQUNhLElBQUksQ0FBQyxHQUFHLENBQUM7SUFDN0M7SUFDQTtJQUNBSCxPQUFPLEdBQUdGLElBQUk7RUFDaEI7RUFFQSxPQUFPO0lBQ0w7SUFDQTtJQUNBO0lBQ0FBLElBQUksRUFBRUEsSUFBSSxJQUFJQSxJQUFJLENBQUNNLE9BQU8sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBR04sSUFBSSxHQUFHQyxTQUFTO0lBQ2hFQztFQUNGLENBQUM7QUFDSCxDQUFDO0FBQUNLLE9BQUEsQ0FBQWhCLHFCQUFBLEdBQUFBLHFCQUFBO0FBRUssTUFBTWlCLDJCQUEyQixHQUFHLFNBQUFBLENBQVVDLGdCQUFnQixFQUFFO0VBQ3JFLE9BQVFBLGdCQUFnQixJQUFJQSxnQkFBZ0IsQ0FBQ0MsUUFBUSxJQUFLLENBQUMsQ0FBQztBQUM5RCxDQUFDO0FBQUNILE9BQUEsQ0FBQUMsMkJBQUEsR0FBQUEsMkJBQUEiLCJpZ25vcmVMaXN0IjpbXX0=
63
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbm9kZSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX2dyYXBocWwiLCJfRXJyb3IiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJlbmZvcmNlTWFzdGVyS2V5QWNjZXNzIiwiYXV0aCIsImNvbmZpZyIsImlzTWFzdGVyIiwiY3JlYXRlU2FuaXRpemVkRXJyb3IiLCJQYXJzZSIsIkVycm9yIiwiT1BFUkFUSU9OX0ZPUkJJRERFTiIsInRvR3JhcGhRTEVycm9yIiwiZXJyb3IiLCJjb2RlIiwibWVzc2FnZSIsIklOVEVSTkFMX1NFUlZFUl9FUlJPUiIsIkdyYXBoUUxFcnJvciIsImV4dGVuc2lvbnMiLCJleHRyYWN0S2V5c0FuZEluY2x1ZGUiLCJzZWxlY3RlZEZpZWxkcyIsImZpbHRlciIsImZpZWxkIiwiaW5jbHVkZXMiLCJtYXAiLCJlbmRzV2l0aCIsInN1YnN0cmluZyIsImxhc3RJbmRleE9mIiwia2V5cyIsInVuZGVmaW5lZCIsImluY2x1ZGUiLCJsZW5ndGgiLCJTZXQiLCJqb2luIiwiaW5kZXhPZiIsImV4cG9ydHMiLCJnZXRQYXJzZUNsYXNzTXV0YXRpb25Db25maWciLCJwYXJzZUNsYXNzQ29uZmlnIiwibXV0YXRpb24iXSwic291cmNlcyI6WyIuLi8uLi9zcmMvR3JhcGhRTC9wYXJzZUdyYXBoUUxVdGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUGFyc2UgZnJvbSAncGFyc2Uvbm9kZSc7XG5pbXBvcnQgeyBHcmFwaFFMRXJyb3IgfSBmcm9tICdncmFwaHFsJztcbmltcG9ydCB7IGNyZWF0ZVNhbml0aXplZEVycm9yIH0gZnJvbSAnLi4vRXJyb3InO1xuXG5leHBvcnQgZnVuY3Rpb24gZW5mb3JjZU1hc3RlcktleUFjY2VzcyhhdXRoLCBjb25maWcpIHtcbiAgaWYgKCFhdXRoLmlzTWFzdGVyKSB7XG4gICAgdGhyb3cgY3JlYXRlU2FuaXRpemVkRXJyb3IoXG4gICAgICBQYXJzZS5FcnJvci5PUEVSQVRJT05fRk9SQklEREVOLFxuICAgICAgJ3VuYXV0aG9yaXplZDogbWFzdGVyIGtleSBpcyByZXF1aXJlZCcsXG4gICAgICBjb25maWdcbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b0dyYXBoUUxFcnJvcihlcnJvcikge1xuICBsZXQgY29kZSwgbWVzc2FnZTtcbiAgaWYgKGVycm9yIGluc3RhbmNlb2YgUGFyc2UuRXJyb3IpIHtcbiAgICBjb2RlID0gZXJyb3IuY29kZTtcbiAgICBtZXNzYWdlID0gZXJyb3IubWVzc2FnZTtcbiAgfSBlbHNlIHtcbiAgICBjb2RlID0gUGFyc2UuRXJyb3IuSU5URVJOQUxfU0VSVkVSX0VSUk9SO1xuICAgIG1lc3NhZ2UgPSAnSW50ZXJuYWwgc2VydmVyIGVycm9yJztcbiAgfVxuICByZXR1cm4gbmV3IEdyYXBoUUxFcnJvcihtZXNzYWdlLCB7IGV4dGVuc2lvbnM6IHsgY29kZSB9IH0pO1xufVxuXG5leHBvcnQgY29uc3QgZXh0cmFjdEtleXNBbmRJbmNsdWRlID0gc2VsZWN0ZWRGaWVsZHMgPT4ge1xuICBzZWxlY3RlZEZpZWxkcyA9IHNlbGVjdGVkRmllbGRzLmZpbHRlcihmaWVsZCA9PiAhZmllbGQuaW5jbHVkZXMoJ19fdHlwZW5hbWUnKSk7XG4gIC8vIEhhbmRsZXMgXCJpZFwiIGZpZWxkIGZvciBib3RoIGN1cnJlbnQgYW5kIGluY2x1ZGVkIG9iamVjdHNcbiAgc2VsZWN0ZWRGaWVsZHMgPSBzZWxlY3RlZEZpZWxkcy5tYXAoZmllbGQgPT4ge1xuICAgIGlmIChmaWVsZCA9PT0gJ2lkJykgeyByZXR1cm4gJ29iamVjdElkJzsgfVxuICAgIHJldHVybiBmaWVsZC5lbmRzV2l0aCgnLmlkJylcbiAgICAgID8gYCR7ZmllbGQuc3Vic3RyaW5nKDAsIGZpZWxkLmxhc3RJbmRleE9mKCcuaWQnKSl9Lm9iamVjdElkYFxuICAgICAgOiBmaWVsZDtcbiAgfSk7XG4gIGxldCBrZXlzID0gdW5kZWZpbmVkO1xuICBsZXQgaW5jbHVkZSA9IHVuZGVmaW5lZDtcblxuICBpZiAoc2VsZWN0ZWRGaWVsZHMubGVuZ3RoID4gMCkge1xuICAgIGtleXMgPSBbLi4ubmV3IFNldChzZWxlY3RlZEZpZWxkcyldLmpvaW4oJywnKTtcbiAgICAvLyBXZSBjYW4gdXNlIHRoaXMgc2hvcnRjdXQgc2luY2Ugb3B0aW1pemF0aW9uIGlzIGhhbmRsZWRcbiAgICAvLyBsYXRlciBvbiBSZXN0UXVlcnksIGF2b2lkIG92ZXJoZWFkIGhlcmUuXG4gICAgaW5jbHVkZSA9IGtleXM7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIC8vIElmIGF1dGhEYXRhIGlzIGRldGVjdGVkIGtleXMgd2lsbCBub3Qgd29yayBwcm9wZXJseVxuICAgIC8vIHNpbmNlIGF1dGhEYXRhIGhhcyBhIHNwZWNpYWwgc3RvcmFnZSBiZWhhdmlvclxuICAgIC8vIHNvIHdlIG5lZWQgdG8gc2tpcCBrZXlzIGN1cnJlbnRseVxuICAgIGtleXM6IGtleXMgJiYga2V5cy5pbmRleE9mKCdhdXRoRGF0YScpID09PSAtMSA/IGtleXMgOiB1bmRlZmluZWQsXG4gICAgaW5jbHVkZSxcbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYXJzZUNsYXNzTXV0YXRpb25Db25maWcgPSBmdW5jdGlvbiAocGFyc2VDbGFzc0NvbmZpZykge1xuICByZXR1cm4gKHBhcnNlQ2xhc3NDb25maWcgJiYgcGFyc2VDbGFzc0NvbmZpZy5tdXRhdGlvbikgfHwge307XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBLElBQUFBLEtBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLFFBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLE1BQUEsR0FBQUYsT0FBQTtBQUFnRCxTQUFBRCx1QkFBQUksQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUV6QyxTQUFTRyxzQkFBc0JBLENBQUNDLElBQUksRUFBRUMsTUFBTSxFQUFFO0VBQ25ELElBQUksQ0FBQ0QsSUFBSSxDQUFDRSxRQUFRLEVBQUU7SUFDbEIsTUFBTSxJQUFBQywyQkFBb0IsRUFDeEJDLGFBQUssQ0FBQ0MsS0FBSyxDQUFDQyxtQkFBbUIsRUFDL0Isc0NBQXNDLEVBQ3RDTCxNQUNGLENBQUM7RUFDSDtBQUNGO0FBRU8sU0FBU00sY0FBY0EsQ0FBQ0MsS0FBSyxFQUFFO0VBQ3BDLElBQUlDLElBQUksRUFBRUMsT0FBTztFQUNqQixJQUFJRixLQUFLLFlBQVlKLGFBQUssQ0FBQ0MsS0FBSyxFQUFFO0lBQ2hDSSxJQUFJLEdBQUdELEtBQUssQ0FBQ0MsSUFBSTtJQUNqQkMsT0FBTyxHQUFHRixLQUFLLENBQUNFLE9BQU87RUFDekIsQ0FBQyxNQUFNO0lBQ0xELElBQUksR0FBR0wsYUFBSyxDQUFDQyxLQUFLLENBQUNNLHFCQUFxQjtJQUN4Q0QsT0FBTyxHQUFHLHVCQUF1QjtFQUNuQztFQUNBLE9BQU8sSUFBSUUscUJBQVksQ0FBQ0YsT0FBTyxFQUFFO0lBQUVHLFVBQVUsRUFBRTtNQUFFSjtJQUFLO0VBQUUsQ0FBQyxDQUFDO0FBQzVEO0FBRU8sTUFBTUsscUJBQXFCLEdBQUdDLGNBQWMsSUFBSTtFQUNyREEsY0FBYyxHQUFHQSxjQUFjLENBQUNDLE1BQU0sQ0FBQ0MsS0FBSyxJQUFJLENBQUNBLEtBQUssQ0FBQ0MsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO0VBQzlFO0VBQ0FILGNBQWMsR0FBR0EsY0FBYyxDQUFDSSxHQUFHLENBQUNGLEtBQUssSUFBSTtJQUMzQyxJQUFJQSxLQUFLLEtBQUssSUFBSSxFQUFFO01BQUUsT0FBTyxVQUFVO0lBQUU7SUFDekMsT0FBT0EsS0FBSyxDQUFDRyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQ3hCLEdBQUdILEtBQUssQ0FBQ0ksU0FBUyxDQUFDLENBQUMsRUFBRUosS0FBSyxDQUFDSyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUMsV0FBVyxHQUMxREwsS0FBSztFQUNYLENBQUMsQ0FBQztFQUNGLElBQUlNLElBQUksR0FBR0MsU0FBUztFQUNwQixJQUFJQyxPQUFPLEdBQUdELFNBQVM7RUFFdkIsSUFBSVQsY0FBYyxDQUFDVyxNQUFNLEdBQUcsQ0FBQyxFQUFFO0lBQzdCSCxJQUFJLEdBQUcsQ0FBQyxHQUFHLElBQUlJLEdBQUcsQ0FBQ1osY0FBYyxDQUFDLENBQUMsQ0FBQ2EsSUFBSSxDQUFDLEdBQUcsQ0FBQztJQUM3QztJQUNBO0lBQ0FILE9BQU8sR0FBR0YsSUFBSTtFQUNoQjtFQUVBLE9BQU87SUFDTDtJQUNBO0lBQ0E7SUFDQUEsSUFBSSxFQUFFQSxJQUFJLElBQUlBLElBQUksQ0FBQ00sT0FBTyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHTixJQUFJLEdBQUdDLFNBQVM7SUFDaEVDO0VBQ0YsQ0FBQztBQUNILENBQUM7QUFBQ0ssT0FBQSxDQUFBaEIscUJBQUEsR0FBQUEscUJBQUE7QUFFSyxNQUFNaUIsMkJBQTJCLEdBQUcsU0FBQUEsQ0FBVUMsZ0JBQWdCLEVBQUU7RUFDckUsT0FBUUEsZ0JBQWdCLElBQUlBLGdCQUFnQixDQUFDQyxRQUFRLElBQUssQ0FBQyxDQUFDO0FBQzlELENBQUM7QUFBQ0gsT0FBQSxDQUFBQywyQkFBQSxHQUFBQSwyQkFBQSIsImlnbm9yZUxpc3QiOltdfQ==