ParseGraphQLSchema.js 60 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.ParseGraphQLSchema = void 0;
  6. var _node = _interopRequireDefault(require("parse/node"));
  7. var _graphql = require("graphql");
  8. var _schema = require("@graphql-tools/schema");
  9. var _merge = require("@graphql-tools/merge");
  10. var _util = require("util");
  11. var _requiredParameter = _interopRequireDefault(require("../requiredParameter"));
  12. var defaultGraphQLTypes = _interopRequireWildcard(require("./loaders/defaultGraphQLTypes"));
  13. var parseClassTypes = _interopRequireWildcard(require("./loaders/parseClassTypes"));
  14. var parseClassQueries = _interopRequireWildcard(require("./loaders/parseClassQueries"));
  15. var parseClassMutations = _interopRequireWildcard(require("./loaders/parseClassMutations"));
  16. var defaultGraphQLQueries = _interopRequireWildcard(require("./loaders/defaultGraphQLQueries"));
  17. var defaultGraphQLMutations = _interopRequireWildcard(require("./loaders/defaultGraphQLMutations"));
  18. var _ParseGraphQLController = _interopRequireWildcard(require("../Controllers/ParseGraphQLController"));
  19. var _DatabaseController = _interopRequireDefault(require("../Controllers/DatabaseController"));
  20. var _SchemaCache = _interopRequireDefault(require("../Adapters/Cache/SchemaCache"));
  21. var _parseGraphQLUtils = require("./parseGraphQLUtils");
  22. var schemaDirectives = _interopRequireWildcard(require("./loaders/schemaDirectives"));
  23. var schemaTypes = _interopRequireWildcard(require("./loaders/schemaTypes"));
  24. var _triggers = require("../triggers");
  25. var defaultRelaySchema = _interopRequireWildcard(require("./loaders/defaultRelaySchema"));
  26. function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
  27. function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
  28. function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
  29. const RESERVED_GRAPHQL_TYPE_NAMES = ['String', 'Boolean', 'Int', 'Float', 'ID', 'ArrayResult', 'Query', 'Mutation', 'Subscription', 'CreateFileInput', 'CreateFilePayload', 'Viewer', 'SignUpInput', 'SignUpPayload', 'LogInInput', 'LogInPayload', 'LogOutInput', 'LogOutPayload', 'CloudCodeFunction', 'CallCloudCodeInput', 'CallCloudCodePayload', 'CreateClassInput', 'CreateClassPayload', 'UpdateClassInput', 'UpdateClassPayload', 'DeleteClassInput', 'DeleteClassPayload', 'PageInfo'];
  30. const RESERVED_GRAPHQL_QUERY_NAMES = ['health', 'viewer', 'class', 'classes'];
  31. const RESERVED_GRAPHQL_MUTATION_NAMES = ['signUp', 'logIn', 'logOut', 'createFile', 'callCloudCode', 'createClass', 'updateClass', 'deleteClass'];
  32. class ParseGraphQLSchema {
  33. constructor(params = {}) {
  34. this.parseGraphQLController = params.parseGraphQLController || (0, _requiredParameter.default)('You must provide a parseGraphQLController instance!');
  35. this.databaseController = params.databaseController || (0, _requiredParameter.default)('You must provide a databaseController instance!');
  36. this.log = params.log || (0, _requiredParameter.default)('You must provide a log instance!');
  37. this.graphQLCustomTypeDefs = params.graphQLCustomTypeDefs;
  38. this.appId = params.appId || (0, _requiredParameter.default)('You must provide the appId!');
  39. this.schemaCache = _SchemaCache.default;
  40. this.logCache = {};
  41. }
  42. async load() {
  43. const {
  44. parseGraphQLConfig
  45. } = await this._initializeSchemaAndConfig();
  46. const parseClassesArray = await this._getClassesForSchema(parseGraphQLConfig);
  47. const functionNames = await this._getFunctionNames();
  48. const functionNamesString = functionNames.join();
  49. const parseClasses = parseClassesArray.reduce((acc, clazz) => {
  50. acc[clazz.className] = clazz;
  51. return acc;
  52. }, {});
  53. if (!this._hasSchemaInputChanged({
  54. parseClasses,
  55. parseGraphQLConfig,
  56. functionNamesString
  57. })) {
  58. return this.graphQLSchema;
  59. }
  60. this.parseClasses = parseClasses;
  61. this.parseGraphQLConfig = parseGraphQLConfig;
  62. this.functionNames = functionNames;
  63. this.functionNamesString = functionNamesString;
  64. this.parseClassTypes = {};
  65. this.viewerType = null;
  66. this.graphQLAutoSchema = null;
  67. this.graphQLSchema = null;
  68. this.graphQLTypes = [];
  69. this.graphQLQueries = {};
  70. this.graphQLMutations = {};
  71. this.graphQLSubscriptions = {};
  72. this.graphQLSchemaDirectivesDefinitions = null;
  73. this.graphQLSchemaDirectives = {};
  74. this.relayNodeInterface = null;
  75. defaultGraphQLTypes.load(this);
  76. defaultRelaySchema.load(this);
  77. schemaTypes.load(this);
  78. this._getParseClassesWithConfig(parseClassesArray, parseGraphQLConfig).forEach(([parseClass, parseClassConfig]) => {
  79. // Some times schema return the _auth_data_ field
  80. // it will lead to unstable graphql generation order
  81. if (parseClass.className === '_User') {
  82. Object.keys(parseClass.fields).forEach(fieldName => {
  83. if (fieldName.startsWith('_auth_data_')) {
  84. delete parseClass.fields[fieldName];
  85. }
  86. });
  87. }
  88. // Fields order inside the schema seems to not be consistent across
  89. // restart so we need to ensure an alphabetical order
  90. // also it's better for the playground documentation
  91. const orderedFields = {};
  92. Object.keys(parseClass.fields).sort().forEach(fieldName => {
  93. orderedFields[fieldName] = parseClass.fields[fieldName];
  94. });
  95. parseClass.fields = orderedFields;
  96. parseClassTypes.load(this, parseClass, parseClassConfig);
  97. parseClassQueries.load(this, parseClass, parseClassConfig);
  98. parseClassMutations.load(this, parseClass, parseClassConfig);
  99. });
  100. defaultGraphQLTypes.loadArrayResult(this, parseClassesArray);
  101. defaultGraphQLQueries.load(this);
  102. defaultGraphQLMutations.load(this);
  103. let graphQLQuery = undefined;
  104. if (Object.keys(this.graphQLQueries).length > 0) {
  105. graphQLQuery = new _graphql.GraphQLObjectType({
  106. name: 'Query',
  107. description: 'Query is the top level type for queries.',
  108. fields: this.graphQLQueries
  109. });
  110. this.addGraphQLType(graphQLQuery, true, true);
  111. }
  112. let graphQLMutation = undefined;
  113. if (Object.keys(this.graphQLMutations).length > 0) {
  114. graphQLMutation = new _graphql.GraphQLObjectType({
  115. name: 'Mutation',
  116. description: 'Mutation is the top level type for mutations.',
  117. fields: this.graphQLMutations
  118. });
  119. this.addGraphQLType(graphQLMutation, true, true);
  120. }
  121. let graphQLSubscription = undefined;
  122. if (Object.keys(this.graphQLSubscriptions).length > 0) {
  123. graphQLSubscription = new _graphql.GraphQLObjectType({
  124. name: 'Subscription',
  125. description: 'Subscription is the top level type for subscriptions.',
  126. fields: this.graphQLSubscriptions
  127. });
  128. this.addGraphQLType(graphQLSubscription, true, true);
  129. }
  130. this.graphQLAutoSchema = new _graphql.GraphQLSchema({
  131. types: this.graphQLTypes,
  132. query: graphQLQuery,
  133. mutation: graphQLMutation,
  134. subscription: graphQLSubscription
  135. });
  136. if (this.graphQLCustomTypeDefs) {
  137. schemaDirectives.load(this);
  138. if (typeof this.graphQLCustomTypeDefs.getTypeMap === 'function') {
  139. // In following code we use underscore attr to keep the direct variable reference
  140. const customGraphQLSchemaTypeMap = this.graphQLCustomTypeDefs._typeMap;
  141. const findAndReplaceLastType = (parent, key) => {
  142. if (parent[key].name) {
  143. if (this.graphQLAutoSchema._typeMap[parent[key].name] && this.graphQLAutoSchema._typeMap[parent[key].name] !== parent[key]) {
  144. // To avoid unresolved field on overloaded schema
  145. // replace the final type with the auto schema one
  146. parent[key] = this.graphQLAutoSchema._typeMap[parent[key].name];
  147. }
  148. } else {
  149. if (parent[key].ofType) {
  150. findAndReplaceLastType(parent[key], 'ofType');
  151. }
  152. }
  153. };
  154. // Add non shared types from custom schema to auto schema
  155. // note: some non shared types can use some shared types
  156. // so this code need to be ran before the shared types addition
  157. // we use sort to ensure schema consistency over restarts
  158. Object.keys(customGraphQLSchemaTypeMap).sort().forEach(customGraphQLSchemaTypeKey => {
  159. const customGraphQLSchemaType = customGraphQLSchemaTypeMap[customGraphQLSchemaTypeKey];
  160. if (!customGraphQLSchemaType || !customGraphQLSchemaType.name || customGraphQLSchemaType.name.startsWith('__')) {
  161. return;
  162. }
  163. const autoGraphQLSchemaType = this.graphQLAutoSchema._typeMap[customGraphQLSchemaType.name];
  164. if (!autoGraphQLSchemaType) {
  165. this.graphQLAutoSchema._typeMap[customGraphQLSchemaType.name] = customGraphQLSchemaType;
  166. }
  167. });
  168. // Handle shared types
  169. // We pass through each type and ensure that all sub field types are replaced
  170. // we use sort to ensure schema consistency over restarts
  171. Object.keys(customGraphQLSchemaTypeMap).sort().forEach(customGraphQLSchemaTypeKey => {
  172. const customGraphQLSchemaType = customGraphQLSchemaTypeMap[customGraphQLSchemaTypeKey];
  173. if (!customGraphQLSchemaType || !customGraphQLSchemaType.name || customGraphQLSchemaType.name.startsWith('__')) {
  174. return;
  175. }
  176. const autoGraphQLSchemaType = this.graphQLAutoSchema._typeMap[customGraphQLSchemaType.name];
  177. if (autoGraphQLSchemaType && typeof customGraphQLSchemaType.getFields === 'function') {
  178. Object.keys(customGraphQLSchemaType._fields).sort().forEach(fieldKey => {
  179. const field = customGraphQLSchemaType._fields[fieldKey];
  180. findAndReplaceLastType(field, 'type');
  181. autoGraphQLSchemaType._fields[field.name] = field;
  182. });
  183. }
  184. });
  185. this.graphQLSchema = this.graphQLAutoSchema;
  186. } else if (typeof this.graphQLCustomTypeDefs === 'function') {
  187. this.graphQLSchema = await this.graphQLCustomTypeDefs({
  188. directivesDefinitionsSchema: this.graphQLSchemaDirectivesDefinitions,
  189. autoSchema: this.graphQLAutoSchema,
  190. graphQLSchemaDirectives: this.graphQLSchemaDirectives
  191. });
  192. } else {
  193. this.graphQLSchema = (0, _schema.mergeSchemas)({
  194. schemas: [this.graphQLAutoSchema],
  195. typeDefs: (0, _merge.mergeTypeDefs)([this.graphQLCustomTypeDefs, this.graphQLSchemaDirectivesDefinitions])
  196. });
  197. this.graphQLSchema = this.graphQLSchemaDirectives(this.graphQLSchema);
  198. }
  199. } else {
  200. this.graphQLSchema = this.graphQLAutoSchema;
  201. }
  202. return this.graphQLSchema;
  203. }
  204. _logOnce(severity, message) {
  205. if (this.logCache[message]) {
  206. return;
  207. }
  208. this.log[severity](message);
  209. this.logCache[message] = true;
  210. }
  211. addGraphQLType(type, throwError = false, ignoreReserved = false, ignoreConnection = false) {
  212. if (!ignoreReserved && RESERVED_GRAPHQL_TYPE_NAMES.includes(type.name) || this.graphQLTypes.find(existingType => existingType.name === type.name) || !ignoreConnection && type.name.endsWith('Connection')) {
  213. const message = `Type ${type.name} could not be added to the auto schema because it collided with an existing type.`;
  214. if (throwError) {
  215. throw new Error(message);
  216. }
  217. this._logOnce('warn', message);
  218. return undefined;
  219. }
  220. this.graphQLTypes.push(type);
  221. return type;
  222. }
  223. addGraphQLQuery(fieldName, field, throwError = false, ignoreReserved = false) {
  224. if (!ignoreReserved && RESERVED_GRAPHQL_QUERY_NAMES.includes(fieldName) || this.graphQLQueries[fieldName]) {
  225. const message = `Query ${fieldName} could not be added to the auto schema because it collided with an existing field.`;
  226. if (throwError) {
  227. throw new Error(message);
  228. }
  229. this._logOnce('warn', message);
  230. return undefined;
  231. }
  232. this.graphQLQueries[fieldName] = field;
  233. return field;
  234. }
  235. addGraphQLMutation(fieldName, field, throwError = false, ignoreReserved = false) {
  236. if (!ignoreReserved && RESERVED_GRAPHQL_MUTATION_NAMES.includes(fieldName) || this.graphQLMutations[fieldName]) {
  237. const message = `Mutation ${fieldName} could not be added to the auto schema because it collided with an existing field.`;
  238. if (throwError) {
  239. throw new Error(message);
  240. }
  241. this._logOnce('warn', message);
  242. return undefined;
  243. }
  244. this.graphQLMutations[fieldName] = field;
  245. return field;
  246. }
  247. handleError(error) {
  248. if (error instanceof _node.default.Error) {
  249. this.log.error('Parse error: ', error);
  250. } else {
  251. this.log.error('Uncaught internal server error.', error, error.stack);
  252. }
  253. throw (0, _parseGraphQLUtils.toGraphQLError)(error);
  254. }
  255. async _initializeSchemaAndConfig() {
  256. const [schemaController, parseGraphQLConfig] = await Promise.all([this.databaseController.loadSchema(), this.parseGraphQLController.getGraphQLConfig()]);
  257. this.schemaController = schemaController;
  258. return {
  259. parseGraphQLConfig
  260. };
  261. }
  262. /**
  263. * Gets all classes found by the `schemaController`
  264. * minus those filtered out by the app's parseGraphQLConfig.
  265. */
  266. async _getClassesForSchema(parseGraphQLConfig) {
  267. const {
  268. enabledForClasses,
  269. disabledForClasses
  270. } = parseGraphQLConfig;
  271. const allClasses = await this.schemaController.getAllClasses();
  272. if (Array.isArray(enabledForClasses) || Array.isArray(disabledForClasses)) {
  273. let includedClasses = allClasses;
  274. if (enabledForClasses) {
  275. includedClasses = allClasses.filter(clazz => {
  276. return enabledForClasses.includes(clazz.className);
  277. });
  278. }
  279. if (disabledForClasses) {
  280. // Classes included in `enabledForClasses` that
  281. // are also present in `disabledForClasses` will
  282. // still be filtered out
  283. includedClasses = includedClasses.filter(clazz => {
  284. return !disabledForClasses.includes(clazz.className);
  285. });
  286. }
  287. this.isUsersClassDisabled = !includedClasses.some(clazz => {
  288. return clazz.className === '_User';
  289. });
  290. return includedClasses;
  291. } else {
  292. return allClasses;
  293. }
  294. }
  295. /**
  296. * This method returns a list of tuples
  297. * that provide the parseClass along with
  298. * its parseClassConfig where provided.
  299. */
  300. _getParseClassesWithConfig(parseClasses, parseGraphQLConfig) {
  301. const {
  302. classConfigs
  303. } = parseGraphQLConfig;
  304. // Make sures that the default classes and classes that
  305. // starts with capitalized letter will be generated first.
  306. const sortClasses = (a, b) => {
  307. a = a.className;
  308. b = b.className;
  309. if (a[0] === '_') {
  310. if (b[0] !== '_') {
  311. return -1;
  312. }
  313. }
  314. if (b[0] === '_') {
  315. if (a[0] !== '_') {
  316. return 1;
  317. }
  318. }
  319. if (a === b) {
  320. return 0;
  321. } else if (a < b) {
  322. return -1;
  323. } else {
  324. return 1;
  325. }
  326. };
  327. return parseClasses.sort(sortClasses).map(parseClass => {
  328. let parseClassConfig;
  329. if (classConfigs) {
  330. parseClassConfig = classConfigs.find(c => c.className === parseClass.className);
  331. }
  332. return [parseClass, parseClassConfig];
  333. });
  334. }
  335. async _getFunctionNames() {
  336. return await (0, _triggers.getFunctionNames)(this.appId).filter(functionName => {
  337. if (/^[_a-zA-Z][_a-zA-Z0-9]*$/.test(functionName)) {
  338. return true;
  339. } else {
  340. this._logOnce('warn', `Function ${functionName} could not be added to the auto schema because GraphQL names must match /^[_a-zA-Z][_a-zA-Z0-9]*$/.`);
  341. return false;
  342. }
  343. });
  344. }
  345. /**
  346. * Checks for changes to the parseClasses
  347. * objects (i.e. database schema) or to
  348. * the parseGraphQLConfig object. If no
  349. * changes are found, return true;
  350. */
  351. _hasSchemaInputChanged(params) {
  352. const {
  353. parseClasses,
  354. parseGraphQLConfig,
  355. functionNamesString
  356. } = params;
  357. // First init
  358. if (!this.graphQLSchema) {
  359. return true;
  360. }
  361. if ((0, _util.isDeepStrictEqual)(this.parseGraphQLConfig, parseGraphQLConfig) && this.functionNamesString === functionNamesString && (0, _util.isDeepStrictEqual)(this.parseClasses, parseClasses)) {
  362. return false;
  363. }
  364. return true;
  365. }
  366. }
  367. exports.ParseGraphQLSchema = ParseGraphQLSchema;
  368. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_graphql","_schema","_merge","_util","_requiredParameter","defaultGraphQLTypes","_interopRequireWildcard","parseClassTypes","parseClassQueries","parseClassMutations","defaultGraphQLQueries","defaultGraphQLMutations","_ParseGraphQLController","_DatabaseController","_SchemaCache","_parseGraphQLUtils","schemaDirectives","schemaTypes","_triggers","defaultRelaySchema","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","RESERVED_GRAPHQL_TYPE_NAMES","RESERVED_GRAPHQL_QUERY_NAMES","RESERVED_GRAPHQL_MUTATION_NAMES","ParseGraphQLSchema","constructor","params","parseGraphQLController","requiredParameter","databaseController","log","graphQLCustomTypeDefs","appId","schemaCache","SchemaCache","logCache","load","parseGraphQLConfig","_initializeSchemaAndConfig","parseClassesArray","_getClassesForSchema","functionNames","_getFunctionNames","functionNamesString","join","parseClasses","reduce","acc","clazz","className","_hasSchemaInputChanged","graphQLSchema","viewerType","graphQLAutoSchema","graphQLTypes","graphQLQueries","graphQLMutations","graphQLSubscriptions","graphQLSchemaDirectivesDefinitions","graphQLSchemaDirectives","relayNodeInterface","_getParseClassesWithConfig","forEach","parseClass","parseClassConfig","keys","fields","fieldName","startsWith","orderedFields","sort","loadArrayResult","graphQLQuery","undefined","length","GraphQLObjectType","name","description","addGraphQLType","graphQLMutation","graphQLSubscription","GraphQLSchema","types","query","mutation","subscription","getTypeMap","customGraphQLSchemaTypeMap","_typeMap","findAndReplaceLastType","parent","key","ofType","customGraphQLSchemaTypeKey","customGraphQLSchemaType","autoGraphQLSchemaType","getFields","_fields","fieldKey","field","directivesDefinitionsSchema","autoSchema","mergeSchemas","schemas","typeDefs","mergeTypeDefs","_logOnce","severity","message","type","throwError","ignoreReserved","ignoreConnection","includes","find","existingType","endsWith","Error","push","addGraphQLQuery","addGraphQLMutation","handleError","error","Parse","stack","toGraphQLError","schemaController","Promise","all","loadSchema","getGraphQLConfig","enabledForClasses","disabledForClasses","allClasses","getAllClasses","Array","isArray","includedClasses","filter","isUsersClassDisabled","some","classConfigs","sortClasses","b","map","c","getFunctionNames","functionName","test","isDeepStrictEqual","exports"],"sources":["../../src/GraphQL/ParseGraphQLSchema.js"],"sourcesContent":["import Parse from 'parse/node';\nimport { GraphQLSchema, GraphQLObjectType, DocumentNode, GraphQLNamedType } from 'graphql';\nimport { mergeSchemas } from '@graphql-tools/schema';\nimport { mergeTypeDefs } from '@graphql-tools/merge';\nimport { isDeepStrictEqual } from 'util';\nimport requiredParameter from '../requiredParameter';\nimport * as defaultGraphQLTypes from './loaders/defaultGraphQLTypes';\nimport * as parseClassTypes from './loaders/parseClassTypes';\nimport * as parseClassQueries from './loaders/parseClassQueries';\nimport * as parseClassMutations from './loaders/parseClassMutations';\nimport * as defaultGraphQLQueries from './loaders/defaultGraphQLQueries';\nimport * as defaultGraphQLMutations from './loaders/defaultGraphQLMutations';\nimport ParseGraphQLController, { ParseGraphQLConfig } from '../Controllers/ParseGraphQLController';\nimport DatabaseController from '../Controllers/DatabaseController';\nimport SchemaCache from '../Adapters/Cache/SchemaCache';\nimport { toGraphQLError } from './parseGraphQLUtils';\nimport * as schemaDirectives from './loaders/schemaDirectives';\nimport * as schemaTypes from './loaders/schemaTypes';\nimport { getFunctionNames } from '../triggers';\nimport * as defaultRelaySchema from './loaders/defaultRelaySchema';\n\nconst RESERVED_GRAPHQL_TYPE_NAMES = [\n  'String',\n  'Boolean',\n  'Int',\n  'Float',\n  'ID',\n  'ArrayResult',\n  'Query',\n  'Mutation',\n  'Subscription',\n  'CreateFileInput',\n  'CreateFilePayload',\n  'Viewer',\n  'SignUpInput',\n  'SignUpPayload',\n  'LogInInput',\n  'LogInPayload',\n  'LogOutInput',\n  'LogOutPayload',\n  'CloudCodeFunction',\n  'CallCloudCodeInput',\n  'CallCloudCodePayload',\n  'CreateClassInput',\n  'CreateClassPayload',\n  'UpdateClassInput',\n  'UpdateClassPayload',\n  'DeleteClassInput',\n  'DeleteClassPayload',\n  'PageInfo',\n];\nconst RESERVED_GRAPHQL_QUERY_NAMES = ['health', 'viewer', 'class', 'classes'];\nconst RESERVED_GRAPHQL_MUTATION_NAMES = [\n  'signUp',\n  'logIn',\n  'logOut',\n  'createFile',\n  'callCloudCode',\n  'createClass',\n  'updateClass',\n  'deleteClass',\n];\n\nclass ParseGraphQLSchema {\n  databaseController: DatabaseController;\n  parseGraphQLController: ParseGraphQLController;\n  parseGraphQLConfig: ParseGraphQLConfig;\n  log: any;\n  appId: string;\n  graphQLCustomTypeDefs: ?(string | GraphQLSchema | DocumentNode | GraphQLNamedType[]);\n  schemaCache: any;\n\n  constructor(\n    params: {\n      databaseController: DatabaseController,\n      parseGraphQLController: ParseGraphQLController,\n      log: any,\n      appId: string,\n      graphQLCustomTypeDefs: ?(string | GraphQLSchema | DocumentNode | GraphQLNamedType[]),\n    } = {}\n  ) {\n    this.parseGraphQLController =\n      params.parseGraphQLController ||\n      requiredParameter('You must provide a parseGraphQLController instance!');\n    this.databaseController =\n      params.databaseController ||\n      requiredParameter('You must provide a databaseController instance!');\n    this.log = params.log || requiredParameter('You must provide a log instance!');\n    this.graphQLCustomTypeDefs = params.graphQLCustomTypeDefs;\n    this.appId = params.appId || requiredParameter('You must provide the appId!');\n    this.schemaCache = SchemaCache;\n    this.logCache = {};\n  }\n\n  async load() {\n    const { parseGraphQLConfig } = await this._initializeSchemaAndConfig();\n    const parseClassesArray = await this._getClassesForSchema(parseGraphQLConfig);\n    const functionNames = await this._getFunctionNames();\n    const functionNamesString = functionNames.join();\n\n    const parseClasses = parseClassesArray.reduce((acc, clazz) => {\n      acc[clazz.className] = clazz;\n      return acc;\n    }, {});\n    if (\n      !this._hasSchemaInputChanged({\n        parseClasses,\n        parseGraphQLConfig,\n        functionNamesString,\n      })\n    ) {\n      return this.graphQLSchema;\n    }\n\n    this.parseClasses = parseClasses;\n    this.parseGraphQLConfig = parseGraphQLConfig;\n    this.functionNames = functionNames;\n    this.functionNamesString = functionNamesString;\n    this.parseClassTypes = {};\n    this.viewerType = null;\n    this.graphQLAutoSchema = null;\n    this.graphQLSchema = null;\n    this.graphQLTypes = [];\n    this.graphQLQueries = {};\n    this.graphQLMutations = {};\n    this.graphQLSubscriptions = {};\n    this.graphQLSchemaDirectivesDefinitions = null;\n    this.graphQLSchemaDirectives = {};\n    this.relayNodeInterface = null;\n\n    defaultGraphQLTypes.load(this);\n    defaultRelaySchema.load(this);\n    schemaTypes.load(this);\n\n    this._getParseClassesWithConfig(parseClassesArray, parseGraphQLConfig).forEach(\n      ([parseClass, parseClassConfig]) => {\n        // Some times schema return the _auth_data_ field\n        // it will lead to unstable graphql generation order\n        if (parseClass.className === '_User') {\n          Object.keys(parseClass.fields).forEach(fieldName => {\n            if (fieldName.startsWith('_auth_data_')) {\n              delete parseClass.fields[fieldName];\n            }\n          });\n        }\n\n        // Fields order inside the schema seems to not be consistent across\n        // restart so we need to ensure an alphabetical order\n        // also it's better for the playground documentation\n        const orderedFields = {};\n        Object.keys(parseClass.fields)\n          .sort()\n          .forEach(fieldName => {\n            orderedFields[fieldName] = parseClass.fields[fieldName];\n          });\n        parseClass.fields = orderedFields;\n        parseClassTypes.load(this, parseClass, parseClassConfig);\n        parseClassQueries.load(this, parseClass, parseClassConfig);\n        parseClassMutations.load(this, parseClass, parseClassConfig);\n      }\n    );\n\n    defaultGraphQLTypes.loadArrayResult(this, parseClassesArray);\n    defaultGraphQLQueries.load(this);\n    defaultGraphQLMutations.load(this);\n\n    let graphQLQuery = undefined;\n    if (Object.keys(this.graphQLQueries).length > 0) {\n      graphQLQuery = new GraphQLObjectType({\n        name: 'Query',\n        description: 'Query is the top level type for queries.',\n        fields: this.graphQLQueries,\n      });\n      this.addGraphQLType(graphQLQuery, true, true);\n    }\n\n    let graphQLMutation = undefined;\n    if (Object.keys(this.graphQLMutations).length > 0) {\n      graphQLMutation = new GraphQLObjectType({\n        name: 'Mutation',\n        description: 'Mutation is the top level type for mutations.',\n        fields: this.graphQLMutations,\n      });\n      this.addGraphQLType(graphQLMutation, true, true);\n    }\n\n    let graphQLSubscription = undefined;\n    if (Object.keys(this.graphQLSubscriptions).length > 0) {\n      graphQLSubscription = new GraphQLObjectType({\n        name: 'Subscription',\n        description: 'Subscription is the top level type for subscriptions.',\n        fields: this.graphQLSubscriptions,\n      });\n      this.addGraphQLType(graphQLSubscription, true, true);\n    }\n\n    this.graphQLAutoSchema = new GraphQLSchema({\n      types: this.graphQLTypes,\n      query: graphQLQuery,\n      mutation: graphQLMutation,\n      subscription: graphQLSubscription,\n    });\n\n    if (this.graphQLCustomTypeDefs) {\n      schemaDirectives.load(this);\n      if (typeof this.graphQLCustomTypeDefs.getTypeMap === 'function') {\n        // In following code we use underscore attr to keep the direct variable reference\n        const customGraphQLSchemaTypeMap = this.graphQLCustomTypeDefs._typeMap;\n        const findAndReplaceLastType = (parent, key) => {\n          if (parent[key].name) {\n            if (\n              this.graphQLAutoSchema._typeMap[parent[key].name] &&\n              this.graphQLAutoSchema._typeMap[parent[key].name] !== parent[key]\n            ) {\n              // To avoid unresolved field on overloaded schema\n              // replace the final type with the auto schema one\n              parent[key] = this.graphQLAutoSchema._typeMap[parent[key].name];\n            }\n          } else {\n            if (parent[key].ofType) {\n              findAndReplaceLastType(parent[key], 'ofType');\n            }\n          }\n        };\n        // Add non shared types from custom schema to auto schema\n        // note: some non shared types can use some shared types\n        // so this code need to be ran before the shared types addition\n        // we use sort to ensure schema consistency over restarts\n        Object.keys(customGraphQLSchemaTypeMap)\n          .sort()\n          .forEach(customGraphQLSchemaTypeKey => {\n            const customGraphQLSchemaType = customGraphQLSchemaTypeMap[customGraphQLSchemaTypeKey];\n            if (\n              !customGraphQLSchemaType ||\n              !customGraphQLSchemaType.name ||\n              customGraphQLSchemaType.name.startsWith('__')\n            ) {\n              return;\n            }\n            const autoGraphQLSchemaType = this.graphQLAutoSchema._typeMap[\n              customGraphQLSchemaType.name\n            ];\n            if (!autoGraphQLSchemaType) {\n              this.graphQLAutoSchema._typeMap[\n                customGraphQLSchemaType.name\n              ] = customGraphQLSchemaType;\n            }\n          });\n        // Handle shared types\n        // We pass through each type and ensure that all sub field types are replaced\n        // we use sort to ensure schema consistency over restarts\n        Object.keys(customGraphQLSchemaTypeMap)\n          .sort()\n          .forEach(customGraphQLSchemaTypeKey => {\n            const customGraphQLSchemaType = customGraphQLSchemaTypeMap[customGraphQLSchemaTypeKey];\n            if (\n              !customGraphQLSchemaType ||\n              !customGraphQLSchemaType.name ||\n              customGraphQLSchemaType.name.startsWith('__')\n            ) {\n              return;\n            }\n            const autoGraphQLSchemaType = this.graphQLAutoSchema._typeMap[\n              customGraphQLSchemaType.name\n            ];\n\n            if (autoGraphQLSchemaType && typeof customGraphQLSchemaType.getFields === 'function') {\n              Object.keys(customGraphQLSchemaType._fields)\n                .sort()\n                .forEach(fieldKey => {\n                  const field = customGraphQLSchemaType._fields[fieldKey];\n                  findAndReplaceLastType(field, 'type');\n                  autoGraphQLSchemaType._fields[field.name] = field;\n                });\n            }\n          });\n        this.graphQLSchema = this.graphQLAutoSchema;\n      } else if (typeof this.graphQLCustomTypeDefs === 'function') {\n        this.graphQLSchema = await this.graphQLCustomTypeDefs({\n          directivesDefinitionsSchema: this.graphQLSchemaDirectivesDefinitions,\n          autoSchema: this.graphQLAutoSchema,\n          graphQLSchemaDirectives: this.graphQLSchemaDirectives,\n        });\n      } else {\n        this.graphQLSchema = mergeSchemas({\n          schemas: [this.graphQLAutoSchema],\n          typeDefs: mergeTypeDefs([\n            this.graphQLCustomTypeDefs,\n            this.graphQLSchemaDirectivesDefinitions,\n          ]),\n        });\n        this.graphQLSchema = this.graphQLSchemaDirectives(this.graphQLSchema);\n      }\n    } else {\n      this.graphQLSchema = this.graphQLAutoSchema;\n    }\n\n    return this.graphQLSchema;\n  }\n\n  _logOnce(severity, message) {\n    if (this.logCache[message]) {\n      return;\n    }\n    this.log[severity](message);\n    this.logCache[message] = true;\n  }\n\n  addGraphQLType(type, throwError = false, ignoreReserved = false, ignoreConnection = false) {\n    if (\n      (!ignoreReserved && RESERVED_GRAPHQL_TYPE_NAMES.includes(type.name)) ||\n      this.graphQLTypes.find(existingType => existingType.name === type.name) ||\n      (!ignoreConnection && type.name.endsWith('Connection'))\n    ) {\n      const message = `Type ${type.name} could not be added to the auto schema because it collided with an existing type.`;\n      if (throwError) {\n        throw new Error(message);\n      }\n      this._logOnce('warn', message);\n      return undefined;\n    }\n    this.graphQLTypes.push(type);\n    return type;\n  }\n\n  addGraphQLQuery(fieldName, field, throwError = false, ignoreReserved = false) {\n    if (\n      (!ignoreReserved && RESERVED_GRAPHQL_QUERY_NAMES.includes(fieldName)) ||\n      this.graphQLQueries[fieldName]\n    ) {\n      const message = `Query ${fieldName} could not be added to the auto schema because it collided with an existing field.`;\n      if (throwError) {\n        throw new Error(message);\n      }\n      this._logOnce('warn', message);\n      return undefined;\n    }\n    this.graphQLQueries[fieldName] = field;\n    return field;\n  }\n\n  addGraphQLMutation(fieldName, field, throwError = false, ignoreReserved = false) {\n    if (\n      (!ignoreReserved && RESERVED_GRAPHQL_MUTATION_NAMES.includes(fieldName)) ||\n      this.graphQLMutations[fieldName]\n    ) {\n      const message = `Mutation ${fieldName} could not be added to the auto schema because it collided with an existing field.`;\n      if (throwError) {\n        throw new Error(message);\n      }\n      this._logOnce('warn', message);\n      return undefined;\n    }\n    this.graphQLMutations[fieldName] = field;\n    return field;\n  }\n\n  handleError(error) {\n    if (error instanceof Parse.Error) {\n      this.log.error('Parse error: ', error);\n    } else {\n      this.log.error('Uncaught internal server error.', error, error.stack);\n    }\n    throw toGraphQLError(error);\n  }\n\n  async _initializeSchemaAndConfig() {\n    const [schemaController, parseGraphQLConfig] = await Promise.all([\n      this.databaseController.loadSchema(),\n      this.parseGraphQLController.getGraphQLConfig(),\n    ]);\n\n    this.schemaController = schemaController;\n\n    return {\n      parseGraphQLConfig,\n    };\n  }\n\n  /**\n   * Gets all classes found by the `schemaController`\n   * minus those filtered out by the app's parseGraphQLConfig.\n   */\n  async _getClassesForSchema(parseGraphQLConfig: ParseGraphQLConfig) {\n    const { enabledForClasses, disabledForClasses } = parseGraphQLConfig;\n    const allClasses = await this.schemaController.getAllClasses();\n\n    if (Array.isArray(enabledForClasses) || Array.isArray(disabledForClasses)) {\n      let includedClasses = allClasses;\n      if (enabledForClasses) {\n        includedClasses = allClasses.filter(clazz => {\n          return enabledForClasses.includes(clazz.className);\n        });\n      }\n      if (disabledForClasses) {\n        // Classes included in `enabledForClasses` that\n        // are also present in `disabledForClasses` will\n        // still be filtered out\n        includedClasses = includedClasses.filter(clazz => {\n          return !disabledForClasses.includes(clazz.className);\n        });\n      }\n\n      this.isUsersClassDisabled = !includedClasses.some(clazz => {\n        return clazz.className === '_User';\n      });\n\n      return includedClasses;\n    } else {\n      return allClasses;\n    }\n  }\n\n  /**\n   * This method returns a list of tuples\n   * that provide the parseClass along with\n   * its parseClassConfig where provided.\n   */\n  _getParseClassesWithConfig(parseClasses, parseGraphQLConfig: ParseGraphQLConfig) {\n    const { classConfigs } = parseGraphQLConfig;\n\n    // Make sures that the default classes and classes that\n    // starts with capitalized letter will be generated first.\n    const sortClasses = (a, b) => {\n      a = a.className;\n      b = b.className;\n      if (a[0] === '_') {\n        if (b[0] !== '_') {\n          return -1;\n        }\n      }\n      if (b[0] === '_') {\n        if (a[0] !== '_') {\n          return 1;\n        }\n      }\n      if (a === b) {\n        return 0;\n      } else if (a < b) {\n        return -1;\n      } else {\n        return 1;\n      }\n    };\n\n    return parseClasses.sort(sortClasses).map(parseClass => {\n      let parseClassConfig;\n      if (classConfigs) {\n        parseClassConfig = classConfigs.find(c => c.className === parseClass.className);\n      }\n      return [parseClass, parseClassConfig];\n    });\n  }\n\n  async _getFunctionNames() {\n    return await getFunctionNames(this.appId).filter(functionName => {\n      if (/^[_a-zA-Z][_a-zA-Z0-9]*$/.test(functionName)) {\n        return true;\n      } else {\n        this._logOnce(\n          'warn',\n          `Function ${functionName} could not be added to the auto schema because GraphQL names must match /^[_a-zA-Z][_a-zA-Z0-9]*$/.`\n        );\n        return false;\n      }\n    });\n  }\n\n  /**\n   * Checks for changes to the parseClasses\n   * objects (i.e. database schema) or to\n   * the parseGraphQLConfig object. If no\n   * changes are found, return true;\n   */\n  _hasSchemaInputChanged(params: {\n    parseClasses: any,\n    parseGraphQLConfig: ?ParseGraphQLConfig,\n    functionNamesString: string,\n  }): boolean {\n    const { parseClasses, parseGraphQLConfig, functionNamesString } = params;\n\n    // First init\n    if (!this.graphQLSchema) {\n      return true;\n    }\n\n    if (\n      isDeepStrictEqual(this.parseGraphQLConfig, parseGraphQLConfig) &&\n      this.functionNamesString === functionNamesString &&\n      isDeepStrictEqual(this.parseClasses, parseClasses)\n    ) {\n      return false;\n    }\n    return true;\n  }\n}\n\nexport { ParseGraphQLSchema };\n"],"mappings":"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","ignoreList":[]}