parse-server 2.8.4 → 8.6.2

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 (240) hide show
  1. package/LICENSE +167 -25
  2. package/NOTICE +10 -0
  3. package/README.md +929 -278
  4. package/lib/AccountLockout.js +47 -30
  5. package/lib/Adapters/AdapterLoader.js +21 -6
  6. package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
  7. package/lib/Adapters/Auth/AuthAdapter.js +116 -13
  8. package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
  9. package/lib/Adapters/Auth/OAuth1Client.js +27 -46
  10. package/lib/Adapters/Auth/apple.js +123 -0
  11. package/lib/Adapters/Auth/facebook.js +162 -35
  12. package/lib/Adapters/Auth/gcenter.js +217 -0
  13. package/lib/Adapters/Auth/github.js +118 -48
  14. package/lib/Adapters/Auth/google.js +160 -51
  15. package/lib/Adapters/Auth/gpgames.js +125 -0
  16. package/lib/Adapters/Auth/httpsRequest.js +6 -7
  17. package/lib/Adapters/Auth/index.js +170 -62
  18. package/lib/Adapters/Auth/instagram.js +114 -40
  19. package/lib/Adapters/Auth/janraincapture.js +52 -23
  20. package/lib/Adapters/Auth/janrainengage.js +19 -36
  21. package/lib/Adapters/Auth/keycloak.js +148 -0
  22. package/lib/Adapters/Auth/ldap.js +167 -0
  23. package/lib/Adapters/Auth/line.js +125 -0
  24. package/lib/Adapters/Auth/linkedin.js +111 -55
  25. package/lib/Adapters/Auth/meetup.js +24 -34
  26. package/lib/Adapters/Auth/mfa.js +324 -0
  27. package/lib/Adapters/Auth/microsoft.js +111 -0
  28. package/lib/Adapters/Auth/oauth2.js +97 -162
  29. package/lib/Adapters/Auth/phantauth.js +53 -0
  30. package/lib/Adapters/Auth/qq.js +108 -49
  31. package/lib/Adapters/Auth/spotify.js +107 -55
  32. package/lib/Adapters/Auth/twitter.js +188 -48
  33. package/lib/Adapters/Auth/utils.js +28 -0
  34. package/lib/Adapters/Auth/vkontakte.js +26 -39
  35. package/lib/Adapters/Auth/wechat.js +106 -44
  36. package/lib/Adapters/Auth/weibo.js +132 -58
  37. package/lib/Adapters/Cache/CacheAdapter.js +13 -8
  38. package/lib/Adapters/Cache/InMemoryCache.js +3 -13
  39. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
  40. package/lib/Adapters/Cache/LRUCache.js +13 -27
  41. package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
  42. package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
  43. package/lib/Adapters/Cache/SchemaCache.js +25 -0
  44. package/lib/Adapters/Email/MailAdapter.js +10 -8
  45. package/lib/Adapters/Files/FilesAdapter.js +83 -25
  46. package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
  47. package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
  48. package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
  49. package/lib/Adapters/Logger/WinstonLogger.js +69 -88
  50. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
  51. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
  52. package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
  53. package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
  54. package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
  55. package/lib/Adapters/Push/PushAdapter.js +14 -7
  56. package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
  57. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
  58. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
  59. package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
  60. package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
  61. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
  62. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
  63. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
  64. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  65. package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
  66. package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
  67. package/lib/Auth.js +488 -125
  68. package/lib/ClientSDK.js +2 -6
  69. package/lib/Config.js +525 -94
  70. package/lib/Controllers/AdaptableController.js +5 -25
  71. package/lib/Controllers/AnalyticsController.js +22 -23
  72. package/lib/Controllers/CacheController.js +10 -31
  73. package/lib/Controllers/DatabaseController.js +767 -313
  74. package/lib/Controllers/FilesController.js +49 -54
  75. package/lib/Controllers/HooksController.js +80 -84
  76. package/lib/Controllers/LiveQueryController.js +35 -22
  77. package/lib/Controllers/LoggerController.js +22 -58
  78. package/lib/Controllers/ParseGraphQLController.js +293 -0
  79. package/lib/Controllers/PushController.js +58 -49
  80. package/lib/Controllers/SchemaController.js +916 -422
  81. package/lib/Controllers/UserController.js +265 -180
  82. package/lib/Controllers/index.js +90 -125
  83. package/lib/Controllers/types.js +1 -1
  84. package/lib/Deprecator/Deprecations.js +30 -0
  85. package/lib/Deprecator/Deprecator.js +127 -0
  86. package/lib/Error.js +48 -0
  87. package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
  88. package/lib/GraphQL/ParseGraphQLServer.js +214 -0
  89. package/lib/GraphQL/helpers/objectsMutations.js +30 -0
  90. package/lib/GraphQL/helpers/objectsQueries.js +246 -0
  91. package/lib/GraphQL/loaders/configMutations.js +87 -0
  92. package/lib/GraphQL/loaders/configQueries.js +79 -0
  93. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
  94. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
  95. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
  96. package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
  97. package/lib/GraphQL/loaders/filesMutations.js +107 -0
  98. package/lib/GraphQL/loaders/functionsMutations.js +78 -0
  99. package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
  100. package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
  101. package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
  102. package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
  103. package/lib/GraphQL/loaders/schemaMutations.js +162 -0
  104. package/lib/GraphQL/loaders/schemaQueries.js +81 -0
  105. package/lib/GraphQL/loaders/schemaTypes.js +341 -0
  106. package/lib/GraphQL/loaders/usersMutations.js +433 -0
  107. package/lib/GraphQL/loaders/usersQueries.js +90 -0
  108. package/lib/GraphQL/parseGraphQLUtils.js +63 -0
  109. package/lib/GraphQL/transformers/className.js +14 -0
  110. package/lib/GraphQL/transformers/constraintType.js +53 -0
  111. package/lib/GraphQL/transformers/inputType.js +51 -0
  112. package/lib/GraphQL/transformers/mutation.js +274 -0
  113. package/lib/GraphQL/transformers/outputType.js +51 -0
  114. package/lib/GraphQL/transformers/query.js +237 -0
  115. package/lib/GraphQL/transformers/schemaFields.js +99 -0
  116. package/lib/KeyPromiseQueue.js +48 -0
  117. package/lib/LiveQuery/Client.js +25 -33
  118. package/lib/LiveQuery/Id.js +2 -5
  119. package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
  120. package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
  121. package/lib/LiveQuery/ParsePubSub.js +7 -16
  122. package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
  123. package/lib/LiveQuery/QueryTools.js +76 -15
  124. package/lib/LiveQuery/RequestSchema.js +111 -97
  125. package/lib/LiveQuery/SessionTokenCache.js +23 -36
  126. package/lib/LiveQuery/Subscription.js +8 -17
  127. package/lib/LiveQuery/equalObjects.js +2 -3
  128. package/lib/Options/Definitions.js +1355 -382
  129. package/lib/Options/docs.js +301 -62
  130. package/lib/Options/index.js +11 -1
  131. package/lib/Options/parsers.js +14 -10
  132. package/lib/Page.js +44 -0
  133. package/lib/ParseMessageQueue.js +6 -13
  134. package/lib/ParseServer.js +474 -235
  135. package/lib/ParseServerRESTController.js +102 -40
  136. package/lib/PromiseRouter.js +39 -50
  137. package/lib/Push/PushQueue.js +24 -30
  138. package/lib/Push/PushWorker.js +32 -56
  139. package/lib/Push/utils.js +22 -35
  140. package/lib/RestQuery.js +361 -139
  141. package/lib/RestWrite.js +713 -344
  142. package/lib/Routers/AggregateRouter.js +97 -71
  143. package/lib/Routers/AnalyticsRouter.js +8 -14
  144. package/lib/Routers/AudiencesRouter.js +16 -35
  145. package/lib/Routers/ClassesRouter.js +86 -72
  146. package/lib/Routers/CloudCodeRouter.js +28 -37
  147. package/lib/Routers/FeaturesRouter.js +22 -25
  148. package/lib/Routers/FilesRouter.js +266 -171
  149. package/lib/Routers/FunctionsRouter.js +87 -103
  150. package/lib/Routers/GlobalConfigRouter.js +94 -33
  151. package/lib/Routers/GraphQLRouter.js +41 -0
  152. package/lib/Routers/HooksRouter.js +43 -47
  153. package/lib/Routers/IAPValidationRouter.js +57 -70
  154. package/lib/Routers/InstallationsRouter.js +17 -25
  155. package/lib/Routers/LogsRouter.js +10 -25
  156. package/lib/Routers/PagesRouter.js +647 -0
  157. package/lib/Routers/PublicAPIRouter.js +104 -112
  158. package/lib/Routers/PurgeRouter.js +19 -29
  159. package/lib/Routers/PushRouter.js +14 -28
  160. package/lib/Routers/RolesRouter.js +7 -14
  161. package/lib/Routers/SchemasRouter.js +63 -42
  162. package/lib/Routers/SecurityRouter.js +34 -0
  163. package/lib/Routers/SessionsRouter.js +25 -38
  164. package/lib/Routers/UsersRouter.js +463 -190
  165. package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
  166. package/lib/SchemaMigrations/Migrations.js +30 -0
  167. package/lib/Security/Check.js +109 -0
  168. package/lib/Security/CheckGroup.js +44 -0
  169. package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
  170. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
  171. package/lib/Security/CheckGroups/CheckGroups.js +21 -0
  172. package/lib/Security/CheckRunner.js +213 -0
  173. package/lib/SharedRest.js +29 -0
  174. package/lib/StatusHandler.js +96 -93
  175. package/lib/TestUtils.js +70 -14
  176. package/lib/Utils.js +468 -0
  177. package/lib/batch.js +74 -40
  178. package/lib/cache.js +8 -8
  179. package/lib/cli/definitions/parse-live-query-server.js +4 -3
  180. package/lib/cli/definitions/parse-server.js +4 -3
  181. package/lib/cli/parse-live-query-server.js +9 -17
  182. package/lib/cli/parse-server.js +49 -47
  183. package/lib/cli/utils/commander.js +20 -29
  184. package/lib/cli/utils/runner.js +31 -32
  185. package/lib/cloud-code/Parse.Cloud.js +711 -36
  186. package/lib/cloud-code/Parse.Server.js +21 -0
  187. package/lib/cryptoUtils.js +6 -11
  188. package/lib/defaults.js +21 -15
  189. package/lib/deprecated.js +1 -1
  190. package/lib/index.js +78 -67
  191. package/lib/logger.js +12 -20
  192. package/lib/middlewares.js +484 -160
  193. package/lib/password.js +10 -6
  194. package/lib/request.js +175 -0
  195. package/lib/requiredParameter.js +4 -3
  196. package/lib/rest.js +157 -82
  197. package/lib/triggers.js +627 -185
  198. package/lib/vendor/README.md +3 -3
  199. package/lib/vendor/mongodbUrl.js +224 -137
  200. package/package.json +135 -57
  201. package/postinstall.js +38 -50
  202. package/public_html/invalid_verification_link.html +3 -3
  203. package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
  204. package/types/@types/deepcopy/index.d.ts +5 -0
  205. package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
  206. package/types/Options/index.d.ts +301 -0
  207. package/types/ParseServer.d.ts +65 -0
  208. package/types/eslint.config.mjs +30 -0
  209. package/types/index.d.ts +21 -0
  210. package/types/logger.d.ts +2 -0
  211. package/types/tests.ts +44 -0
  212. package/types/tsconfig.json +24 -0
  213. package/CHANGELOG.md +0 -1246
  214. package/PATENTS +0 -37
  215. package/bin/dev +0 -37
  216. package/lib/.DS_Store +0 -0
  217. package/lib/Adapters/Auth/common.js +0 -2
  218. package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
  219. package/lib/Controllers/SchemaCache.js +0 -97
  220. package/lib/LiveQuery/.DS_Store +0 -0
  221. package/lib/cli/utils/parsers.js +0 -77
  222. package/lib/cloud-code/.DS_Store +0 -0
  223. package/lib/cloud-code/HTTPResponse.js +0 -57
  224. package/lib/cloud-code/Untitled-1 +0 -123
  225. package/lib/cloud-code/httpRequest.js +0 -102
  226. package/lib/cloud-code/team.html +0 -123
  227. package/lib/graphql/ParseClass.js +0 -234
  228. package/lib/graphql/Schema.js +0 -197
  229. package/lib/graphql/index.js +0 -1
  230. package/lib/graphql/types/ACL.js +0 -35
  231. package/lib/graphql/types/Date.js +0 -25
  232. package/lib/graphql/types/File.js +0 -24
  233. package/lib/graphql/types/GeoPoint.js +0 -35
  234. package/lib/graphql/types/JSONObject.js +0 -30
  235. package/lib/graphql/types/NumberInput.js +0 -43
  236. package/lib/graphql/types/NumberQuery.js +0 -42
  237. package/lib/graphql/types/Pointer.js +0 -35
  238. package/lib/graphql/types/QueryConstraint.js +0 -61
  239. package/lib/graphql/types/StringQuery.js +0 -39
  240. package/lib/graphql/types/index.js +0 -110
