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.
- package/LICENSE +167 -25
- package/NOTICE +10 -0
- package/README.md +929 -278
- package/lib/AccountLockout.js +47 -30
- package/lib/Adapters/AdapterLoader.js +21 -6
- package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
- package/lib/Adapters/Auth/AuthAdapter.js +116 -13
- package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
- package/lib/Adapters/Auth/OAuth1Client.js +27 -46
- package/lib/Adapters/Auth/apple.js +123 -0
- package/lib/Adapters/Auth/facebook.js +162 -35
- package/lib/Adapters/Auth/gcenter.js +217 -0
- package/lib/Adapters/Auth/github.js +118 -48
- package/lib/Adapters/Auth/google.js +160 -51
- package/lib/Adapters/Auth/gpgames.js +125 -0
- package/lib/Adapters/Auth/httpsRequest.js +6 -7
- package/lib/Adapters/Auth/index.js +170 -62
- package/lib/Adapters/Auth/instagram.js +114 -40
- package/lib/Adapters/Auth/janraincapture.js +52 -23
- package/lib/Adapters/Auth/janrainengage.js +19 -36
- package/lib/Adapters/Auth/keycloak.js +148 -0
- package/lib/Adapters/Auth/ldap.js +167 -0
- package/lib/Adapters/Auth/line.js +125 -0
- package/lib/Adapters/Auth/linkedin.js +111 -55
- package/lib/Adapters/Auth/meetup.js +24 -34
- package/lib/Adapters/Auth/mfa.js +324 -0
- package/lib/Adapters/Auth/microsoft.js +111 -0
- package/lib/Adapters/Auth/oauth2.js +97 -162
- package/lib/Adapters/Auth/phantauth.js +53 -0
- package/lib/Adapters/Auth/qq.js +108 -49
- package/lib/Adapters/Auth/spotify.js +107 -55
- package/lib/Adapters/Auth/twitter.js +188 -48
- package/lib/Adapters/Auth/utils.js +28 -0
- package/lib/Adapters/Auth/vkontakte.js +26 -39
- package/lib/Adapters/Auth/wechat.js +106 -44
- package/lib/Adapters/Auth/weibo.js +132 -58
- package/lib/Adapters/Cache/CacheAdapter.js +13 -8
- package/lib/Adapters/Cache/InMemoryCache.js +3 -13
- package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
- package/lib/Adapters/Cache/LRUCache.js +13 -27
- package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
- package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
- package/lib/Adapters/Cache/SchemaCache.js +25 -0
- package/lib/Adapters/Email/MailAdapter.js +10 -8
- package/lib/Adapters/Files/FilesAdapter.js +83 -25
- package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
- package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
- package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
- package/lib/Adapters/Logger/WinstonLogger.js +69 -88
- package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
- package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
- package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
- package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
- package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
- package/lib/Adapters/Push/PushAdapter.js +14 -7
- package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
- package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
- package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
- package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
- package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
- package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
- package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
- package/lib/Adapters/Storage/StorageAdapter.js +1 -1
- package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
- package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
- package/lib/Auth.js +488 -125
- package/lib/ClientSDK.js +2 -6
- package/lib/Config.js +525 -94
- package/lib/Controllers/AdaptableController.js +5 -25
- package/lib/Controllers/AnalyticsController.js +22 -23
- package/lib/Controllers/CacheController.js +10 -31
- package/lib/Controllers/DatabaseController.js +767 -313
- package/lib/Controllers/FilesController.js +49 -54
- package/lib/Controllers/HooksController.js +80 -84
- package/lib/Controllers/LiveQueryController.js +35 -22
- package/lib/Controllers/LoggerController.js +22 -58
- package/lib/Controllers/ParseGraphQLController.js +293 -0
- package/lib/Controllers/PushController.js +58 -49
- package/lib/Controllers/SchemaController.js +916 -422
- package/lib/Controllers/UserController.js +265 -180
- package/lib/Controllers/index.js +90 -125
- package/lib/Controllers/types.js +1 -1
- package/lib/Deprecator/Deprecations.js +30 -0
- package/lib/Deprecator/Deprecator.js +127 -0
- package/lib/Error.js +48 -0
- package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
- package/lib/GraphQL/ParseGraphQLServer.js +214 -0
- package/lib/GraphQL/helpers/objectsMutations.js +30 -0
- package/lib/GraphQL/helpers/objectsQueries.js +246 -0
- package/lib/GraphQL/loaders/configMutations.js +87 -0
- package/lib/GraphQL/loaders/configQueries.js +79 -0
- package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
- package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
- package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
- package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
- package/lib/GraphQL/loaders/filesMutations.js +107 -0
- package/lib/GraphQL/loaders/functionsMutations.js +78 -0
- package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
- package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
- package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
- package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
- package/lib/GraphQL/loaders/schemaMutations.js +162 -0
- package/lib/GraphQL/loaders/schemaQueries.js +81 -0
- package/lib/GraphQL/loaders/schemaTypes.js +341 -0
- package/lib/GraphQL/loaders/usersMutations.js +433 -0
- package/lib/GraphQL/loaders/usersQueries.js +90 -0
- package/lib/GraphQL/parseGraphQLUtils.js +63 -0
- package/lib/GraphQL/transformers/className.js +14 -0
- package/lib/GraphQL/transformers/constraintType.js +53 -0
- package/lib/GraphQL/transformers/inputType.js +51 -0
- package/lib/GraphQL/transformers/mutation.js +274 -0
- package/lib/GraphQL/transformers/outputType.js +51 -0
- package/lib/GraphQL/transformers/query.js +237 -0
- package/lib/GraphQL/transformers/schemaFields.js +99 -0
- package/lib/KeyPromiseQueue.js +48 -0
- package/lib/LiveQuery/Client.js +25 -33
- package/lib/LiveQuery/Id.js +2 -5
- package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
- package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
- package/lib/LiveQuery/ParsePubSub.js +7 -16
- package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
- package/lib/LiveQuery/QueryTools.js +76 -15
- package/lib/LiveQuery/RequestSchema.js +111 -97
- package/lib/LiveQuery/SessionTokenCache.js +23 -36
- package/lib/LiveQuery/Subscription.js +8 -17
- package/lib/LiveQuery/equalObjects.js +2 -3
- package/lib/Options/Definitions.js +1355 -382
- package/lib/Options/docs.js +301 -62
- package/lib/Options/index.js +11 -1
- package/lib/Options/parsers.js +14 -10
- package/lib/Page.js +44 -0
- package/lib/ParseMessageQueue.js +6 -13
- package/lib/ParseServer.js +474 -235
- package/lib/ParseServerRESTController.js +102 -40
- package/lib/PromiseRouter.js +39 -50
- package/lib/Push/PushQueue.js +24 -30
- package/lib/Push/PushWorker.js +32 -56
- package/lib/Push/utils.js +22 -35
- package/lib/RestQuery.js +361 -139
- package/lib/RestWrite.js +713 -344
- package/lib/Routers/AggregateRouter.js +97 -71
- package/lib/Routers/AnalyticsRouter.js +8 -14
- package/lib/Routers/AudiencesRouter.js +16 -35
- package/lib/Routers/ClassesRouter.js +86 -72
- package/lib/Routers/CloudCodeRouter.js +28 -37
- package/lib/Routers/FeaturesRouter.js +22 -25
- package/lib/Routers/FilesRouter.js +266 -171
- package/lib/Routers/FunctionsRouter.js +87 -103
- package/lib/Routers/GlobalConfigRouter.js +94 -33
- package/lib/Routers/GraphQLRouter.js +41 -0
- package/lib/Routers/HooksRouter.js +43 -47
- package/lib/Routers/IAPValidationRouter.js +57 -70
- package/lib/Routers/InstallationsRouter.js +17 -25
- package/lib/Routers/LogsRouter.js +10 -25
- package/lib/Routers/PagesRouter.js +647 -0
- package/lib/Routers/PublicAPIRouter.js +104 -112
- package/lib/Routers/PurgeRouter.js +19 -29
- package/lib/Routers/PushRouter.js +14 -28
- package/lib/Routers/RolesRouter.js +7 -14
- package/lib/Routers/SchemasRouter.js +63 -42
- package/lib/Routers/SecurityRouter.js +34 -0
- package/lib/Routers/SessionsRouter.js +25 -38
- package/lib/Routers/UsersRouter.js +463 -190
- package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
- package/lib/SchemaMigrations/Migrations.js +30 -0
- package/lib/Security/Check.js +109 -0
- package/lib/Security/CheckGroup.js +44 -0
- package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
- package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
- package/lib/Security/CheckGroups/CheckGroups.js +21 -0
- package/lib/Security/CheckRunner.js +213 -0
- package/lib/SharedRest.js +29 -0
- package/lib/StatusHandler.js +96 -93
- package/lib/TestUtils.js +70 -14
- package/lib/Utils.js +468 -0
- package/lib/batch.js +74 -40
- package/lib/cache.js +8 -8
- package/lib/cli/definitions/parse-live-query-server.js +4 -3
- package/lib/cli/definitions/parse-server.js +4 -3
- package/lib/cli/parse-live-query-server.js +9 -17
- package/lib/cli/parse-server.js +49 -47
- package/lib/cli/utils/commander.js +20 -29
- package/lib/cli/utils/runner.js +31 -32
- package/lib/cloud-code/Parse.Cloud.js +711 -36
- package/lib/cloud-code/Parse.Server.js +21 -0
- package/lib/cryptoUtils.js +6 -11
- package/lib/defaults.js +21 -15
- package/lib/deprecated.js +1 -1
- package/lib/index.js +78 -67
- package/lib/logger.js +12 -20
- package/lib/middlewares.js +484 -160
- package/lib/password.js +10 -6
- package/lib/request.js +175 -0
- package/lib/requiredParameter.js +4 -3
- package/lib/rest.js +157 -82
- package/lib/triggers.js +627 -185
- package/lib/vendor/README.md +3 -3
- package/lib/vendor/mongodbUrl.js +224 -137
- package/package.json +135 -57
- package/postinstall.js +38 -50
- package/public_html/invalid_verification_link.html +3 -3
- package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
- package/types/@types/deepcopy/index.d.ts +5 -0
- package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
- package/types/Options/index.d.ts +301 -0
- package/types/ParseServer.d.ts +65 -0
- package/types/eslint.config.mjs +30 -0
- package/types/index.d.ts +21 -0
- package/types/logger.d.ts +2 -0
- package/types/tests.ts +44 -0
- package/types/tsconfig.json +24 -0
- package/CHANGELOG.md +0 -1246
- package/PATENTS +0 -37
- package/bin/dev +0 -37
- package/lib/.DS_Store +0 -0
- package/lib/Adapters/Auth/common.js +0 -2
- package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
- package/lib/Controllers/SchemaCache.js +0 -97
- package/lib/LiveQuery/.DS_Store +0 -0
- package/lib/cli/utils/parsers.js +0 -77
- package/lib/cloud-code/.DS_Store +0 -0
- package/lib/cloud-code/HTTPResponse.js +0 -57
- package/lib/cloud-code/Untitled-1 +0 -123
- package/lib/cloud-code/httpRequest.js +0 -102
- package/lib/cloud-code/team.html +0 -123
- package/lib/graphql/ParseClass.js +0 -234
- package/lib/graphql/Schema.js +0 -197
- package/lib/graphql/index.js +0 -1
- package/lib/graphql/types/ACL.js +0 -35
- package/lib/graphql/types/Date.js +0 -25
- package/lib/graphql/types/File.js +0 -24
- package/lib/graphql/types/GeoPoint.js +0 -35
- package/lib/graphql/types/JSONObject.js +0 -30
- package/lib/graphql/types/NumberInput.js +0 -43
- package/lib/graphql/types/NumberQuery.js +0 -42
- package/lib/graphql/types/Pointer.js +0 -35
- package/lib/graphql/types/QueryConstraint.js +0 -61
- package/lib/graphql/types/StringQuery.js +0 -39
- 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":[]}
|