@@ -0,0 +1,1098 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.GLOBAL_OR_OBJECT_ID_ATT = exports.GEO_WITHIN_INPUT = exports.GEO_POINT_WHERE_INPUT = exports.GEO_POINT_INPUT = exports.GEO_POINT_FIELDS = exports.GEO_POINT = exports.GEO_INTERSECTS_INPUT = exports.FILE_WHERE_INPUT = exports.FILE_INPUT = exports.FILE_INFO = exports.FILE = exports.ELEMENT = exports.DATE_WHERE_INPUT = exports.DATE = exports.CREATE_RESULT_FIELDS = exports.CREATED_AT_ATT = exports.COUNT_ATT = exports.CLASS_NAME_ATT = exports.CENTER_SPHERE_INPUT = exports.BYTES_WHERE_INPUT = exports.BYTES = exports.BOX_INPUT = exports.BOOLEAN_WHERE_INPUT = exports.ARRAY_WHERE_INPUT = exports.ARRAY_RESULT = exports.ANY = exports.ACL_INPUT = exports.ACL = void 0;
7
+ Object.defineProperty(exports, "GraphQLUpload", {
8
+ enumerable: true,
9
+ get: function () {
10
+ return _GraphQLUpload.default;
11
+ }
12
+ });
13
+ exports.serializeDateIso = exports.parseValue = exports.parseStringValue = exports.parseObjectFields = exports.parseListValues = exports.parseIntValue = exports.parseFloatValue = exports.parseFileValue = exports.parseDateIsoValue = exports.parseBooleanValue = exports.options = exports.notInQueryKey = exports.notIn = exports.notEqualTo = exports.matchesRegex = exports.loadArrayResult = exports.load = exports.lessThanOrEqualTo = exports.lessThan = exports.inQueryKey = exports.inOp = exports.greaterThanOrEqualTo = exports.greaterThan = exports.exists = exports.equalTo = exports.WITHIN_INPUT = exports.WHERE_ATT = exports.USER_ACL_INPUT = exports.USER_ACL = exports.UPDATE_RESULT_FIELDS = exports.UPDATED_AT_ATT = exports.TypeValidationError = exports.TEXT_INPUT = exports.SUBQUERY_READ_PREFERENCE_ATT = exports.SUBQUERY_INPUT = exports.STRING_WHERE_INPUT = exports.SKIP_ATT = exports.SESSION_TOKEN_ATT = exports.SELECT_INPUT = exports.SEARCH_INPUT = exports.ROLE_ACL_INPUT = exports.ROLE_ACL = exports.READ_PREFERENCE_ATT = exports.READ_PREFERENCE = exports.READ_OPTIONS_INPUT = exports.READ_OPTIONS_ATT = exports.PUBLIC_ACL_INPUT = exports.PUBLIC_ACL = exports.POLYGON_WHERE_INPUT = exports.POLYGON_INPUT = exports.POLYGON = exports.PARSE_OBJECT_FIELDS = exports.PARSE_OBJECT = exports.OBJECT_WHERE_INPUT = exports.OBJECT_ID_ATT = exports.OBJECT_ID = exports.OBJECT = exports.NUMBER_WHERE_INPUT = exports.LIMIT_ATT = exports.KEY_VALUE_INPUT = exports.INPUT_FIELDS = exports.INCLUDE_READ_PREFERENCE_ATT = exports.ID_WHERE_INPUT = void 0;
14
+ var _graphql = require("graphql");
15
+ var _graphqlRelay = require("graphql-relay");
16
+ var _GraphQLUpload = _interopRequireDefault(require("graphql-upload/GraphQLUpload.js"));
17
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
18
+ class TypeValidationError extends Error {
19
+ constructor(value, type) {
20
+ super(`${value} is not a valid ${type}`);
21
+ }
22
+ }
23
+ exports.TypeValidationError = TypeValidationError;
24
+ const parseStringValue = value => {
25
+ if (typeof value === 'string') {
26
+ return value;
27
+ }
28
+ throw new TypeValidationError(value, 'String');
29
+ };
30
+ exports.parseStringValue = parseStringValue;
31
+ const parseIntValue = value => {
32
+ if (typeof value === 'string') {
33
+ const int = Number(value);
34
+ if (Number.isInteger(int)) {
35
+ return int;
36
+ }
37
+ }
38
+ throw new TypeValidationError(value, 'Int');
39
+ };
40
+ exports.parseIntValue = parseIntValue;
41
+ const parseFloatValue = value => {
42
+ if (typeof value === 'string') {
43
+ const float = Number(value);
44
+ if (!isNaN(float)) {
45
+ return float;
46
+ }
47
+ }
48
+ throw new TypeValidationError(value, 'Float');
49
+ };
50
+ exports.parseFloatValue = parseFloatValue;
51
+ const parseBooleanValue = value => {
52
+ if (typeof value === 'boolean') {
53
+ return value;
54
+ }
55
+ throw new TypeValidationError(value, 'Boolean');
56
+ };
57
+ exports.parseBooleanValue = parseBooleanValue;
58
+ const parseValue = value => {
59
+ switch (value.kind) {
60
+ case _graphql.Kind.STRING:
61
+ return parseStringValue(value.value);
62
+ case _graphql.Kind.INT:
63
+ return parseIntValue(value.value);
64
+ case _graphql.Kind.FLOAT:
65
+ return parseFloatValue(value.value);
66
+ case _graphql.Kind.BOOLEAN:
67
+ return parseBooleanValue(value.value);
68
+ case _graphql.Kind.LIST:
69
+ return parseListValues(value.values);
70
+ case _graphql.Kind.OBJECT:
71
+ return parseObjectFields(value.fields);
72
+ default:
73
+ return value.value;
74
+ }
75
+ };
76
+ exports.parseValue = parseValue;
77
+ const parseListValues = values => {
78
+ if (Array.isArray(values)) {
79
+ return values.map(value => parseValue(value));
80
+ }
81
+ throw new TypeValidationError(values, 'List');
82
+ };
83
+ exports.parseListValues = parseListValues;
84
+ const parseObjectFields = fields => {
85
+ if (Array.isArray(fields)) {
86
+ return fields.reduce((object, field) => ({
87
+ ...object,
88
+ [field.name.value]: parseValue(field.value)
89
+ }), {});
90
+ }
91
+ throw new TypeValidationError(fields, 'Object');
92
+ };
93
+ exports.parseObjectFields = parseObjectFields;
94
+ const ANY = exports.ANY = new _graphql.GraphQLScalarType({
95
+ name: 'Any',
96
+ description: 'The Any scalar type is used in operations and types that involve any type of value.',
97
+ parseValue: value => value,
98
+ serialize: value => value,
99
+ parseLiteral: ast => parseValue(ast)
100
+ });
101
+ const OBJECT = exports.OBJECT = new _graphql.GraphQLScalarType({
102
+ name: 'Object',
103
+ description: 'The Object scalar type is used in operations and types that involve objects.',
104
+ parseValue(value) {
105
+ if (typeof value === 'object') {
106
+ return value;
107
+ }
108
+ throw new TypeValidationError(value, 'Object');
109
+ },
110
+ serialize(value) {
111
+ if (typeof value === 'object') {
112
+ return value;
113
+ }
114
+ throw new TypeValidationError(value, 'Object');
115
+ },
116
+ parseLiteral(ast) {
117
+ if (ast.kind === _graphql.Kind.OBJECT) {
118
+ return parseObjectFields(ast.fields);
119
+ }
120
+ throw new TypeValidationError(ast.kind, 'Object');
121
+ }
122
+ });
123
+ const parseDateIsoValue = value => {
124
+ if (typeof value === 'string') {
125
+ const date = new Date(value);
126
+ if (!isNaN(date)) {
127
+ return date;
128
+ }
129
+ } else if (value instanceof Date) {
130
+ return value;
131
+ }
132
+ throw new TypeValidationError(value, 'Date');
133
+ };
134
+ exports.parseDateIsoValue = parseDateIsoValue;
135
+ const serializeDateIso = value => {
136
+ if (typeof value === 'string') {
137
+ return value;
138
+ }
139
+ if (value instanceof Date) {
140
+ return value.toISOString();
141
+ }
142
+ throw new TypeValidationError(value, 'Date');
143
+ };
144
+ exports.serializeDateIso = serializeDateIso;
145
+ const parseDateIsoLiteral = ast => {
146
+ if (ast.kind === _graphql.Kind.STRING) {
147
+ return parseDateIsoValue(ast.value);
148
+ }
149
+ throw new TypeValidationError(ast.kind, 'Date');
150
+ };
151
+ const DATE = exports.DATE = new _graphql.GraphQLScalarType({
152
+ name: 'Date',
153
+ description: 'The Date scalar type is used in operations and types that involve dates.',
154
+ parseValue(value) {
155
+ if (typeof value === 'string' || value instanceof Date) {
156
+ return {
157
+ __type: 'Date',
158
+ iso: parseDateIsoValue(value)
159
+ };
160
+ } else if (typeof value === 'object' && value.__type === 'Date' && value.iso) {
161
+ return {
162
+ __type: value.__type,
163
+ iso: parseDateIsoValue(value.iso)
164
+ };
165
+ }
166
+ throw new TypeValidationError(value, 'Date');
167
+ },
168
+ serialize(value) {
169
+ if (typeof value === 'string' || value instanceof Date) {
170
+ return serializeDateIso(value);
171
+ } else if (typeof value === 'object' && value.__type === 'Date' && value.iso) {
172
+ return serializeDateIso(value.iso);
173
+ }
174
+ throw new TypeValidationError(value, 'Date');
175
+ },
176
+ parseLiteral(ast) {
177
+ if (ast.kind === _graphql.Kind.STRING) {
178
+ return {
179
+ __type: 'Date',
180
+ iso: parseDateIsoLiteral(ast)
181
+ };
182
+ } else if (ast.kind === _graphql.Kind.OBJECT) {
183
+ const __type = ast.fields.find(field => field.name.value === '__type');
184
+ const iso = ast.fields.find(field => field.name.value === 'iso');
185
+ if (__type && __type.value && __type.value.value === 'Date' && iso) {
186
+ return {
187
+ __type: __type.value.value,
188
+ iso: parseDateIsoLiteral(iso.value)
189
+ };
190
+ }
191
+ }
192
+ throw new TypeValidationError(ast.kind, 'Date');
193
+ }
194
+ });
195
+ const BYTES = exports.BYTES = new _graphql.GraphQLScalarType({
196
+ name: 'Bytes',
197
+ description: 'The Bytes scalar type is used in operations and types that involve base 64 binary data.',
198
+ parseValue(value) {
199
+ if (typeof value === 'string') {
200
+ return {
201
+ __type: 'Bytes',
202
+ base64: value
203
+ };
204
+ } else if (typeof value === 'object' && value.__type === 'Bytes' && typeof value.base64 === 'string') {
205
+ return value;
206
+ }
207
+ throw new TypeValidationError(value, 'Bytes');
208
+ },
209
+ serialize(value) {
210
+ if (typeof value === 'string') {
211
+ return value;
212
+ } else if (typeof value === 'object' && value.__type === 'Bytes' && typeof value.base64 === 'string') {
213
+ return value.base64;
214
+ }
215
+ throw new TypeValidationError(value, 'Bytes');
216
+ },
217
+ parseLiteral(ast) {
218
+ if (ast.kind === _graphql.Kind.STRING) {
219
+ return {
220
+ __type: 'Bytes',
221
+ base64: ast.value
222
+ };
223
+ } else if (ast.kind === _graphql.Kind.OBJECT) {
224
+ const __type = ast.fields.find(field => field.name.value === '__type');
225
+ const base64 = ast.fields.find(field => field.name.value === 'base64');
226
+ if (__type && __type.value && __type.value.value === 'Bytes' && base64 && base64.value && typeof base64.value.value === 'string') {
227
+ return {
228
+ __type: __type.value.value,
229
+ base64: base64.value.value
230
+ };
231
+ }
232
+ }
233
+ throw new TypeValidationError(ast.kind, 'Bytes');
234
+ }
235
+ });
236
+ const parseFileValue = value => {
237
+ if (typeof value === 'string') {
238
+ return {
239
+ __type: 'File',
240
+ name: value
241
+ };
242
+ } else if (typeof value === 'object' && value.__type === 'File' && typeof value.name === 'string' && (value.url === undefined || typeof value.url === 'string')) {
243
+ return value;
244
+ }
245
+ throw new TypeValidationError(value, 'File');
246
+ };
247
+ exports.parseFileValue = parseFileValue;
248
+ const FILE = exports.FILE = new _graphql.GraphQLScalarType({
249
+ name: 'File',
250
+ description: 'The File scalar type is used in operations and types that involve files.',
251
+ parseValue: parseFileValue,
252
+ serialize: value => {
253
+ if (typeof value === 'string') {
254
+ return value;
255
+ } else if (typeof value === 'object' && value.__type === 'File' && typeof value.name === 'string' && (value.url === undefined || typeof value.url === 'string')) {
256
+ return value.name;
257
+ }
258
+ throw new TypeValidationError(value, 'File');
259
+ },
260
+ parseLiteral(ast) {
261
+ if (ast.kind === _graphql.Kind.STRING) {
262
+ return parseFileValue(ast.value);
263
+ } else if (ast.kind === _graphql.Kind.OBJECT) {
264
+ const __type = ast.fields.find(field => field.name.value === '__type');
265
+ const name = ast.fields.find(field => field.name.value === 'name');
266
+ const url = ast.fields.find(field => field.name.value === 'url');
267
+ if (__type && __type.value && name && name.value) {
268
+ return parseFileValue({
269
+ __type: __type.value.value,
270
+ name: name.value.value,
271
+ url: url && url.value ? url.value.value : undefined
272
+ });
273
+ }
274
+ }
275
+ throw new TypeValidationError(ast.kind, 'File');
276
+ }
277
+ });
278
+ const FILE_INFO = exports.FILE_INFO = new _graphql.GraphQLObjectType({
279
+ name: 'FileInfo',
280
+ description: 'The FileInfo object type is used to return the information about files.',
281
+ fields: {
282
+ name: {
283
+ description: 'This is the file name.',
284
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
285
+ },
286
+ url: {
287
+ description: 'This is the url in which the file can be downloaded.',
288
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
289
+ }
290
+ }
291
+ });
292
+ const FILE_INPUT = exports.FILE_INPUT = new _graphql.GraphQLInputObjectType({
293
+ name: 'FileInput',
294
+ description: 'If this field is set to null the file will be unlinked (the file will not be deleted on cloud storage).',
295
+ fields: {
296
+ file: {
297
+ description: 'A File Scalar can be an url or a FileInfo object.',
298
+ type: FILE
299
+ },
300
+ upload: {
301
+ description: 'Use this field if you want to create a new file.',
302
+ type: _GraphQLUpload.default
303
+ }
304
+ }
305
+ });
306
+ const GEO_POINT_FIELDS = exports.GEO_POINT_FIELDS = {
307
+ latitude: {
308
+ description: 'This is the latitude.',
309
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLFloat)
310
+ },
311
+ longitude: {
312
+ description: 'This is the longitude.',
313
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLFloat)
314
+ }
315
+ };
316
+ const GEO_POINT_INPUT = exports.GEO_POINT_INPUT = new _graphql.GraphQLInputObjectType({
317
+ name: 'GeoPointInput',
318
+ description: 'The GeoPointInput type is used in operations that involve inputting fields of type geo point.',
319
+ fields: GEO_POINT_FIELDS
320
+ });
321
+ const GEO_POINT = exports.GEO_POINT = new _graphql.GraphQLObjectType({
322
+ name: 'GeoPoint',
323
+ description: 'The GeoPoint object type is used to return the information about geo point fields.',
324
+ fields: GEO_POINT_FIELDS
325
+ });
326
+ const POLYGON_INPUT = exports.POLYGON_INPUT = new _graphql.GraphQLList(new _graphql.GraphQLNonNull(GEO_POINT_INPUT));
327
+ const POLYGON = exports.POLYGON = new _graphql.GraphQLList(new _graphql.GraphQLNonNull(GEO_POINT));
328
+ const USER_ACL_INPUT = exports.USER_ACL_INPUT = new _graphql.GraphQLInputObjectType({
329
+ name: 'UserACLInput',
330
+ description: 'Allow to manage users in ACL.',
331
+ fields: {
332
+ userId: {
333
+ description: 'ID of the targetted User.',
334
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLID)
335
+ },
336
+ read: {
337
+ description: 'Allow the user to read the current object.',
338
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
339
+ },
340
+ write: {
341
+ description: 'Allow the user to write on the current object.',
342
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
343
+ }
344
+ }
345
+ });
346
+ const ROLE_ACL_INPUT = exports.ROLE_ACL_INPUT = new _graphql.GraphQLInputObjectType({
347
+ name: 'RoleACLInput',
348
+ description: 'Allow to manage roles in ACL.',
349
+ fields: {
350
+ roleName: {
351
+ description: 'Name of the targetted Role.',
352
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
353
+ },
354
+ read: {
355
+ description: 'Allow users who are members of the role to read the current object.',
356
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
357
+ },
358
+ write: {
359
+ description: 'Allow users who are members of the role to write on the current object.',
360
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
361
+ }
362
+ }
363
+ });
364
+ const PUBLIC_ACL_INPUT = exports.PUBLIC_ACL_INPUT = new _graphql.GraphQLInputObjectType({
365
+ name: 'PublicACLInput',
366
+ description: 'Allow to manage public rights.',
367
+ fields: {
368
+ read: {
369
+ description: 'Allow anyone to read the current object.',
370
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
371
+ },
372
+ write: {
373
+ description: 'Allow anyone to write on the current object.',
374
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
375
+ }
376
+ }
377
+ });
378
+ const ACL_INPUT = exports.ACL_INPUT = new _graphql.GraphQLInputObjectType({
379
+ name: 'ACLInput',
380
+ description: 'Allow to manage access rights. If not provided object will be publicly readable and writable',
381
+ fields: {
382
+ users: {
383
+ description: 'Access control list for users.',
384
+ type: new _graphql.GraphQLList(new _graphql.GraphQLNonNull(USER_ACL_INPUT))
385
+ },
386
+ roles: {
387
+ description: 'Access control list for roles.',
388
+ type: new _graphql.GraphQLList(new _graphql.GraphQLNonNull(ROLE_ACL_INPUT))
389
+ },
390
+ public: {
391
+ description: 'Public access control list.',
392
+ type: PUBLIC_ACL_INPUT
393
+ }
394
+ }
395
+ });
396
+ const USER_ACL = exports.USER_ACL = new _graphql.GraphQLObjectType({
397
+ name: 'UserACL',
398
+ description: 'Allow to manage users in ACL. If read and write are null the users have read and write rights.',
399
+ fields: {
400
+ userId: {
401
+ description: 'ID of the targetted User.',
402
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLID)
403
+ },
404
+ read: {
405
+ description: 'Allow the user to read the current object.',
406
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
407
+ },
408
+ write: {
409
+ description: 'Allow the user to write on the current object.',
410
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
411
+ }
412
+ }
413
+ });
414
+ const ROLE_ACL = exports.ROLE_ACL = new _graphql.GraphQLObjectType({
415
+ name: 'RoleACL',
416
+ description: 'Allow to manage roles in ACL. If read and write are null the role have read and write rights.',
417
+ fields: {
418
+ roleName: {
419
+ description: 'Name of the targetted Role.',
420
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLID)
421
+ },
422
+ read: {
423
+ description: 'Allow users who are members of the role to read the current object.',
424
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
425
+ },
426
+ write: {
427
+ description: 'Allow users who are members of the role to write on the current object.',
428
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
429
+ }
430
+ }
431
+ });
432
+ const PUBLIC_ACL = exports.PUBLIC_ACL = new _graphql.GraphQLObjectType({
433
+ name: 'PublicACL',
434
+ description: 'Allow to manage public rights.',
435
+ fields: {
436
+ read: {
437
+ description: 'Allow anyone to read the current object.',
438
+ type: _graphql.GraphQLBoolean
439
+ },
440
+ write: {
441
+ description: 'Allow anyone to write on the current object.',
442
+ type: _graphql.GraphQLBoolean
443
+ }
444
+ }
445
+ });
446
+ const ACL = exports.ACL = new _graphql.GraphQLObjectType({
447
+ name: 'ACL',
448
+ description: 'Current access control list of the current object.',
449
+ fields: {
450
+ users: {
451
+ description: 'Access control list for users.',
452
+ type: new _graphql.GraphQLList(new _graphql.GraphQLNonNull(USER_ACL)),
453
+ resolve(p) {
454
+ const users = [];
455
+ Object.keys(p).forEach(rule => {
456
+ if (rule !== '*' && rule.indexOf('role:') !== 0) {
457
+ users.push({
458
+ userId: (0, _graphqlRelay.toGlobalId)('_User', rule),
459
+ read: p[rule].read ? true : false,
460
+ write: p[rule].write ? true : false
461
+ });
462
+ }
463
+ });
464
+ return users.length ? users : null;
465
+ }
466
+ },
467
+ roles: {
468
+ description: 'Access control list for roles.',
469
+ type: new _graphql.GraphQLList(new _graphql.GraphQLNonNull(ROLE_ACL)),
470
+ resolve(p) {
471
+ const roles = [];
472
+ Object.keys(p).forEach(rule => {
473
+ if (rule.indexOf('role:') === 0) {
474
+ roles.push({
475
+ roleName: rule.replace('role:', ''),
476
+ read: p[rule].read ? true : false,
477
+ write: p[rule].write ? true : false
478
+ });
479
+ }
480
+ });
481
+ return roles.length ? roles : null;
482
+ }
483
+ },
484
+ public: {
485
+ description: 'Public access control list.',
486
+ type: PUBLIC_ACL,
487
+ resolve(p) {
488
+ /* eslint-disable */
489
+ return p['*'] ? {
490
+ read: p['*'].read ? true : false,
491
+ write: p['*'].write ? true : false
492
+ } : null;
493
+ }
494
+ }
495
+ }
496
+ });
497
+ const OBJECT_ID = exports.OBJECT_ID = new _graphql.GraphQLNonNull(_graphql.GraphQLID);
498
+ const CLASS_NAME_ATT = exports.CLASS_NAME_ATT = {
499
+ description: 'This is the class name of the object.',
500
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
501
+ };
502
+ const GLOBAL_OR_OBJECT_ID_ATT = exports.GLOBAL_OR_OBJECT_ID_ATT = {
503
+ description: 'This is the object id. You can use either the global or the object id.',
504
+ type: OBJECT_ID
505
+ };
506
+ const OBJECT_ID_ATT = exports.OBJECT_ID_ATT = {
507
+ description: 'This is the object id.',
508
+ type: OBJECT_ID
509
+ };
510
+ const CREATED_AT_ATT = exports.CREATED_AT_ATT = {
511
+ description: 'This is the date in which the object was created.',
512
+ type: new _graphql.GraphQLNonNull(DATE)
513
+ };
514
+ const UPDATED_AT_ATT = exports.UPDATED_AT_ATT = {
515
+ description: 'This is the date in which the object was las updated.',
516
+ type: new _graphql.GraphQLNonNull(DATE)
517
+ };
518
+ const INPUT_FIELDS = exports.INPUT_FIELDS = {
519
+ ACL: {
520
+ type: ACL
521
+ }
522
+ };
523
+ const CREATE_RESULT_FIELDS = exports.CREATE_RESULT_FIELDS = {
524
+ objectId: OBJECT_ID_ATT,
525
+ createdAt: CREATED_AT_ATT
526
+ };
527
+ const UPDATE_RESULT_FIELDS = exports.UPDATE_RESULT_FIELDS = {
528
+ updatedAt: UPDATED_AT_ATT
529
+ };
530
+ const PARSE_OBJECT_FIELDS = exports.PARSE_OBJECT_FIELDS = {
531
+ ...CREATE_RESULT_FIELDS,
532
+ ...UPDATE_RESULT_FIELDS,
533
+ ...INPUT_FIELDS,
534
+ ACL: {
535
+ type: new _graphql.GraphQLNonNull(ACL),
536
+ resolve: ({
537
+ ACL
538
+ }) => ACL ? ACL : {
539
+ '*': {
540
+ read: true,
541
+ write: true
542
+ }
543
+ }
544
+ }
545
+ };
546
+ const PARSE_OBJECT = exports.PARSE_OBJECT = new _graphql.GraphQLInterfaceType({
547
+ name: 'ParseObject',
548
+ description: 'The ParseObject interface type is used as a base type for the auto generated object types.',
549
+ fields: PARSE_OBJECT_FIELDS
550
+ });
551
+ const SESSION_TOKEN_ATT = exports.SESSION_TOKEN_ATT = {
552
+ description: 'The current user session token.',
553
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
554
+ };
555
+ const READ_PREFERENCE = exports.READ_PREFERENCE = new _graphql.GraphQLEnumType({
556
+ name: 'ReadPreference',
557
+ description: 'The ReadPreference enum type is used in queries in order to select in which database replica the operation must run.',
558
+ values: {
559
+ PRIMARY: {
560
+ value: 'PRIMARY'
561
+ },
562
+ PRIMARY_PREFERRED: {
563
+ value: 'PRIMARY_PREFERRED'
564
+ },
565
+ SECONDARY: {
566
+ value: 'SECONDARY'
567
+ },
568
+ SECONDARY_PREFERRED: {
569
+ value: 'SECONDARY_PREFERRED'
570
+ },
571
+ NEAREST: {
572
+ value: 'NEAREST'
573
+ }
574
+ }
575
+ });
576
+ const READ_PREFERENCE_ATT = exports.READ_PREFERENCE_ATT = {
577
+ description: 'The read preference for the main query to be executed.',
578
+ type: READ_PREFERENCE
579
+ };
580
+ const INCLUDE_READ_PREFERENCE_ATT = exports.INCLUDE_READ_PREFERENCE_ATT = {
581
+ description: 'The read preference for the queries to be executed to include fields.',
582
+ type: READ_PREFERENCE
583
+ };
584
+ const SUBQUERY_READ_PREFERENCE_ATT = exports.SUBQUERY_READ_PREFERENCE_ATT = {
585
+ description: 'The read preference for the subqueries that may be required.',
586
+ type: READ_PREFERENCE
587
+ };
588
+ const READ_OPTIONS_INPUT = exports.READ_OPTIONS_INPUT = new _graphql.GraphQLInputObjectType({
589
+ name: 'ReadOptionsInput',
590
+ description: 'The ReadOptionsInputt type is used in queries in order to set the read preferences.',
591
+ fields: {
592
+ readPreference: READ_PREFERENCE_ATT,
593
+ includeReadPreference: INCLUDE_READ_PREFERENCE_ATT,
594
+ subqueryReadPreference: SUBQUERY_READ_PREFERENCE_ATT
595
+ }
596
+ });
597
+ const READ_OPTIONS_ATT = exports.READ_OPTIONS_ATT = {
598
+ description: 'The read options for the query to be executed.',
599
+ type: READ_OPTIONS_INPUT
600
+ };
601
+ const WHERE_ATT = exports.WHERE_ATT = {
602
+ description: 'These are the conditions that the objects need to match in order to be found',
603
+ type: OBJECT
604
+ };
605
+ const SKIP_ATT = exports.SKIP_ATT = {
606
+ description: 'This is the number of objects that must be skipped to return.',
607
+ type: _graphql.GraphQLInt
608
+ };
609
+ const LIMIT_ATT = exports.LIMIT_ATT = {
610
+ description: 'This is the limit number of objects that must be returned.',
611
+ type: _graphql.GraphQLInt
612
+ };
613
+ const COUNT_ATT = exports.COUNT_ATT = {
614
+ description: 'This is the total matched objecs count that is returned when the count flag is set.',
615
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLInt)
616
+ };
617
+ const SEARCH_INPUT = exports.SEARCH_INPUT = new _graphql.GraphQLInputObjectType({
618
+ name: 'SearchInput',
619
+ description: 'The SearchInput type is used to specifiy a search operation on a full text search.',
620
+ fields: {
621
+ term: {
622
+ description: 'This is the term to be searched.',
623
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
624
+ },
625
+ language: {
626
+ description: 'This is the language to tetermine the list of stop words and the rules for tokenizer.',
627
+ type: _graphql.GraphQLString
628
+ },
629
+ caseSensitive: {
630
+ description: 'This is the flag to enable or disable case sensitive search.',
631
+ type: _graphql.GraphQLBoolean
632
+ },
633
+ diacriticSensitive: {
634
+ description: 'This is the flag to enable or disable diacritic sensitive search.',
635
+ type: _graphql.GraphQLBoolean
636
+ }
637
+ }
638
+ });
639
+ const TEXT_INPUT = exports.TEXT_INPUT = new _graphql.GraphQLInputObjectType({
640
+ name: 'TextInput',
641
+ description: 'The TextInput type is used to specify a text operation on a constraint.',
642
+ fields: {
643
+ search: {
644
+ description: 'This is the search to be executed.',
645
+ type: new _graphql.GraphQLNonNull(SEARCH_INPUT)
646
+ }
647
+ }
648
+ });
649
+ const BOX_INPUT = exports.BOX_INPUT = new _graphql.GraphQLInputObjectType({
650
+ name: 'BoxInput',
651
+ description: 'The BoxInput type is used to specifiy a box operation on a within geo query.',
652
+ fields: {
653
+ bottomLeft: {
654
+ description: 'This is the bottom left coordinates of the box.',
655
+ type: new _graphql.GraphQLNonNull(GEO_POINT_INPUT)
656
+ },
657
+ upperRight: {
658
+ description: 'This is the upper right coordinates of the box.',
659
+ type: new _graphql.GraphQLNonNull(GEO_POINT_INPUT)
660
+ }
661
+ }
662
+ });
663
+ const WITHIN_INPUT = exports.WITHIN_INPUT = new _graphql.GraphQLInputObjectType({
664
+ name: 'WithinInput',
665
+ description: 'The WithinInput type is used to specify a within operation on a constraint.',
666
+ fields: {
667
+ box: {
668
+ description: 'This is the box to be specified.',
669
+ type: new _graphql.GraphQLNonNull(BOX_INPUT)
670
+ }
671
+ }
672
+ });
673
+ const CENTER_SPHERE_INPUT = exports.CENTER_SPHERE_INPUT = new _graphql.GraphQLInputObjectType({
674
+ name: 'CenterSphereInput',
675
+ description: 'The CenterSphereInput type is used to specifiy a centerSphere operation on a geoWithin query.',
676
+ fields: {
677
+ center: {
678
+ description: 'This is the center of the sphere.',
679
+ type: new _graphql.GraphQLNonNull(GEO_POINT_INPUT)
680
+ },
681
+ distance: {
682
+ description: 'This is the radius of the sphere.',
683
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLFloat)
684
+ }
685
+ }
686
+ });
687
+ const GEO_WITHIN_INPUT = exports.GEO_WITHIN_INPUT = new _graphql.GraphQLInputObjectType({
688
+ name: 'GeoWithinInput',
689
+ description: 'The GeoWithinInput type is used to specify a geoWithin operation on a constraint.',
690
+ fields: {
691
+ polygon: {
692
+ description: 'This is the polygon to be specified.',
693
+ type: POLYGON_INPUT
694
+ },
695
+ centerSphere: {
696
+ description: 'This is the sphere to be specified.',
697
+ type: CENTER_SPHERE_INPUT
698
+ }
699
+ }
700
+ });
701
+ const GEO_INTERSECTS_INPUT = exports.GEO_INTERSECTS_INPUT = new _graphql.GraphQLInputObjectType({
702
+ name: 'GeoIntersectsInput',
703
+ description: 'The GeoIntersectsInput type is used to specify a geoIntersects operation on a constraint.',
704
+ fields: {
705
+ point: {
706
+ description: 'This is the point to be specified.',
707
+ type: GEO_POINT_INPUT
708
+ }
709
+ }
710
+ });
711
+ const equalTo = type => ({
712
+ description: 'This is the equalTo operator to specify a constraint to select the objects where the value of a field equals to a specified value.',
713
+ type
714
+ });
715
+ exports.equalTo = equalTo;
716
+ const notEqualTo = type => ({
717
+ description: 'This is the notEqualTo operator to specify a constraint to select the objects where the value of a field do not equal to a specified value.',
718
+ type
719
+ });
720
+ exports.notEqualTo = notEqualTo;
721
+ const lessThan = type => ({
722
+ description: 'This is the lessThan operator to specify a constraint to select the objects where the value of a field is less than a specified value.',
723
+ type
724
+ });
725
+ exports.lessThan = lessThan;
726
+ const lessThanOrEqualTo = type => ({
727
+ description: 'This is the lessThanOrEqualTo operator to specify a constraint to select the objects where the value of a field is less than or equal to a specified value.',
728
+ type
729
+ });
730
+ exports.lessThanOrEqualTo = lessThanOrEqualTo;
731
+ const greaterThan = type => ({
732
+ description: 'This is the greaterThan operator to specify a constraint to select the objects where the value of a field is greater than a specified value.',
733
+ type
734
+ });
735
+ exports.greaterThan = greaterThan;
736
+ const greaterThanOrEqualTo = type => ({
737
+ description: 'This is the greaterThanOrEqualTo operator to specify a constraint to select the objects where the value of a field is greater than or equal to a specified value.',
738
+ type
739
+ });
740
+ exports.greaterThanOrEqualTo = greaterThanOrEqualTo;
741
+ const inOp = type => ({
742
+ description: 'This is the in operator to specify a constraint to select the objects where the value of a field equals any value in the specified array.',
743
+ type: new _graphql.GraphQLList(type)
744
+ });
745
+ exports.inOp = inOp;
746
+ const notIn = type => ({
747
+ description: 'This is the notIn operator to specify a constraint to select the objects where the value of a field do not equal any value in the specified array.',
748
+ type: new _graphql.GraphQLList(type)
749
+ });
750
+ exports.notIn = notIn;
751
+ const exists = exports.exists = {
752
+ description: 'This is the exists operator to specify a constraint to select the objects where a field exists (or do not exist).',
753
+ type: _graphql.GraphQLBoolean
754
+ };
755
+ const matchesRegex = exports.matchesRegex = {
756
+ description: 'This is the matchesRegex operator to specify a constraint to select the objects where the value of a field matches a specified regular expression.',
757
+ type: _graphql.GraphQLString
758
+ };
759
+ const options = exports.options = {
760
+ description: 'This is the options operator to specify optional flags (such as "i" and "m") to be added to a matchesRegex operation in the same set of constraints.',
761
+ type: _graphql.GraphQLString
762
+ };
763
+ const SUBQUERY_INPUT = exports.SUBQUERY_INPUT = new _graphql.GraphQLInputObjectType({
764
+ name: 'SubqueryInput',
765
+ description: 'The SubqueryInput type is used to specify a sub query to another class.',
766
+ fields: {
767
+ className: CLASS_NAME_ATT,
768
+ where: Object.assign({}, WHERE_ATT, {
769
+ type: new _graphql.GraphQLNonNull(WHERE_ATT.type)
770
+ })
771
+ }
772
+ });
773
+ const SELECT_INPUT = exports.SELECT_INPUT = new _graphql.GraphQLInputObjectType({
774
+ name: 'SelectInput',
775
+ description: 'The SelectInput type is used to specify an inQueryKey or a notInQueryKey operation on a constraint.',
776
+ fields: {
777
+ query: {
778
+ description: 'This is the subquery to be executed.',
779
+ type: new _graphql.GraphQLNonNull(SUBQUERY_INPUT)
780
+ },
781
+ key: {
782
+ description: 'This is the key in the result of the subquery that must match (not match) the field.',
783
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
784
+ }
785
+ }
786
+ });
787
+ const inQueryKey = exports.inQueryKey = {
788
+ description: 'This is the inQueryKey operator to specify a constraint to select the objects where a field equals to a key in the result of a different query.',
789
+ type: SELECT_INPUT
790
+ };
791
+ const notInQueryKey = exports.notInQueryKey = {
792
+ description: 'This is the notInQueryKey operator to specify a constraint to select the objects where a field do not equal to a key in the result of a different query.',
793
+ type: SELECT_INPUT
794
+ };
795
+ const ID_WHERE_INPUT = exports.ID_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
796
+ name: 'IdWhereInput',
797
+ description: 'The IdWhereInput input type is used in operations that involve filtering objects by an id.',
798
+ fields: {
799
+ equalTo: equalTo(_graphql.GraphQLID),
800
+ notEqualTo: notEqualTo(_graphql.GraphQLID),
801
+ lessThan: lessThan(_graphql.GraphQLID),
802
+ lessThanOrEqualTo: lessThanOrEqualTo(_graphql.GraphQLID),
803
+ greaterThan: greaterThan(_graphql.GraphQLID),
804
+ greaterThanOrEqualTo: greaterThanOrEqualTo(_graphql.GraphQLID),
805
+ in: inOp(_graphql.GraphQLID),
806
+ notIn: notIn(_graphql.GraphQLID),
807
+ exists,
808
+ inQueryKey,
809
+ notInQueryKey
810
+ }
811
+ });
812
+ const STRING_WHERE_INPUT = exports.STRING_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
813
+ name: 'StringWhereInput',
814
+ description: 'The StringWhereInput input type is used in operations that involve filtering objects by a field of type String.',
815
+ fields: {
816
+ equalTo: equalTo(_graphql.GraphQLString),
817
+ notEqualTo: notEqualTo(_graphql.GraphQLString),
818
+ lessThan: lessThan(_graphql.GraphQLString),
819
+ lessThanOrEqualTo: lessThanOrEqualTo(_graphql.GraphQLString),
820
+ greaterThan: greaterThan(_graphql.GraphQLString),
821
+ greaterThanOrEqualTo: greaterThanOrEqualTo(_graphql.GraphQLString),
822
+ in: inOp(_graphql.GraphQLString),
823
+ notIn: notIn(_graphql.GraphQLString),
824
+ exists,
825
+ matchesRegex,
826
+ options,
827
+ text: {
828
+ description: 'This is the $text operator to specify a full text search constraint.',
829
+ type: TEXT_INPUT
830
+ },
831
+ inQueryKey,
832
+ notInQueryKey
833
+ }
834
+ });
835
+ const NUMBER_WHERE_INPUT = exports.NUMBER_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
836
+ name: 'NumberWhereInput',
837
+ description: 'The NumberWhereInput input type is used in operations that involve filtering objects by a field of type Number.',
838
+ fields: {
839
+ equalTo: equalTo(_graphql.GraphQLFloat),
840
+ notEqualTo: notEqualTo(_graphql.GraphQLFloat),
841
+ lessThan: lessThan(_graphql.GraphQLFloat),
842
+ lessThanOrEqualTo: lessThanOrEqualTo(_graphql.GraphQLFloat),
843
+ greaterThan: greaterThan(_graphql.GraphQLFloat),
844
+ greaterThanOrEqualTo: greaterThanOrEqualTo(_graphql.GraphQLFloat),
845
+ in: inOp(_graphql.GraphQLFloat),
846
+ notIn: notIn(_graphql.GraphQLFloat),
847
+ exists,
848
+ inQueryKey,
849
+ notInQueryKey
850
+ }
851
+ });
852
+ const BOOLEAN_WHERE_INPUT = exports.BOOLEAN_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
853
+ name: 'BooleanWhereInput',
854
+ description: 'The BooleanWhereInput input type is used in operations that involve filtering objects by a field of type Boolean.',
855
+ fields: {
856
+ equalTo: equalTo(_graphql.GraphQLBoolean),
857
+ notEqualTo: notEqualTo(_graphql.GraphQLBoolean),
858
+ exists,
859
+ inQueryKey,
860
+ notInQueryKey
861
+ }
862
+ });
863
+ const ARRAY_WHERE_INPUT = exports.ARRAY_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
864
+ name: 'ArrayWhereInput',
865
+ description: 'The ArrayWhereInput input type is used in operations that involve filtering objects by a field of type Array.',
866
+ fields: {
867
+ equalTo: equalTo(ANY),
868
+ notEqualTo: notEqualTo(ANY),
869
+ lessThan: lessThan(ANY),
870
+ lessThanOrEqualTo: lessThanOrEqualTo(ANY),
871
+ greaterThan: greaterThan(ANY),
872
+ greaterThanOrEqualTo: greaterThanOrEqualTo(ANY),
873
+ in: inOp(ANY),
874
+ notIn: notIn(ANY),
875
+ exists,
876
+ containedBy: {
877
+ description: 'This is the containedBy operator to specify a constraint to select the objects where the values of an array field is contained by another specified array.',
878
+ type: new _graphql.GraphQLList(ANY)
879
+ },
880
+ contains: {
881
+ description: 'This is the contains operator to specify a constraint to select the objects where the values of an array field contain all elements of another specified array.',
882
+ type: new _graphql.GraphQLList(ANY)
883
+ },
884
+ inQueryKey,
885
+ notInQueryKey
886
+ }
887
+ });
888
+ const KEY_VALUE_INPUT = exports.KEY_VALUE_INPUT = new _graphql.GraphQLInputObjectType({
889
+ name: 'KeyValueInput',
890
+ description: 'An entry from an object, i.e., a pair of key and value.',
891
+ fields: {
892
+ key: {
893
+ description: 'The key used to retrieve the value of this entry.',
894
+ type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
895
+ },
896
+ value: {
897
+ description: 'The value of the entry. Could be any type of scalar data.',
898
+ type: new _graphql.GraphQLNonNull(ANY)
899
+ }
900
+ }
901
+ });
902
+ const OBJECT_WHERE_INPUT = exports.OBJECT_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
903
+ name: 'ObjectWhereInput',
904
+ description: 'The ObjectWhereInput input type is used in operations that involve filtering result by a field of type Object.',
905
+ fields: {
906
+ equalTo: equalTo(KEY_VALUE_INPUT),
907
+ notEqualTo: notEqualTo(KEY_VALUE_INPUT),
908
+ in: inOp(KEY_VALUE_INPUT),
909
+ notIn: notIn(KEY_VALUE_INPUT),
910
+ lessThan: lessThan(KEY_VALUE_INPUT),
911
+ lessThanOrEqualTo: lessThanOrEqualTo(KEY_VALUE_INPUT),
912
+ greaterThan: greaterThan(KEY_VALUE_INPUT),
913
+ greaterThanOrEqualTo: greaterThanOrEqualTo(KEY_VALUE_INPUT),
914
+ exists,
915
+ inQueryKey,
916
+ notInQueryKey
917
+ }
918
+ });
919
+ const DATE_WHERE_INPUT = exports.DATE_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
920
+ name: 'DateWhereInput',
921
+ description: 'The DateWhereInput input type is used in operations that involve filtering objects by a field of type Date.',
922
+ fields: {
923
+ equalTo: equalTo(DATE),
924
+ notEqualTo: notEqualTo(DATE),
925
+ lessThan: lessThan(DATE),
926
+ lessThanOrEqualTo: lessThanOrEqualTo(DATE),
927
+ greaterThan: greaterThan(DATE),
928
+ greaterThanOrEqualTo: greaterThanOrEqualTo(DATE),
929
+ in: inOp(DATE),
930
+ notIn: notIn(DATE),
931
+ exists,
932
+ inQueryKey,
933
+ notInQueryKey
934
+ }
935
+ });
936
+ const BYTES_WHERE_INPUT = exports.BYTES_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
937
+ name: 'BytesWhereInput',
938
+ description: 'The BytesWhereInput input type is used in operations that involve filtering objects by a field of type Bytes.',
939
+ fields: {
940
+ equalTo: equalTo(BYTES),
941
+ notEqualTo: notEqualTo(BYTES),
942
+ lessThan: lessThan(BYTES),
943
+ lessThanOrEqualTo: lessThanOrEqualTo(BYTES),
944
+ greaterThan: greaterThan(BYTES),
945
+ greaterThanOrEqualTo: greaterThanOrEqualTo(BYTES),
946
+ in: inOp(BYTES),
947
+ notIn: notIn(BYTES),
948
+ exists,
949
+ inQueryKey,
950
+ notInQueryKey
951
+ }
952
+ });
953
+ const FILE_WHERE_INPUT = exports.FILE_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
954
+ name: 'FileWhereInput',
955
+ description: 'The FileWhereInput input type is used in operations that involve filtering objects by a field of type File.',
956
+ fields: {
957
+ equalTo: equalTo(FILE),
958
+ notEqualTo: notEqualTo(FILE),
959
+ lessThan: lessThan(FILE),
960
+ lessThanOrEqualTo: lessThanOrEqualTo(FILE),
961
+ greaterThan: greaterThan(FILE),
962
+ greaterThanOrEqualTo: greaterThanOrEqualTo(FILE),
963
+ in: inOp(FILE),
964
+ notIn: notIn(FILE),
965
+ exists,
966
+ matchesRegex,
967
+ options,
968
+ inQueryKey,
969
+ notInQueryKey
970
+ }
971
+ });
972
+ const GEO_POINT_WHERE_INPUT = exports.GEO_POINT_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
973
+ name: 'GeoPointWhereInput',
974
+ description: 'The GeoPointWhereInput input type is used in operations that involve filtering objects by a field of type GeoPoint.',
975
+ fields: {
976
+ exists,
977
+ nearSphere: {
978
+ description: 'This is the nearSphere operator to specify a constraint to select the objects where the values of a geo point field is near to another geo point.',
979
+ type: GEO_POINT_INPUT
980
+ },
981
+ maxDistance: {
982
+ description: 'This is the maxDistance operator to specify a constraint to select the objects where the values of a geo point field is at a max distance (in radians) from the geo point specified in the $nearSphere operator.',
983
+ type: _graphql.GraphQLFloat
984
+ },
985
+ maxDistanceInRadians: {
986
+ description: 'This is the maxDistanceInRadians operator to specify a constraint to select the objects where the values of a geo point field is at a max distance (in radians) from the geo point specified in the $nearSphere operator.',
987
+ type: _graphql.GraphQLFloat
988
+ },
989
+ maxDistanceInMiles: {
990
+ description: 'This is the maxDistanceInMiles operator to specify a constraint to select the objects where the values of a geo point field is at a max distance (in miles) from the geo point specified in the $nearSphere operator.',
991
+ type: _graphql.GraphQLFloat
992
+ },
993
+ maxDistanceInKilometers: {
994
+ description: 'This is the maxDistanceInKilometers operator to specify a constraint to select the objects where the values of a geo point field is at a max distance (in kilometers) from the geo point specified in the $nearSphere operator.',
995
+ type: _graphql.GraphQLFloat
996
+ },
997
+ within: {
998
+ description: 'This is the within operator to specify a constraint to select the objects where the values of a geo point field is within a specified box.',
999
+ type: WITHIN_INPUT
1000
+ },
1001
+ geoWithin: {
1002
+ description: 'This is the geoWithin operator to specify a constraint to select the objects where the values of a geo point field is within a specified polygon or sphere.',
1003
+ type: GEO_WITHIN_INPUT
1004
+ }
1005
+ }
1006
+ });
1007
+ const POLYGON_WHERE_INPUT = exports.POLYGON_WHERE_INPUT = new _graphql.GraphQLInputObjectType({
1008
+ name: 'PolygonWhereInput',
1009
+ description: 'The PolygonWhereInput input type is used in operations that involve filtering objects by a field of type Polygon.',
1010
+ fields: {
1011
+ exists,
1012
+ geoIntersects: {
1013
+ description: 'This is the geoIntersects operator to specify a constraint to select the objects where the values of a polygon field intersect a specified point.',
1014
+ type: GEO_INTERSECTS_INPUT
1015
+ }
1016
+ }
1017
+ });
1018
+ const ELEMENT = exports.ELEMENT = new _graphql.GraphQLObjectType({
1019
+ name: 'Element',
1020
+ description: "The Element object type is used to return array items' value.",
1021
+ fields: {
1022
+ value: {
1023
+ description: 'Return the value of the element in the array',
1024
+ type: new _graphql.GraphQLNonNull(ANY)
1025
+ }
1026
+ }
1027
+ });
1028
+
1029
+ // Default static union type, we update types and resolveType function later
1030
+ let ARRAY_RESULT = exports.ARRAY_RESULT = void 0;
1031
+ const loadArrayResult = (parseGraphQLSchema, parseClassesArray) => {
1032
+ const classTypes = parseClassesArray.filter(parseClass => parseGraphQLSchema.parseClassTypes[parseClass.className].classGraphQLOutputType ? true : false).map(parseClass => parseGraphQLSchema.parseClassTypes[parseClass.className].classGraphQLOutputType);
1033
+ exports.ARRAY_RESULT = ARRAY_RESULT = new _graphql.GraphQLUnionType({
1034
+ name: 'ArrayResult',
1035
+ description: 'Use Inline Fragment on Array to get results: https://graphql.org/learn/queries/#inline-fragments',
1036
+ types: () => [ELEMENT, ...classTypes],
1037
+ resolveType: value => {
1038
+ if (value.__type === 'Object' && value.className && value.objectId) {
1039
+ if (parseGraphQLSchema.parseClassTypes[value.className]) {
1040
+ return parseGraphQLSchema.parseClassTypes[value.className].classGraphQLOutputType.name;
1041
+ } else {
1042
+ return ELEMENT.name;
1043
+ }
1044
+ } else {
1045
+ return ELEMENT.name;
1046
+ }
1047
+ }
1048
+ });
1049
+ parseGraphQLSchema.graphQLTypes.push(ARRAY_RESULT);
1050
+ };
1051
+ exports.loadArrayResult = loadArrayResult;
1052
+ const load = parseGraphQLSchema => {
1053
+ parseGraphQLSchema.addGraphQLType(_GraphQLUpload.default, true);
1054
+ parseGraphQLSchema.addGraphQLType(ANY, true);
1055
+ parseGraphQLSchema.addGraphQLType(OBJECT, true);
1056
+ parseGraphQLSchema.addGraphQLType(DATE, true);
1057
+ parseGraphQLSchema.addGraphQLType(BYTES, true);
1058
+ parseGraphQLSchema.addGraphQLType(FILE, true);
1059
+ parseGraphQLSchema.addGraphQLType(FILE_INFO, true);
1060
+ parseGraphQLSchema.addGraphQLType(FILE_INPUT, true);
1061
+ parseGraphQLSchema.addGraphQLType(GEO_POINT_INPUT, true);
1062
+ parseGraphQLSchema.addGraphQLType(GEO_POINT, true);
1063
+ parseGraphQLSchema.addGraphQLType(PARSE_OBJECT, true);
1064
+ parseGraphQLSchema.addGraphQLType(READ_PREFERENCE, true);
1065
+ parseGraphQLSchema.addGraphQLType(READ_OPTIONS_INPUT, true);
1066
+ parseGraphQLSchema.addGraphQLType(SEARCH_INPUT, true);
1067
+ parseGraphQLSchema.addGraphQLType(TEXT_INPUT, true);
1068
+ parseGraphQLSchema.addGraphQLType(BOX_INPUT, true);
1069
+ parseGraphQLSchema.addGraphQLType(WITHIN_INPUT, true);
1070
+ parseGraphQLSchema.addGraphQLType(CENTER_SPHERE_INPUT, true);
1071
+ parseGraphQLSchema.addGraphQLType(GEO_WITHIN_INPUT, true);
1072
+ parseGraphQLSchema.addGraphQLType(GEO_INTERSECTS_INPUT, true);
1073
+ parseGraphQLSchema.addGraphQLType(ID_WHERE_INPUT, true);
1074
+ parseGraphQLSchema.addGraphQLType(STRING_WHERE_INPUT, true);
1075
+ parseGraphQLSchema.addGraphQLType(NUMBER_WHERE_INPUT, true);
1076
+ parseGraphQLSchema.addGraphQLType(BOOLEAN_WHERE_INPUT, true);
1077
+ parseGraphQLSchema.addGraphQLType(ARRAY_WHERE_INPUT, true);
1078
+ parseGraphQLSchema.addGraphQLType(KEY_VALUE_INPUT, true);
1079
+ parseGraphQLSchema.addGraphQLType(OBJECT_WHERE_INPUT, true);
1080
+ parseGraphQLSchema.addGraphQLType(DATE_WHERE_INPUT, true);
1081
+ parseGraphQLSchema.addGraphQLType(BYTES_WHERE_INPUT, true);
1082
+ parseGraphQLSchema.addGraphQLType(FILE_WHERE_INPUT, true);
1083
+ parseGraphQLSchema.addGraphQLType(GEO_POINT_WHERE_INPUT, true);
1084
+ parseGraphQLSchema.addGraphQLType(POLYGON_WHERE_INPUT, true);
1085
+ parseGraphQLSchema.addGraphQLType(ELEMENT, true);
1086
+ parseGraphQLSchema.addGraphQLType(ACL_INPUT, true);
1087
+ parseGraphQLSchema.addGraphQLType(USER_ACL_INPUT, true);
1088
+ parseGraphQLSchema.addGraphQLType(ROLE_ACL_INPUT, true);
1089
+ parseGraphQLSchema.addGraphQLType(PUBLIC_ACL_INPUT, true);
1090
+ parseGraphQLSchema.addGraphQLType(ACL, true);
1091
+ parseGraphQLSchema.addGraphQLType(USER_ACL, true);
1092
+ parseGraphQLSchema.addGraphQLType(ROLE_ACL, true);
1093
+ parseGraphQLSchema.addGraphQLType(PUBLIC_ACL, true);
1094
+ parseGraphQLSchema.addGraphQLType(SUBQUERY_INPUT, true);
1095
+ parseGraphQLSchema.addGraphQLType(SELECT_INPUT, true);
1096
+ };
1097
+ exports.load = load;
1098
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlRelay","_GraphQLUpload","_interopRequireDefault","e","__esModule","default","TypeValidationError","Error","constructor","value","type","exports","parseStringValue","parseIntValue","int","Number","isInteger","parseFloatValue","float","isNaN","parseBooleanValue","parseValue","kind","Kind","STRING","INT","FLOAT","BOOLEAN","LIST","parseListValues","values","OBJECT","parseObjectFields","fields","Array","isArray","map","reduce","object","field","name","ANY","GraphQLScalarType","description","serialize","parseLiteral","ast","parseDateIsoValue","date","Date","serializeDateIso","toISOString","parseDateIsoLiteral","DATE","__type","iso","find","BYTES","base64","parseFileValue","url","undefined","FILE","FILE_INFO","GraphQLObjectType","GraphQLNonNull","GraphQLString","FILE_INPUT","GraphQLInputObjectType","file","upload","GraphQLUpload","GEO_POINT_FIELDS","latitude","GraphQLFloat","longitude","GEO_POINT_INPUT","GEO_POINT","POLYGON_INPUT","GraphQLList","POLYGON","USER_ACL_INPUT","userId","GraphQLID","read","GraphQLBoolean","write","ROLE_ACL_INPUT","roleName","PUBLIC_ACL_INPUT","ACL_INPUT","users","roles","public","USER_ACL","ROLE_ACL","PUBLIC_ACL","ACL","resolve","p","Object","keys","forEach","rule","indexOf","push","toGlobalId","length","replace","OBJECT_ID","CLASS_NAME_ATT","GLOBAL_OR_OBJECT_ID_ATT","OBJECT_ID_ATT","CREATED_AT_ATT","UPDATED_AT_ATT","INPUT_FIELDS","CREATE_RESULT_FIELDS","objectId","createdAt","UPDATE_RESULT_FIELDS","updatedAt","PARSE_OBJECT_FIELDS","PARSE_OBJECT","GraphQLInterfaceType","SESSION_TOKEN_ATT","READ_PREFERENCE","GraphQLEnumType","PRIMARY","PRIMARY_PREFERRED","SECONDARY","SECONDARY_PREFERRED","NEAREST","READ_PREFERENCE_ATT","INCLUDE_READ_PREFERENCE_ATT","SUBQUERY_READ_PREFERENCE_ATT","READ_OPTIONS_INPUT","readPreference","includeReadPreference","subqueryReadPreference","READ_OPTIONS_ATT","WHERE_ATT","SKIP_ATT","GraphQLInt","LIMIT_ATT","COUNT_ATT","SEARCH_INPUT","term","language","caseSensitive","diacriticSensitive","TEXT_INPUT","search","BOX_INPUT","bottomLeft","upperRight","WITHIN_INPUT","box","CENTER_SPHERE_INPUT","center","distance","GEO_WITHIN_INPUT","polygon","centerSphere","GEO_INTERSECTS_INPUT","point","equalTo","notEqualTo","lessThan","lessThanOrEqualTo","greaterThan","greaterThanOrEqualTo","inOp","notIn","exists","matchesRegex","options","SUBQUERY_INPUT","className","where","assign","SELECT_INPUT","query","key","inQueryKey","notInQueryKey","ID_WHERE_INPUT","in","STRING_WHERE_INPUT","text","NUMBER_WHERE_INPUT","BOOLEAN_WHERE_INPUT","ARRAY_WHERE_INPUT","containedBy","contains","KEY_VALUE_INPUT","OBJECT_WHERE_INPUT","DATE_WHERE_INPUT","BYTES_WHERE_INPUT","FILE_WHERE_INPUT","GEO_POINT_WHERE_INPUT","nearSphere","maxDistance","maxDistanceInRadians","maxDistanceInMiles","maxDistanceInKilometers","within","geoWithin","POLYGON_WHERE_INPUT","geoIntersects","ELEMENT","ARRAY_RESULT","loadArrayResult","parseGraphQLSchema","parseClassesArray","classTypes","filter","parseClass","parseClassTypes","classGraphQLOutputType","GraphQLUnionType","types","resolveType","graphQLTypes","load","addGraphQLType"],"sources":["../../../src/GraphQL/loaders/defaultGraphQLTypes.js"],"sourcesContent":["import {\n  Kind,\n  GraphQLNonNull,\n  GraphQLScalarType,\n  GraphQLID,\n  GraphQLString,\n  GraphQLObjectType,\n  GraphQLInterfaceType,\n  GraphQLEnumType,\n  GraphQLInt,\n  GraphQLFloat,\n  GraphQLList,\n  GraphQLInputObjectType,\n  GraphQLBoolean,\n  GraphQLUnionType,\n} from 'graphql';\nimport { toGlobalId } from 'graphql-relay';\nimport GraphQLUpload from 'graphql-upload/GraphQLUpload.js';\n\nclass TypeValidationError extends Error {\n  constructor(value, type) {\n    super(`${value} is not a valid ${type}`);\n  }\n}\n\nconst parseStringValue = value => {\n  if (typeof value === 'string') {\n    return value;\n  }\n\n  throw new TypeValidationError(value, 'String');\n};\n\nconst parseIntValue = value => {\n  if (typeof value === 'string') {\n    const int = Number(value);\n    if (Number.isInteger(int)) {\n      return int;\n    }\n  }\n\n  throw new TypeValidationError(value, 'Int');\n};\n\nconst parseFloatValue = value => {\n  if (typeof value === 'string') {\n    const float = Number(value);\n    if (!isNaN(float)) {\n      return float;\n    }\n  }\n\n  throw new TypeValidationError(value, 'Float');\n};\n\nconst parseBooleanValue = value => {\n  if (typeof value === 'boolean') {\n    return value;\n  }\n\n  throw new TypeValidationError(value, 'Boolean');\n};\n\nconst parseValue = value => {\n  switch (value.kind) {\n    case Kind.STRING:\n      return parseStringValue(value.value);\n\n    case Kind.INT:\n      return parseIntValue(value.value);\n\n    case Kind.FLOAT:\n      return parseFloatValue(value.value);\n\n    case Kind.BOOLEAN:\n      return parseBooleanValue(value.value);\n\n    case Kind.LIST:\n      return parseListValues(value.values);\n\n    case Kind.OBJECT:\n      return parseObjectFields(value.fields);\n\n    default:\n      return value.value;\n  }\n};\n\nconst parseListValues = values => {\n  if (Array.isArray(values)) {\n    return values.map(value => parseValue(value));\n  }\n\n  throw new TypeValidationError(values, 'List');\n};\n\nconst parseObjectFields = fields => {\n  if (Array.isArray(fields)) {\n    return fields.reduce(\n      (object, field) => ({\n        ...object,\n        [field.name.value]: parseValue(field.value),\n      }),\n      {}\n    );\n  }\n\n  throw new TypeValidationError(fields, 'Object');\n};\n\nconst ANY = new GraphQLScalarType({\n  name: 'Any',\n  description:\n    'The Any scalar type is used in operations and types that involve any type of value.',\n  parseValue: value => value,\n  serialize: value => value,\n  parseLiteral: ast => parseValue(ast),\n});\n\nconst OBJECT = new GraphQLScalarType({\n  name: 'Object',\n  description: 'The Object scalar type is used in operations and types that involve objects.',\n  parseValue(value) {\n    if (typeof value === 'object') {\n      return value;\n    }\n\n    throw new TypeValidationError(value, 'Object');\n  },\n  serialize(value) {\n    if (typeof value === 'object') {\n      return value;\n    }\n\n    throw new TypeValidationError(value, 'Object');\n  },\n  parseLiteral(ast) {\n    if (ast.kind === Kind.OBJECT) {\n      return parseObjectFields(ast.fields);\n    }\n\n    throw new TypeValidationError(ast.kind, 'Object');\n  },\n});\n\nconst parseDateIsoValue = value => {\n  if (typeof value === 'string') {\n    const date = new Date(value);\n    if (!isNaN(date)) {\n      return date;\n    }\n  } else if (value instanceof Date) {\n    return value;\n  }\n\n  throw new TypeValidationError(value, 'Date');\n};\n\nconst serializeDateIso = value => {\n  if (typeof value === 'string') {\n    return value;\n  }\n  if (value instanceof Date) {\n    return value.toISOString();\n  }\n\n  throw new TypeValidationError(value, 'Date');\n};\n\nconst parseDateIsoLiteral = ast => {\n  if (ast.kind === Kind.STRING) {\n    return parseDateIsoValue(ast.value);\n  }\n\n  throw new TypeValidationError(ast.kind, 'Date');\n};\n\nconst DATE = new GraphQLScalarType({\n  name: 'Date',\n  description: 'The Date scalar type is used in operations and types that involve dates.',\n  parseValue(value) {\n    if (typeof value === 'string' || value instanceof Date) {\n      return {\n        __type: 'Date',\n        iso: parseDateIsoValue(value),\n      };\n    } else if (typeof value === 'object' && value.__type === 'Date' && value.iso) {\n      return {\n        __type: value.__type,\n        iso: parseDateIsoValue(value.iso),\n      };\n    }\n\n    throw new TypeValidationError(value, 'Date');\n  },\n  serialize(value) {\n    if (typeof value === 'string' || value instanceof Date) {\n      return serializeDateIso(value);\n    } else if (typeof value === 'object' && value.__type === 'Date' && value.iso) {\n      return serializeDateIso(value.iso);\n    }\n\n    throw new TypeValidationError(value, 'Date');\n  },\n  parseLiteral(ast) {\n    if (ast.kind === Kind.STRING) {\n      return {\n        __type: 'Date',\n        iso: parseDateIsoLiteral(ast),\n      };\n    } else if (ast.kind === Kind.OBJECT) {\n      const __type = ast.fields.find(field => field.name.value === '__type');\n      const iso = ast.fields.find(field => field.name.value === 'iso');\n      if (__type && __type.value && __type.value.value === 'Date' && iso) {\n        return {\n          __type: __type.value.value,\n          iso: parseDateIsoLiteral(iso.value),\n        };\n      }\n    }\n\n    throw new TypeValidationError(ast.kind, 'Date');\n  },\n});\n\nconst BYTES = new GraphQLScalarType({\n  name: 'Bytes',\n  description:\n    'The Bytes scalar type is used in operations and types that involve base 64 binary data.',\n  parseValue(value) {\n    if (typeof value === 'string') {\n      return {\n        __type: 'Bytes',\n        base64: value,\n      };\n    } else if (\n      typeof value === 'object' &&\n      value.__type === 'Bytes' &&\n      typeof value.base64 === 'string'\n    ) {\n      return value;\n    }\n\n    throw new TypeValidationError(value, 'Bytes');\n  },\n  serialize(value) {\n    if (typeof value === 'string') {\n      return value;\n    } else if (\n      typeof value === 'object' &&\n      value.__type === 'Bytes' &&\n      typeof value.base64 === 'string'\n    ) {\n      return value.base64;\n    }\n\n    throw new TypeValidationError(value, 'Bytes');\n  },\n  parseLiteral(ast) {\n    if (ast.kind === Kind.STRING) {\n      return {\n        __type: 'Bytes',\n        base64: ast.value,\n      };\n    } else if (ast.kind === Kind.OBJECT) {\n      const __type = ast.fields.find(field => field.name.value === '__type');\n      const base64 = ast.fields.find(field => field.name.value === 'base64');\n      if (\n        __type &&\n        __type.value &&\n        __type.value.value === 'Bytes' &&\n        base64 &&\n        base64.value &&\n        typeof base64.value.value === 'string'\n      ) {\n        return {\n          __type: __type.value.value,\n          base64: base64.value.value,\n        };\n      }\n    }\n\n    throw new TypeValidationError(ast.kind, 'Bytes');\n  },\n});\n\nconst parseFileValue = value => {\n  if (typeof value === 'string') {\n    return {\n      __type: 'File',\n      name: value,\n    };\n  } else if (\n    typeof value === 'object' &&\n    value.__type === 'File' &&\n    typeof value.name === 'string' &&\n    (value.url === undefined || typeof value.url === 'string')\n  ) {\n    return value;\n  }\n\n  throw new TypeValidationError(value, 'File');\n};\n\nconst FILE = new GraphQLScalarType({\n  name: 'File',\n  description: 'The File scalar type is used in operations and types that involve files.',\n  parseValue: parseFileValue,\n  serialize: value => {\n    if (typeof value === 'string') {\n      return value;\n    } else if (\n      typeof value === 'object' &&\n      value.__type === 'File' &&\n      typeof value.name === 'string' &&\n      (value.url === undefined || typeof value.url === 'string')\n    ) {\n      return value.name;\n    }\n\n    throw new TypeValidationError(value, 'File');\n  },\n  parseLiteral(ast) {\n    if (ast.kind === Kind.STRING) {\n      return parseFileValue(ast.value);\n    } else if (ast.kind === Kind.OBJECT) {\n      const __type = ast.fields.find(field => field.name.value === '__type');\n      const name = ast.fields.find(field => field.name.value === 'name');\n      const url = ast.fields.find(field => field.name.value === 'url');\n      if (__type && __type.value && name && name.value) {\n        return parseFileValue({\n          __type: __type.value.value,\n          name: name.value.value,\n          url: url && url.value ? url.value.value : undefined,\n        });\n      }\n    }\n\n    throw new TypeValidationError(ast.kind, 'File');\n  },\n});\n\nconst FILE_INFO = new GraphQLObjectType({\n  name: 'FileInfo',\n  description: 'The FileInfo object type is used to return the information about files.',\n  fields: {\n    name: {\n      description: 'This is the file name.',\n      type: new GraphQLNonNull(GraphQLString),\n    },\n    url: {\n      description: 'This is the url in which the file can be downloaded.',\n      type: new GraphQLNonNull(GraphQLString),\n    },\n  },\n});\n\nconst FILE_INPUT = new GraphQLInputObjectType({\n  name: 'FileInput',\n  description:\n    'If this field is set to null the file will be unlinked (the file will not be deleted on cloud storage).',\n  fields: {\n    file: {\n      description: 'A File Scalar can be an url or a FileInfo object.',\n      type: FILE,\n    },\n    upload: {\n      description: 'Use this field if you want to create a new file.',\n      type: GraphQLUpload,\n    },\n  },\n});\n\nconst GEO_POINT_FIELDS = {\n  latitude: {\n    description: 'This is the latitude.',\n    type: new GraphQLNonNull(GraphQLFloat),\n  },\n  longitude: {\n    description: 'This is the longitude.',\n    type: new GraphQLNonNull(GraphQLFloat),\n  },\n};\n\nconst GEO_POINT_INPUT = new GraphQLInputObjectType({\n  name: 'GeoPointInput',\n  description:\n    'The GeoPointInput type is used in operations that involve inputting fields of type geo point.',\n  fields: GEO_POINT_FIELDS,\n});\n\nconst GEO_POINT = new GraphQLObjectType({\n  name: 'GeoPoint',\n  description: 'The GeoPoint object type is used to return the information about geo point fields.',\n  fields: GEO_POINT_FIELDS,\n});\n\nconst POLYGON_INPUT = new GraphQLList(new GraphQLNonNull(GEO_POINT_INPUT));\n\nconst POLYGON = new GraphQLList(new GraphQLNonNull(GEO_POINT));\n\nconst USER_ACL_INPUT = new GraphQLInputObjectType({\n  name: 'UserACLInput',\n  description: 'Allow to manage users in ACL.',\n  fields: {\n    userId: {\n      description: 'ID of the targetted User.',\n      type: new GraphQLNonNull(GraphQLID),\n    },\n    read: {\n      description: 'Allow the user to read the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n    write: {\n      description: 'Allow the user to write on the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n  },\n});\n\nconst ROLE_ACL_INPUT = new GraphQLInputObjectType({\n  name: 'RoleACLInput',\n  description: 'Allow to manage roles in ACL.',\n  fields: {\n    roleName: {\n      description: 'Name of the targetted Role.',\n      type: new GraphQLNonNull(GraphQLString),\n    },\n    read: {\n      description: 'Allow users who are members of the role to read the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n    write: {\n      description: 'Allow users who are members of the role to write on the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n  },\n});\n\nconst PUBLIC_ACL_INPUT = new GraphQLInputObjectType({\n  name: 'PublicACLInput',\n  description: 'Allow to manage public rights.',\n  fields: {\n    read: {\n      description: 'Allow anyone to read the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n    write: {\n      description: 'Allow anyone to write on the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n  },\n});\n\nconst ACL_INPUT = new GraphQLInputObjectType({\n  name: 'ACLInput',\n  description:\n    'Allow to manage access rights. If not provided object will be publicly readable and writable',\n  fields: {\n    users: {\n      description: 'Access control list for users.',\n      type: new GraphQLList(new GraphQLNonNull(USER_ACL_INPUT)),\n    },\n    roles: {\n      description: 'Access control list for roles.',\n      type: new GraphQLList(new GraphQLNonNull(ROLE_ACL_INPUT)),\n    },\n    public: {\n      description: 'Public access control list.',\n      type: PUBLIC_ACL_INPUT,\n    },\n  },\n});\n\nconst USER_ACL = new GraphQLObjectType({\n  name: 'UserACL',\n  description:\n    'Allow to manage users in ACL. If read and write are null the users have read and write rights.',\n  fields: {\n    userId: {\n      description: 'ID of the targetted User.',\n      type: new GraphQLNonNull(GraphQLID),\n    },\n    read: {\n      description: 'Allow the user to read the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n    write: {\n      description: 'Allow the user to write on the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n  },\n});\n\nconst ROLE_ACL = new GraphQLObjectType({\n  name: 'RoleACL',\n  description:\n    'Allow to manage roles in ACL. If read and write are null the role have read and write rights.',\n  fields: {\n    roleName: {\n      description: 'Name of the targetted Role.',\n      type: new GraphQLNonNull(GraphQLID),\n    },\n    read: {\n      description: 'Allow users who are members of the role to read the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n    write: {\n      description: 'Allow users who are members of the role to write on the current object.',\n      type: new GraphQLNonNull(GraphQLBoolean),\n    },\n  },\n});\n\nconst PUBLIC_ACL = new GraphQLObjectType({\n  name: 'PublicACL',\n  description: 'Allow to manage public rights.',\n  fields: {\n    read: {\n      description: 'Allow anyone to read the current object.',\n      type: GraphQLBoolean,\n    },\n    write: {\n      description: 'Allow anyone to write on the current object.',\n      type: GraphQLBoolean,\n    },\n  },\n});\n\nconst ACL = new GraphQLObjectType({\n  name: 'ACL',\n  description: 'Current access control list of the current object.',\n  fields: {\n    users: {\n      description: 'Access control list for users.',\n      type: new GraphQLList(new GraphQLNonNull(USER_ACL)),\n      resolve(p) {\n        const users = [];\n        Object.keys(p).forEach(rule => {\n          if (rule !== '*' && rule.indexOf('role:') !== 0) {\n            users.push({\n              userId: toGlobalId('_User', rule),\n              read: p[rule].read ? true : false,\n              write: p[rule].write ? true : false,\n            });\n          }\n        });\n        return users.length ? users : null;\n      },\n    },\n    roles: {\n      description: 'Access control list for roles.',\n      type: new GraphQLList(new GraphQLNonNull(ROLE_ACL)),\n      resolve(p) {\n        const roles = [];\n        Object.keys(p).forEach(rule => {\n          if (rule.indexOf('role:') === 0) {\n            roles.push({\n              roleName: rule.replace('role:', ''),\n              read: p[rule].read ? true : false,\n              write: p[rule].write ? true : false,\n            });\n          }\n        });\n        return roles.length ? roles : null;\n      },\n    },\n    public: {\n      description: 'Public access control list.',\n      type: PUBLIC_ACL,\n      resolve(p) {\n        /* eslint-disable */\n        return p['*']\n          ? {\n              read: p['*'].read ? true : false,\n              write: p['*'].write ? true : false,\n            }\n          : null;\n      },\n    },\n  },\n});\n\nconst OBJECT_ID = new GraphQLNonNull(GraphQLID);\n\nconst CLASS_NAME_ATT = {\n  description: 'This is the class name of the object.',\n  type: new GraphQLNonNull(GraphQLString),\n};\n\nconst GLOBAL_OR_OBJECT_ID_ATT = {\n  description: 'This is the object id. You can use either the global or the object id.',\n  type: OBJECT_ID,\n};\n\nconst OBJECT_ID_ATT = {\n  description: 'This is the object id.',\n  type: OBJECT_ID,\n};\n\nconst CREATED_AT_ATT = {\n  description: 'This is the date in which the object was created.',\n  type: new GraphQLNonNull(DATE),\n};\n\nconst UPDATED_AT_ATT = {\n  description: 'This is the date in which the object was las updated.',\n  type: new GraphQLNonNull(DATE),\n};\n\nconst INPUT_FIELDS = {\n  ACL: {\n    type: ACL,\n  },\n};\n\nconst CREATE_RESULT_FIELDS = {\n  objectId: OBJECT_ID_ATT,\n  createdAt: CREATED_AT_ATT,\n};\n\nconst UPDATE_RESULT_FIELDS = {\n  updatedAt: UPDATED_AT_ATT,\n};\n\nconst PARSE_OBJECT_FIELDS = {\n  ...CREATE_RESULT_FIELDS,\n  ...UPDATE_RESULT_FIELDS,\n  ...INPUT_FIELDS,\n  ACL: {\n    type: new GraphQLNonNull(ACL),\n    resolve: ({ ACL }) => (ACL ? ACL : { '*': { read: true, write: true } }),\n  },\n};\n\nconst PARSE_OBJECT = new GraphQLInterfaceType({\n  name: 'ParseObject',\n  description:\n    'The ParseObject interface type is used as a base type for the auto generated object types.',\n  fields: PARSE_OBJECT_FIELDS,\n});\n\nconst SESSION_TOKEN_ATT = {\n  description: 'The current user session token.',\n  type: new GraphQLNonNull(GraphQLString),\n};\n\nconst READ_PREFERENCE = new GraphQLEnumType({\n  name: 'ReadPreference',\n  description:\n    'The ReadPreference enum type is used in queries in order to select in which database replica the operation must run.',\n  values: {\n    PRIMARY: { value: 'PRIMARY' },\n    PRIMARY_PREFERRED: { value: 'PRIMARY_PREFERRED' },\n    SECONDARY: { value: 'SECONDARY' },\n    SECONDARY_PREFERRED: { value: 'SECONDARY_PREFERRED' },\n    NEAREST: { value: 'NEAREST' },\n  },\n});\n\nconst READ_PREFERENCE_ATT = {\n  description: 'The read preference for the main query to be executed.',\n  type: READ_PREFERENCE,\n};\n\nconst INCLUDE_READ_PREFERENCE_ATT = {\n  description: 'The read preference for the queries to be executed to include fields.',\n  type: READ_PREFERENCE,\n};\n\nconst SUBQUERY_READ_PREFERENCE_ATT = {\n  description: 'The read preference for the subqueries that may be required.',\n  type: READ_PREFERENCE,\n};\n\nconst READ_OPTIONS_INPUT = new GraphQLInputObjectType({\n  name: 'ReadOptionsInput',\n  description:\n    'The ReadOptionsInputt type is used in queries in order to set the read preferences.',\n  fields: {\n    readPreference: READ_PREFERENCE_ATT,\n    includeReadPreference: INCLUDE_READ_PREFERENCE_ATT,\n    subqueryReadPreference: SUBQUERY_READ_PREFERENCE_ATT,\n  },\n});\n\nconst READ_OPTIONS_ATT = {\n  description: 'The read options for the query to be executed.',\n  type: READ_OPTIONS_INPUT,\n};\n\nconst WHERE_ATT = {\n  description: 'These are the conditions that the objects need to match in order to be found',\n  type: OBJECT,\n};\n\nconst SKIP_ATT = {\n  description: 'This is the number of objects that must be skipped to return.',\n  type: GraphQLInt,\n};\n\nconst LIMIT_ATT = {\n  description: 'This is the limit number of objects that must be returned.',\n  type: GraphQLInt,\n};\n\nconst COUNT_ATT = {\n  description:\n    'This is the total matched objecs count that is returned when the count flag is set.',\n  type: new GraphQLNonNull(GraphQLInt),\n};\n\nconst SEARCH_INPUT = new GraphQLInputObjectType({\n  name: 'SearchInput',\n  description: 'The SearchInput type is used to specifiy a search operation on a full text search.',\n  fields: {\n    term: {\n      description: 'This is the term to be searched.',\n      type: new GraphQLNonNull(GraphQLString),\n    },\n    language: {\n      description:\n        'This is the language to tetermine the list of stop words and the rules for tokenizer.',\n      type: GraphQLString,\n    },\n    caseSensitive: {\n      description: 'This is the flag to enable or disable case sensitive search.',\n      type: GraphQLBoolean,\n    },\n    diacriticSensitive: {\n      description: 'This is the flag to enable or disable diacritic sensitive search.',\n      type: GraphQLBoolean,\n    },\n  },\n});\n\nconst TEXT_INPUT = new GraphQLInputObjectType({\n  name: 'TextInput',\n  description: 'The TextInput type is used to specify a text operation on a constraint.',\n  fields: {\n    search: {\n      description: 'This is the search to be executed.',\n      type: new GraphQLNonNull(SEARCH_INPUT),\n    },\n  },\n});\n\nconst BOX_INPUT = new GraphQLInputObjectType({\n  name: 'BoxInput',\n  description: 'The BoxInput type is used to specifiy a box operation on a within geo query.',\n  fields: {\n    bottomLeft: {\n      description: 'This is the bottom left coordinates of the box.',\n      type: new GraphQLNonNull(GEO_POINT_INPUT),\n    },\n    upperRight: {\n      description: 'This is the upper right coordinates of the box.',\n      type: new GraphQLNonNull(GEO_POINT_INPUT),\n    },\n  },\n});\n\nconst WITHIN_INPUT = new GraphQLInputObjectType({\n  name: 'WithinInput',\n  description: 'The WithinInput type is used to specify a within operation on a constraint.',\n  fields: {\n    box: {\n      description: 'This is the box to be specified.',\n      type: new GraphQLNonNull(BOX_INPUT),\n    },\n  },\n});\n\nconst CENTER_SPHERE_INPUT = new GraphQLInputObjectType({\n  name: 'CenterSphereInput',\n  description:\n    'The CenterSphereInput type is used to specifiy a centerSphere operation on a geoWithin query.',\n  fields: {\n    center: {\n      description: 'This is the center of the sphere.',\n      type: new GraphQLNonNull(GEO_POINT_INPUT),\n    },\n    distance: {\n      description: 'This is the radius of the sphere.',\n      type: new GraphQLNonNull(GraphQLFloat),\n    },\n  },\n});\n\nconst GEO_WITHIN_INPUT = new GraphQLInputObjectType({\n  name: 'GeoWithinInput',\n  description: 'The GeoWithinInput type is used to specify a geoWithin operation on a constraint.',\n  fields: {\n    polygon: {\n      description: 'This is the polygon to be specified.',\n      type: POLYGON_INPUT,\n    },\n    centerSphere: {\n      description: 'This is the sphere to be specified.',\n      type: CENTER_SPHERE_INPUT,\n    },\n  },\n});\n\nconst GEO_INTERSECTS_INPUT = new GraphQLInputObjectType({\n  name: 'GeoIntersectsInput',\n  description:\n    'The GeoIntersectsInput type is used to specify a geoIntersects operation on a constraint.',\n  fields: {\n    point: {\n      description: 'This is the point to be specified.',\n      type: GEO_POINT_INPUT,\n    },\n  },\n});\n\nconst equalTo = type => ({\n  description:\n    'This is the equalTo operator to specify a constraint to select the objects where the value of a field equals to a specified value.',\n  type,\n});\n\nconst notEqualTo = type => ({\n  description:\n    'This is the notEqualTo operator to specify a constraint to select the objects where the value of a field do not equal to a specified value.',\n  type,\n});\n\nconst lessThan = type => ({\n  description:\n    'This is the lessThan operator to specify a constraint to select the objects where the value of a field is less than a specified value.',\n  type,\n});\n\nconst lessThanOrEqualTo = type => ({\n  description:\n    'This is the lessThanOrEqualTo operator to specify a constraint to select the objects where the value of a field is less than or equal to a specified value.',\n  type,\n});\n\nconst greaterThan = type => ({\n  description:\n    'This is the greaterThan operator to specify a constraint to select the objects where the value of a field is greater than a specified value.',\n  type,\n});\n\nconst greaterThanOrEqualTo = type => ({\n  description:\n    'This is the greaterThanOrEqualTo operator to specify a constraint to select the objects where the value of a field is greater than or equal to a specified value.',\n  type,\n});\n\nconst inOp = type => ({\n  description:\n    'This is the in operator to specify a constraint to select the objects where the value of a field equals any value in the specified array.',\n  type: new GraphQLList(type),\n});\n\nconst notIn = type => ({\n  description:\n    'This is the notIn operator to specify a constraint to select the objects where the value of a field do not equal any value in the specified array.',\n  type: new GraphQLList(type),\n});\n\nconst exists = {\n  description:\n    'This is the exists operator to specify a constraint to select the objects where a field exists (or do not exist).',\n  type: GraphQLBoolean,\n};\n\nconst matchesRegex = {\n  description:\n    'This is the matchesRegex operator to specify a constraint to select the objects where the value of a field matches a specified regular expression.',\n  type: GraphQLString,\n};\n\nconst options = {\n  description:\n    'This is the options operator to specify optional flags (such as \"i\" and \"m\") to be added to a matchesRegex operation in the same set of constraints.',\n  type: GraphQLString,\n};\n\nconst SUBQUERY_INPUT = new GraphQLInputObjectType({\n  name: 'SubqueryInput',\n  description: 'The SubqueryInput type is used to specify a sub query to another class.',\n  fields: {\n    className: CLASS_NAME_ATT,\n    where: Object.assign({}, WHERE_ATT, {\n      type: new GraphQLNonNull(WHERE_ATT.type),\n    }),\n  },\n});\n\nconst SELECT_INPUT = new GraphQLInputObjectType({\n  name: 'SelectInput',\n  description:\n    'The SelectInput type is used to specify an inQueryKey or a notInQueryKey operation on a constraint.',\n  fields: {\n    query: {\n      description: 'This is the subquery to be executed.',\n      type: new GraphQLNonNull(SUBQUERY_INPUT),\n    },\n    key: {\n      description:\n        'This is the key in the result of the subquery that must match (not match) the field.',\n      type: new GraphQLNonNull(GraphQLString),\n    },\n  },\n});\n\nconst inQueryKey = {\n  description:\n    'This is the inQueryKey operator to specify a constraint to select the objects where a field equals to a key in the result of a different query.',\n  type: SELECT_INPUT,\n};\n\nconst notInQueryKey = {\n  description:\n    'This is the notInQueryKey operator to specify a constraint to select the objects where a field do not equal to a key in the result of a different query.',\n  type: SELECT_INPUT,\n};\n\nconst ID_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'IdWhereInput',\n  description:\n    'The IdWhereInput input type is used in operations that involve filtering objects by an id.',\n  fields: {\n    equalTo: equalTo(GraphQLID),\n    notEqualTo: notEqualTo(GraphQLID),\n    lessThan: lessThan(GraphQLID),\n    lessThanOrEqualTo: lessThanOrEqualTo(GraphQLID),\n    greaterThan: greaterThan(GraphQLID),\n    greaterThanOrEqualTo: greaterThanOrEqualTo(GraphQLID),\n    in: inOp(GraphQLID),\n    notIn: notIn(GraphQLID),\n    exists,\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst STRING_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'StringWhereInput',\n  description:\n    'The StringWhereInput input type is used in operations that involve filtering objects by a field of type String.',\n  fields: {\n    equalTo: equalTo(GraphQLString),\n    notEqualTo: notEqualTo(GraphQLString),\n    lessThan: lessThan(GraphQLString),\n    lessThanOrEqualTo: lessThanOrEqualTo(GraphQLString),\n    greaterThan: greaterThan(GraphQLString),\n    greaterThanOrEqualTo: greaterThanOrEqualTo(GraphQLString),\n    in: inOp(GraphQLString),\n    notIn: notIn(GraphQLString),\n    exists,\n    matchesRegex,\n    options,\n    text: {\n      description: 'This is the $text operator to specify a full text search constraint.',\n      type: TEXT_INPUT,\n    },\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst NUMBER_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'NumberWhereInput',\n  description:\n    'The NumberWhereInput input type is used in operations that involve filtering objects by a field of type Number.',\n  fields: {\n    equalTo: equalTo(GraphQLFloat),\n    notEqualTo: notEqualTo(GraphQLFloat),\n    lessThan: lessThan(GraphQLFloat),\n    lessThanOrEqualTo: lessThanOrEqualTo(GraphQLFloat),\n    greaterThan: greaterThan(GraphQLFloat),\n    greaterThanOrEqualTo: greaterThanOrEqualTo(GraphQLFloat),\n    in: inOp(GraphQLFloat),\n    notIn: notIn(GraphQLFloat),\n    exists,\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst BOOLEAN_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'BooleanWhereInput',\n  description:\n    'The BooleanWhereInput input type is used in operations that involve filtering objects by a field of type Boolean.',\n  fields: {\n    equalTo: equalTo(GraphQLBoolean),\n    notEqualTo: notEqualTo(GraphQLBoolean),\n    exists,\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst ARRAY_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'ArrayWhereInput',\n  description:\n    'The ArrayWhereInput input type is used in operations that involve filtering objects by a field of type Array.',\n  fields: {\n    equalTo: equalTo(ANY),\n    notEqualTo: notEqualTo(ANY),\n    lessThan: lessThan(ANY),\n    lessThanOrEqualTo: lessThanOrEqualTo(ANY),\n    greaterThan: greaterThan(ANY),\n    greaterThanOrEqualTo: greaterThanOrEqualTo(ANY),\n    in: inOp(ANY),\n    notIn: notIn(ANY),\n    exists,\n    containedBy: {\n      description:\n        'This is the containedBy operator to specify a constraint to select the objects where the values of an array field is contained by another specified array.',\n      type: new GraphQLList(ANY),\n    },\n    contains: {\n      description:\n        'This is the contains operator to specify a constraint to select the objects where the values of an array field contain all elements of another specified array.',\n      type: new GraphQLList(ANY),\n    },\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst KEY_VALUE_INPUT = new GraphQLInputObjectType({\n  name: 'KeyValueInput',\n  description: 'An entry from an object, i.e., a pair of key and value.',\n  fields: {\n    key: {\n      description: 'The key used to retrieve the value of this entry.',\n      type: new GraphQLNonNull(GraphQLString),\n    },\n    value: {\n      description: 'The value of the entry. Could be any type of scalar data.',\n      type: new GraphQLNonNull(ANY),\n    },\n  },\n});\n\nconst OBJECT_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'ObjectWhereInput',\n  description:\n    'The ObjectWhereInput input type is used in operations that involve filtering result by a field of type Object.',\n  fields: {\n    equalTo: equalTo(KEY_VALUE_INPUT),\n    notEqualTo: notEqualTo(KEY_VALUE_INPUT),\n    in: inOp(KEY_VALUE_INPUT),\n    notIn: notIn(KEY_VALUE_INPUT),\n    lessThan: lessThan(KEY_VALUE_INPUT),\n    lessThanOrEqualTo: lessThanOrEqualTo(KEY_VALUE_INPUT),\n    greaterThan: greaterThan(KEY_VALUE_INPUT),\n    greaterThanOrEqualTo: greaterThanOrEqualTo(KEY_VALUE_INPUT),\n    exists,\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst DATE_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'DateWhereInput',\n  description:\n    'The DateWhereInput input type is used in operations that involve filtering objects by a field of type Date.',\n  fields: {\n    equalTo: equalTo(DATE),\n    notEqualTo: notEqualTo(DATE),\n    lessThan: lessThan(DATE),\n    lessThanOrEqualTo: lessThanOrEqualTo(DATE),\n    greaterThan: greaterThan(DATE),\n    greaterThanOrEqualTo: greaterThanOrEqualTo(DATE),\n    in: inOp(DATE),\n    notIn: notIn(DATE),\n    exists,\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst BYTES_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'BytesWhereInput',\n  description:\n    'The BytesWhereInput input type is used in operations that involve filtering objects by a field of type Bytes.',\n  fields: {\n    equalTo: equalTo(BYTES),\n    notEqualTo: notEqualTo(BYTES),\n    lessThan: lessThan(BYTES),\n    lessThanOrEqualTo: lessThanOrEqualTo(BYTES),\n    greaterThan: greaterThan(BYTES),\n    greaterThanOrEqualTo: greaterThanOrEqualTo(BYTES),\n    in: inOp(BYTES),\n    notIn: notIn(BYTES),\n    exists,\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst FILE_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'FileWhereInput',\n  description:\n    'The FileWhereInput input type is used in operations that involve filtering objects by a field of type File.',\n  fields: {\n    equalTo: equalTo(FILE),\n    notEqualTo: notEqualTo(FILE),\n    lessThan: lessThan(FILE),\n    lessThanOrEqualTo: lessThanOrEqualTo(FILE),\n    greaterThan: greaterThan(FILE),\n    greaterThanOrEqualTo: greaterThanOrEqualTo(FILE),\n    in: inOp(FILE),\n    notIn: notIn(FILE),\n    exists,\n    matchesRegex,\n    options,\n    inQueryKey,\n    notInQueryKey,\n  },\n});\n\nconst GEO_POINT_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'GeoPointWhereInput',\n  description:\n    'The GeoPointWhereInput input type is used in operations that involve filtering objects by a field of type GeoPoint.',\n  fields: {\n    exists,\n    nearSphere: {\n      description:\n        'This is the nearSphere operator to specify a constraint to select the objects where the values of a geo point field is near to another geo point.',\n      type: GEO_POINT_INPUT,\n    },\n    maxDistance: {\n      description:\n        'This is the maxDistance operator to specify a constraint to select the objects where the values of a geo point field is at a max distance (in radians) from the geo point specified in the $nearSphere operator.',\n      type: GraphQLFloat,\n    },\n    maxDistanceInRadians: {\n      description:\n        'This is the maxDistanceInRadians operator to specify a constraint to select the objects where the values of a geo point field is at a max distance (in radians) from the geo point specified in the $nearSphere operator.',\n      type: GraphQLFloat,\n    },\n    maxDistanceInMiles: {\n      description:\n        'This is the maxDistanceInMiles operator to specify a constraint to select the objects where the values of a geo point field is at a max distance (in miles) from the geo point specified in the $nearSphere operator.',\n      type: GraphQLFloat,\n    },\n    maxDistanceInKilometers: {\n      description:\n        'This is the maxDistanceInKilometers operator to specify a constraint to select the objects where the values of a geo point field is at a max distance (in kilometers) from the geo point specified in the $nearSphere operator.',\n      type: GraphQLFloat,\n    },\n    within: {\n      description:\n        'This is the within operator to specify a constraint to select the objects where the values of a geo point field is within a specified box.',\n      type: WITHIN_INPUT,\n    },\n    geoWithin: {\n      description:\n        'This is the geoWithin operator to specify a constraint to select the objects where the values of a geo point field is within a specified polygon or sphere.',\n      type: GEO_WITHIN_INPUT,\n    },\n  },\n});\n\nconst POLYGON_WHERE_INPUT = new GraphQLInputObjectType({\n  name: 'PolygonWhereInput',\n  description:\n    'The PolygonWhereInput input type is used in operations that involve filtering objects by a field of type Polygon.',\n  fields: {\n    exists,\n    geoIntersects: {\n      description:\n        'This is the geoIntersects operator to specify a constraint to select the objects where the values of a polygon field intersect a specified point.',\n      type: GEO_INTERSECTS_INPUT,\n    },\n  },\n});\n\nconst ELEMENT = new GraphQLObjectType({\n  name: 'Element',\n  description: \"The Element object type is used to return array items' value.\",\n  fields: {\n    value: {\n      description: 'Return the value of the element in the array',\n      type: new GraphQLNonNull(ANY),\n    },\n  },\n});\n\n// Default static union type, we update types and resolveType function later\nlet ARRAY_RESULT;\n\nconst loadArrayResult = (parseGraphQLSchema, parseClassesArray) => {\n  const classTypes = parseClassesArray\n    .filter(parseClass =>\n      parseGraphQLSchema.parseClassTypes[parseClass.className].classGraphQLOutputType ? true : false\n    )\n    .map(\n      parseClass => parseGraphQLSchema.parseClassTypes[parseClass.className].classGraphQLOutputType\n    );\n  ARRAY_RESULT = new GraphQLUnionType({\n    name: 'ArrayResult',\n    description:\n      'Use Inline Fragment on Array to get results: https://graphql.org/learn/queries/#inline-fragments',\n    types: () => [ELEMENT, ...classTypes],\n    resolveType: value => {\n      if (value.__type === 'Object' && value.className && value.objectId) {\n        if (parseGraphQLSchema.parseClassTypes[value.className]) {\n          return parseGraphQLSchema.parseClassTypes[value.className].classGraphQLOutputType.name;\n        } else {\n          return ELEMENT.name;\n        }\n      } else {\n        return ELEMENT.name;\n      }\n    },\n  });\n  parseGraphQLSchema.graphQLTypes.push(ARRAY_RESULT);\n};\n\nconst load = parseGraphQLSchema => {\n  parseGraphQLSchema.addGraphQLType(GraphQLUpload, true);\n  parseGraphQLSchema.addGraphQLType(ANY, true);\n  parseGraphQLSchema.addGraphQLType(OBJECT, true);\n  parseGraphQLSchema.addGraphQLType(DATE, true);\n  parseGraphQLSchema.addGraphQLType(BYTES, true);\n  parseGraphQLSchema.addGraphQLType(FILE, true);\n  parseGraphQLSchema.addGraphQLType(FILE_INFO, true);\n  parseGraphQLSchema.addGraphQLType(FILE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(GEO_POINT_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(GEO_POINT, true);\n  parseGraphQLSchema.addGraphQLType(PARSE_OBJECT, true);\n  parseGraphQLSchema.addGraphQLType(READ_PREFERENCE, true);\n  parseGraphQLSchema.addGraphQLType(READ_OPTIONS_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(SEARCH_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(TEXT_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(BOX_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(WITHIN_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(CENTER_SPHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(GEO_WITHIN_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(GEO_INTERSECTS_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(ID_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(STRING_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(NUMBER_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(BOOLEAN_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(ARRAY_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(KEY_VALUE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(OBJECT_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(DATE_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(BYTES_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(FILE_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(GEO_POINT_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(POLYGON_WHERE_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(ELEMENT, true);\n  parseGraphQLSchema.addGraphQLType(ACL_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(USER_ACL_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(ROLE_ACL_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(PUBLIC_ACL_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(ACL, true);\n  parseGraphQLSchema.addGraphQLType(USER_ACL, true);\n  parseGraphQLSchema.addGraphQLType(ROLE_ACL, true);\n  parseGraphQLSchema.addGraphQLType(PUBLIC_ACL, true);\n  parseGraphQLSchema.addGraphQLType(SUBQUERY_INPUT, true);\n  parseGraphQLSchema.addGraphQLType(SELECT_INPUT, true);\n};\n\nexport {\n  GraphQLUpload,\n  TypeValidationError,\n  parseStringValue,\n  parseIntValue,\n  parseFloatValue,\n  parseBooleanValue,\n  parseValue,\n  parseListValues,\n  parseObjectFields,\n  ANY,\n  OBJECT,\n  parseDateIsoValue,\n  serializeDateIso,\n  DATE,\n  BYTES,\n  parseFileValue,\n  SUBQUERY_INPUT,\n  SELECT_INPUT,\n  FILE,\n  FILE_INFO,\n  FILE_INPUT,\n  GEO_POINT_FIELDS,\n  GEO_POINT_INPUT,\n  GEO_POINT,\n  POLYGON_INPUT,\n  POLYGON,\n  OBJECT_ID,\n  CLASS_NAME_ATT,\n  GLOBAL_OR_OBJECT_ID_ATT,\n  OBJECT_ID_ATT,\n  UPDATED_AT_ATT,\n  CREATED_AT_ATT,\n  INPUT_FIELDS,\n  CREATE_RESULT_FIELDS,\n  UPDATE_RESULT_FIELDS,\n  PARSE_OBJECT_FIELDS,\n  PARSE_OBJECT,\n  SESSION_TOKEN_ATT,\n  READ_PREFERENCE,\n  READ_PREFERENCE_ATT,\n  INCLUDE_READ_PREFERENCE_ATT,\n  SUBQUERY_READ_PREFERENCE_ATT,\n  READ_OPTIONS_INPUT,\n  READ_OPTIONS_ATT,\n  WHERE_ATT,\n  SKIP_ATT,\n  LIMIT_ATT,\n  COUNT_ATT,\n  SEARCH_INPUT,\n  TEXT_INPUT,\n  BOX_INPUT,\n  WITHIN_INPUT,\n  CENTER_SPHERE_INPUT,\n  GEO_WITHIN_INPUT,\n  GEO_INTERSECTS_INPUT,\n  equalTo,\n  notEqualTo,\n  lessThan,\n  lessThanOrEqualTo,\n  greaterThan,\n  greaterThanOrEqualTo,\n  inOp,\n  notIn,\n  exists,\n  matchesRegex,\n  options,\n  inQueryKey,\n  notInQueryKey,\n  ID_WHERE_INPUT,\n  STRING_WHERE_INPUT,\n  NUMBER_WHERE_INPUT,\n  BOOLEAN_WHERE_INPUT,\n  ARRAY_WHERE_INPUT,\n  KEY_VALUE_INPUT,\n  OBJECT_WHERE_INPUT,\n  DATE_WHERE_INPUT,\n  BYTES_WHERE_INPUT,\n  FILE_WHERE_INPUT,\n  GEO_POINT_WHERE_INPUT,\n  POLYGON_WHERE_INPUT,\n  ARRAY_RESULT,\n  ELEMENT,\n  ACL_INPUT,\n  USER_ACL_INPUT,\n  ROLE_ACL_INPUT,\n  PUBLIC_ACL_INPUT,\n  ACL,\n  USER_ACL,\n  ROLE_ACL,\n  PUBLIC_ACL,\n  load,\n  loadArrayResult,\n};\n"],"mappings":"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","ignoreList":[]}