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,433 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.load = void 0;
|
|
7
|
+
var _graphql = require("graphql");
|
|
8
|
+
var _graphqlRelay = require("graphql-relay");
|
|
9
|
+
var _deepcopy = _interopRequireDefault(require("deepcopy"));
|
|
10
|
+
var _UsersRouter = _interopRequireDefault(require("../../Routers/UsersRouter"));
|
|
11
|
+
var objectsMutations = _interopRequireWildcard(require("../helpers/objectsMutations"));
|
|
12
|
+
var _defaultGraphQLTypes = require("./defaultGraphQLTypes");
|
|
13
|
+
var _usersQueries = require("./usersQueries");
|
|
14
|
+
var _mutation = require("../transformers/mutation");
|
|
15
|
+
var _node = _interopRequireDefault(require("parse/node"));
|
|
16
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
17
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
18
|
+
const usersRouter = new _UsersRouter.default();
|
|
19
|
+
const load = parseGraphQLSchema => {
|
|
20
|
+
if (parseGraphQLSchema.isUsersClassDisabled) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const signUpMutation = (0, _graphqlRelay.mutationWithClientMutationId)({
|
|
24
|
+
name: 'SignUp',
|
|
25
|
+
description: 'The signUp mutation can be used to create and sign up a new user.',
|
|
26
|
+
inputFields: {
|
|
27
|
+
fields: {
|
|
28
|
+
descriptions: 'These are the fields of the new user to be created and signed up.',
|
|
29
|
+
type: parseGraphQLSchema.parseClassTypes['_User'].classGraphQLCreateType
|
|
30
|
+
}
|
|
31
|
+
},
|
|
32
|
+
outputFields: {
|
|
33
|
+
viewer: {
|
|
34
|
+
description: 'This is the new user that was created, signed up and returned as a viewer.',
|
|
35
|
+
type: new _graphql.GraphQLNonNull(parseGraphQLSchema.viewerType)
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
mutateAndGetPayload: async (args, context, mutationInfo) => {
|
|
39
|
+
try {
|
|
40
|
+
const {
|
|
41
|
+
fields
|
|
42
|
+
} = (0, _deepcopy.default)(args);
|
|
43
|
+
const {
|
|
44
|
+
config,
|
|
45
|
+
auth,
|
|
46
|
+
info
|
|
47
|
+
} = context;
|
|
48
|
+
const parseFields = await (0, _mutation.transformTypes)('create', fields, {
|
|
49
|
+
className: '_User',
|
|
50
|
+
parseGraphQLSchema,
|
|
51
|
+
originalFields: args.fields,
|
|
52
|
+
req: {
|
|
53
|
+
config,
|
|
54
|
+
auth,
|
|
55
|
+
info
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
const {
|
|
59
|
+
sessionToken,
|
|
60
|
+
objectId,
|
|
61
|
+
authDataResponse
|
|
62
|
+
} = await objectsMutations.createObject('_User', parseFields, config, auth, info);
|
|
63
|
+
context.info.sessionToken = sessionToken;
|
|
64
|
+
const viewer = await (0, _usersQueries.getUserFromSessionToken)(context, mutationInfo, 'viewer.user.', objectId);
|
|
65
|
+
if (authDataResponse && viewer.user) {
|
|
66
|
+
viewer.user.authDataResponse = authDataResponse;
|
|
67
|
+
}
|
|
68
|
+
return {
|
|
69
|
+
viewer
|
|
70
|
+
};
|
|
71
|
+
} catch (e) {
|
|
72
|
+
parseGraphQLSchema.handleError(e);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
parseGraphQLSchema.addGraphQLType(signUpMutation.args.input.type.ofType, true, true);
|
|
77
|
+
parseGraphQLSchema.addGraphQLType(signUpMutation.type, true, true);
|
|
78
|
+
parseGraphQLSchema.addGraphQLMutation('signUp', signUpMutation, true, true);
|
|
79
|
+
const logInWithMutation = (0, _graphqlRelay.mutationWithClientMutationId)({
|
|
80
|
+
name: 'LogInWith',
|
|
81
|
+
description: 'The logInWith mutation can be used to signup, login user with 3rd party authentication system. This mutation create a user if the authData do not correspond to an existing one.',
|
|
82
|
+
inputFields: {
|
|
83
|
+
authData: {
|
|
84
|
+
descriptions: 'This is the auth data of your custom auth provider',
|
|
85
|
+
type: new _graphql.GraphQLNonNull(_defaultGraphQLTypes.OBJECT)
|
|
86
|
+
},
|
|
87
|
+
fields: {
|
|
88
|
+
descriptions: 'These are the fields of the user to be created/updated and logged in.',
|
|
89
|
+
type: new _graphql.GraphQLInputObjectType({
|
|
90
|
+
name: 'UserLoginWithInput',
|
|
91
|
+
fields: () => {
|
|
92
|
+
const classGraphQLCreateFields = parseGraphQLSchema.parseClassTypes['_User'].classGraphQLCreateType.getFields();
|
|
93
|
+
return Object.keys(classGraphQLCreateFields).reduce((fields, fieldName) => {
|
|
94
|
+
if (fieldName !== 'password' && fieldName !== 'username' && fieldName !== 'authData') {
|
|
95
|
+
fields[fieldName] = classGraphQLCreateFields[fieldName];
|
|
96
|
+
}
|
|
97
|
+
return fields;
|
|
98
|
+
}, {});
|
|
99
|
+
}
|
|
100
|
+
})
|
|
101
|
+
}
|
|
102
|
+
},
|
|
103
|
+
outputFields: {
|
|
104
|
+
viewer: {
|
|
105
|
+
description: 'This is the new user that was created, signed up and returned as a viewer.',
|
|
106
|
+
type: new _graphql.GraphQLNonNull(parseGraphQLSchema.viewerType)
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
mutateAndGetPayload: async (args, context, mutationInfo) => {
|
|
110
|
+
try {
|
|
111
|
+
const {
|
|
112
|
+
fields,
|
|
113
|
+
authData
|
|
114
|
+
} = (0, _deepcopy.default)(args);
|
|
115
|
+
const {
|
|
116
|
+
config,
|
|
117
|
+
auth,
|
|
118
|
+
info
|
|
119
|
+
} = context;
|
|
120
|
+
const parseFields = await (0, _mutation.transformTypes)('create', fields, {
|
|
121
|
+
className: '_User',
|
|
122
|
+
parseGraphQLSchema,
|
|
123
|
+
originalFields: args.fields,
|
|
124
|
+
req: {
|
|
125
|
+
config,
|
|
126
|
+
auth,
|
|
127
|
+
info
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
const {
|
|
131
|
+
sessionToken,
|
|
132
|
+
objectId,
|
|
133
|
+
authDataResponse
|
|
134
|
+
} = await objectsMutations.createObject('_User', {
|
|
135
|
+
...parseFields,
|
|
136
|
+
authData
|
|
137
|
+
}, config, auth, info);
|
|
138
|
+
context.info.sessionToken = sessionToken;
|
|
139
|
+
const viewer = await (0, _usersQueries.getUserFromSessionToken)(context, mutationInfo, 'viewer.user.', objectId);
|
|
140
|
+
if (authDataResponse && viewer.user) {
|
|
141
|
+
viewer.user.authDataResponse = authDataResponse;
|
|
142
|
+
}
|
|
143
|
+
return {
|
|
144
|
+
viewer
|
|
145
|
+
};
|
|
146
|
+
} catch (e) {
|
|
147
|
+
parseGraphQLSchema.handleError(e);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
parseGraphQLSchema.addGraphQLType(logInWithMutation.args.input.type.ofType, true, true);
|
|
152
|
+
parseGraphQLSchema.addGraphQLType(logInWithMutation.type, true, true);
|
|
153
|
+
parseGraphQLSchema.addGraphQLMutation('logInWith', logInWithMutation, true, true);
|
|
154
|
+
const logInMutation = (0, _graphqlRelay.mutationWithClientMutationId)({
|
|
155
|
+
name: 'LogIn',
|
|
156
|
+
description: 'The logIn mutation can be used to log in an existing user.',
|
|
157
|
+
inputFields: {
|
|
158
|
+
username: {
|
|
159
|
+
description: 'This is the username used to log in the user.',
|
|
160
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
|
|
161
|
+
},
|
|
162
|
+
password: {
|
|
163
|
+
description: 'This is the password used to log in the user.',
|
|
164
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
|
|
165
|
+
},
|
|
166
|
+
authData: {
|
|
167
|
+
description: 'Auth data payload, needed if some required auth adapters are configured.',
|
|
168
|
+
type: _defaultGraphQLTypes.OBJECT
|
|
169
|
+
}
|
|
170
|
+
},
|
|
171
|
+
outputFields: {
|
|
172
|
+
viewer: {
|
|
173
|
+
description: 'This is the existing user that was logged in and returned as a viewer.',
|
|
174
|
+
type: new _graphql.GraphQLNonNull(parseGraphQLSchema.viewerType)
|
|
175
|
+
}
|
|
176
|
+
},
|
|
177
|
+
mutateAndGetPayload: async (args, context, mutationInfo) => {
|
|
178
|
+
try {
|
|
179
|
+
const {
|
|
180
|
+
username,
|
|
181
|
+
password,
|
|
182
|
+
authData
|
|
183
|
+
} = (0, _deepcopy.default)(args);
|
|
184
|
+
const {
|
|
185
|
+
config,
|
|
186
|
+
auth,
|
|
187
|
+
info
|
|
188
|
+
} = context;
|
|
189
|
+
const {
|
|
190
|
+
sessionToken,
|
|
191
|
+
objectId,
|
|
192
|
+
authDataResponse
|
|
193
|
+
} = (await usersRouter.handleLogIn({
|
|
194
|
+
body: {
|
|
195
|
+
username,
|
|
196
|
+
password,
|
|
197
|
+
authData
|
|
198
|
+
},
|
|
199
|
+
query: {},
|
|
200
|
+
config,
|
|
201
|
+
auth,
|
|
202
|
+
info
|
|
203
|
+
})).response;
|
|
204
|
+
context.info.sessionToken = sessionToken;
|
|
205
|
+
const viewer = await (0, _usersQueries.getUserFromSessionToken)(context, mutationInfo, 'viewer.user.', objectId);
|
|
206
|
+
if (authDataResponse && viewer.user) {
|
|
207
|
+
viewer.user.authDataResponse = authDataResponse;
|
|
208
|
+
}
|
|
209
|
+
return {
|
|
210
|
+
viewer
|
|
211
|
+
};
|
|
212
|
+
} catch (e) {
|
|
213
|
+
parseGraphQLSchema.handleError(e);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
});
|
|
217
|
+
parseGraphQLSchema.addGraphQLType(logInMutation.args.input.type.ofType, true, true);
|
|
218
|
+
parseGraphQLSchema.addGraphQLType(logInMutation.type, true, true);
|
|
219
|
+
parseGraphQLSchema.addGraphQLMutation('logIn', logInMutation, true, true);
|
|
220
|
+
const logOutMutation = (0, _graphqlRelay.mutationWithClientMutationId)({
|
|
221
|
+
name: 'LogOut',
|
|
222
|
+
description: 'The logOut mutation can be used to log out an existing user.',
|
|
223
|
+
outputFields: {
|
|
224
|
+
ok: {
|
|
225
|
+
description: "It's always true.",
|
|
226
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
|
|
227
|
+
}
|
|
228
|
+
},
|
|
229
|
+
mutateAndGetPayload: async (_args, context) => {
|
|
230
|
+
try {
|
|
231
|
+
const {
|
|
232
|
+
config,
|
|
233
|
+
auth,
|
|
234
|
+
info
|
|
235
|
+
} = context;
|
|
236
|
+
await usersRouter.handleLogOut({
|
|
237
|
+
config,
|
|
238
|
+
auth,
|
|
239
|
+
info
|
|
240
|
+
});
|
|
241
|
+
return {
|
|
242
|
+
ok: true
|
|
243
|
+
};
|
|
244
|
+
} catch (e) {
|
|
245
|
+
parseGraphQLSchema.handleError(e);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
});
|
|
249
|
+
parseGraphQLSchema.addGraphQLType(logOutMutation.args.input.type.ofType, true, true);
|
|
250
|
+
parseGraphQLSchema.addGraphQLType(logOutMutation.type, true, true);
|
|
251
|
+
parseGraphQLSchema.addGraphQLMutation('logOut', logOutMutation, true, true);
|
|
252
|
+
const resetPasswordMutation = (0, _graphqlRelay.mutationWithClientMutationId)({
|
|
253
|
+
name: 'ResetPassword',
|
|
254
|
+
description: 'The resetPassword mutation can be used to reset the password of an existing user.',
|
|
255
|
+
inputFields: {
|
|
256
|
+
email: {
|
|
257
|
+
descriptions: 'Email of the user that should receive the reset email',
|
|
258
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
|
|
259
|
+
}
|
|
260
|
+
},
|
|
261
|
+
outputFields: {
|
|
262
|
+
ok: {
|
|
263
|
+
description: "It's always true.",
|
|
264
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
|
|
265
|
+
}
|
|
266
|
+
},
|
|
267
|
+
mutateAndGetPayload: async ({
|
|
268
|
+
email
|
|
269
|
+
}, context) => {
|
|
270
|
+
const {
|
|
271
|
+
config,
|
|
272
|
+
auth,
|
|
273
|
+
info
|
|
274
|
+
} = context;
|
|
275
|
+
await usersRouter.handleResetRequest({
|
|
276
|
+
body: {
|
|
277
|
+
email
|
|
278
|
+
},
|
|
279
|
+
config,
|
|
280
|
+
auth,
|
|
281
|
+
info
|
|
282
|
+
});
|
|
283
|
+
return {
|
|
284
|
+
ok: true
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
});
|
|
288
|
+
parseGraphQLSchema.addGraphQLType(resetPasswordMutation.args.input.type.ofType, true, true);
|
|
289
|
+
parseGraphQLSchema.addGraphQLType(resetPasswordMutation.type, true, true);
|
|
290
|
+
parseGraphQLSchema.addGraphQLMutation('resetPassword', resetPasswordMutation, true, true);
|
|
291
|
+
const confirmResetPasswordMutation = (0, _graphqlRelay.mutationWithClientMutationId)({
|
|
292
|
+
name: 'ConfirmResetPassword',
|
|
293
|
+
description: 'The confirmResetPassword mutation can be used to reset the password of an existing user.',
|
|
294
|
+
inputFields: {
|
|
295
|
+
username: {
|
|
296
|
+
descriptions: 'Username of the user that have received the reset email',
|
|
297
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
|
|
298
|
+
},
|
|
299
|
+
password: {
|
|
300
|
+
descriptions: 'New password of the user',
|
|
301
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
|
|
302
|
+
},
|
|
303
|
+
token: {
|
|
304
|
+
descriptions: 'Reset token that was emailed to the user',
|
|
305
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
|
|
306
|
+
}
|
|
307
|
+
},
|
|
308
|
+
outputFields: {
|
|
309
|
+
ok: {
|
|
310
|
+
description: "It's always true.",
|
|
311
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
|
|
312
|
+
}
|
|
313
|
+
},
|
|
314
|
+
mutateAndGetPayload: async ({
|
|
315
|
+
password,
|
|
316
|
+
token
|
|
317
|
+
}, context) => {
|
|
318
|
+
const {
|
|
319
|
+
config
|
|
320
|
+
} = context;
|
|
321
|
+
if (!password) {
|
|
322
|
+
throw new _node.default.Error(_node.default.Error.PASSWORD_MISSING, 'you must provide a password');
|
|
323
|
+
}
|
|
324
|
+
if (!token) {
|
|
325
|
+
throw new _node.default.Error(_node.default.Error.OTHER_CAUSE, 'you must provide a token');
|
|
326
|
+
}
|
|
327
|
+
const userController = config.userController;
|
|
328
|
+
await userController.updatePassword(token, password);
|
|
329
|
+
return {
|
|
330
|
+
ok: true
|
|
331
|
+
};
|
|
332
|
+
}
|
|
333
|
+
});
|
|
334
|
+
parseGraphQLSchema.addGraphQLType(confirmResetPasswordMutation.args.input.type.ofType, true, true);
|
|
335
|
+
parseGraphQLSchema.addGraphQLType(confirmResetPasswordMutation.type, true, true);
|
|
336
|
+
parseGraphQLSchema.addGraphQLMutation('confirmResetPassword', confirmResetPasswordMutation, true, true);
|
|
337
|
+
const sendVerificationEmailMutation = (0, _graphqlRelay.mutationWithClientMutationId)({
|
|
338
|
+
name: 'SendVerificationEmail',
|
|
339
|
+
description: 'The sendVerificationEmail mutation can be used to send the verification email again.',
|
|
340
|
+
inputFields: {
|
|
341
|
+
email: {
|
|
342
|
+
descriptions: 'Email of the user that should receive the verification email',
|
|
343
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLString)
|
|
344
|
+
}
|
|
345
|
+
},
|
|
346
|
+
outputFields: {
|
|
347
|
+
ok: {
|
|
348
|
+
description: "It's always true.",
|
|
349
|
+
type: new _graphql.GraphQLNonNull(_graphql.GraphQLBoolean)
|
|
350
|
+
}
|
|
351
|
+
},
|
|
352
|
+
mutateAndGetPayload: async ({
|
|
353
|
+
email
|
|
354
|
+
}, context) => {
|
|
355
|
+
try {
|
|
356
|
+
const {
|
|
357
|
+
config,
|
|
358
|
+
auth,
|
|
359
|
+
info
|
|
360
|
+
} = context;
|
|
361
|
+
await usersRouter.handleVerificationEmailRequest({
|
|
362
|
+
body: {
|
|
363
|
+
email
|
|
364
|
+
},
|
|
365
|
+
config,
|
|
366
|
+
auth,
|
|
367
|
+
info
|
|
368
|
+
});
|
|
369
|
+
return {
|
|
370
|
+
ok: true
|
|
371
|
+
};
|
|
372
|
+
} catch (e) {
|
|
373
|
+
parseGraphQLSchema.handleError(e);
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
});
|
|
377
|
+
parseGraphQLSchema.addGraphQLType(sendVerificationEmailMutation.args.input.type.ofType, true, true);
|
|
378
|
+
parseGraphQLSchema.addGraphQLType(sendVerificationEmailMutation.type, true, true);
|
|
379
|
+
parseGraphQLSchema.addGraphQLMutation('sendVerificationEmail', sendVerificationEmailMutation, true, true);
|
|
380
|
+
const challengeMutation = (0, _graphqlRelay.mutationWithClientMutationId)({
|
|
381
|
+
name: 'Challenge',
|
|
382
|
+
description: 'The challenge mutation can be used to initiate an authentication challenge when an auth adapter needs it.',
|
|
383
|
+
inputFields: {
|
|
384
|
+
username: {
|
|
385
|
+
description: 'This is the username used to log in the user.',
|
|
386
|
+
type: _graphql.GraphQLString
|
|
387
|
+
},
|
|
388
|
+
password: {
|
|
389
|
+
description: 'This is the password used to log in the user.',
|
|
390
|
+
type: _graphql.GraphQLString
|
|
391
|
+
},
|
|
392
|
+
authData: {
|
|
393
|
+
description: 'Auth data allow to preidentify the user if the auth adapter needs preidentification.',
|
|
394
|
+
type: _defaultGraphQLTypes.OBJECT
|
|
395
|
+
},
|
|
396
|
+
challengeData: {
|
|
397
|
+
description: 'Challenge data payload, can be used to post data to auth providers to auth providers if they need data for the response.',
|
|
398
|
+
type: _defaultGraphQLTypes.OBJECT
|
|
399
|
+
}
|
|
400
|
+
},
|
|
401
|
+
outputFields: {
|
|
402
|
+
challengeData: {
|
|
403
|
+
description: 'Challenge response from configured auth adapters.',
|
|
404
|
+
type: _defaultGraphQLTypes.OBJECT
|
|
405
|
+
}
|
|
406
|
+
},
|
|
407
|
+
mutateAndGetPayload: async (input, context) => {
|
|
408
|
+
try {
|
|
409
|
+
const {
|
|
410
|
+
config,
|
|
411
|
+
auth,
|
|
412
|
+
info
|
|
413
|
+
} = context;
|
|
414
|
+
const {
|
|
415
|
+
response
|
|
416
|
+
} = await usersRouter.handleChallenge({
|
|
417
|
+
body: input,
|
|
418
|
+
config,
|
|
419
|
+
auth,
|
|
420
|
+
info
|
|
421
|
+
});
|
|
422
|
+
return response;
|
|
423
|
+
} catch (e) {
|
|
424
|
+
parseGraphQLSchema.handleError(e);
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
});
|
|
428
|
+
parseGraphQLSchema.addGraphQLType(challengeMutation.args.input.type.ofType, true, true);
|
|
429
|
+
parseGraphQLSchema.addGraphQLType(challengeMutation.type, true, true);
|
|
430
|
+
parseGraphQLSchema.addGraphQLMutation('challenge', challengeMutation, true, true);
|
|
431
|
+
};
|
|
432
|
+
exports.load = load;
|
|
433
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlRelay","_deepcopy","_interopRequireDefault","_UsersRouter","objectsMutations","_interopRequireWildcard","_defaultGraphQLTypes","_usersQueries","_mutation","_node","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","usersRouter","UsersRouter","load","parseGraphQLSchema","isUsersClassDisabled","signUpMutation","mutationWithClientMutationId","name","description","inputFields","fields","descriptions","type","parseClassTypes","classGraphQLCreateType","outputFields","viewer","GraphQLNonNull","viewerType","mutateAndGetPayload","args","context","mutationInfo","deepcopy","config","auth","info","parseFields","transformTypes","className","originalFields","req","sessionToken","objectId","authDataResponse","createObject","getUserFromSessionToken","user","handleError","addGraphQLType","input","ofType","addGraphQLMutation","logInWithMutation","authData","OBJECT","GraphQLInputObjectType","classGraphQLCreateFields","getFields","keys","reduce","fieldName","logInMutation","username","GraphQLString","password","handleLogIn","body","query","response","logOutMutation","ok","GraphQLBoolean","_args","handleLogOut","resetPasswordMutation","email","handleResetRequest","confirmResetPasswordMutation","token","Parse","Error","PASSWORD_MISSING","OTHER_CAUSE","userController","updatePassword","sendVerificationEmailMutation","handleVerificationEmailRequest","challengeMutation","challengeData","handleChallenge","exports"],"sources":["../../../src/GraphQL/loaders/usersMutations.js"],"sourcesContent":["import { GraphQLNonNull, GraphQLString, GraphQLBoolean, GraphQLInputObjectType } from 'graphql';\nimport { mutationWithClientMutationId } from 'graphql-relay';\nimport deepcopy from 'deepcopy';\nimport UsersRouter from '../../Routers/UsersRouter';\nimport * as objectsMutations from '../helpers/objectsMutations';\nimport { OBJECT } from './defaultGraphQLTypes';\nimport { getUserFromSessionToken } from './usersQueries';\nimport { transformTypes } from '../transformers/mutation';\nimport Parse from 'parse/node';\n\nconst usersRouter = new UsersRouter();\n\nconst load = parseGraphQLSchema => {\n  if (parseGraphQLSchema.isUsersClassDisabled) {\n    return;\n  }\n\n  const signUpMutation = mutationWithClientMutationId({\n    name: 'SignUp',\n    description: 'The signUp mutation can be used to create and sign up a new user.',\n    inputFields: {\n      fields: {\n        descriptions: 'These are the fields of the new user to be created and signed up.',\n        type: parseGraphQLSchema.parseClassTypes['_User'].classGraphQLCreateType,\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the new user that was created, signed up and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { fields } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const parseFields = await transformTypes('create', fields, {\n          className: '_User',\n          parseGraphQLSchema,\n          originalFields: args.fields,\n          req: { config, auth, info },\n        });\n\n        const { sessionToken, objectId, authDataResponse } = await objectsMutations.createObject(\n          '_User',\n          parseFields,\n          config,\n          auth,\n          info\n        );\n\n        context.info.sessionToken = sessionToken;\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(signUpMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(signUpMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('signUp', signUpMutation, true, true);\n  const logInWithMutation = mutationWithClientMutationId({\n    name: 'LogInWith',\n    description:\n      'The logInWith mutation can be used to signup, login user with 3rd party authentication system. This mutation create a user if the authData do not correspond to an existing one.',\n    inputFields: {\n      authData: {\n        descriptions: 'This is the auth data of your custom auth provider',\n        type: new GraphQLNonNull(OBJECT),\n      },\n      fields: {\n        descriptions: 'These are the fields of the user to be created/updated and logged in.',\n        type: new GraphQLInputObjectType({\n          name: 'UserLoginWithInput',\n          fields: () => {\n            const classGraphQLCreateFields = parseGraphQLSchema.parseClassTypes[\n              '_User'\n            ].classGraphQLCreateType.getFields();\n            return Object.keys(classGraphQLCreateFields).reduce((fields, fieldName) => {\n              if (\n                fieldName !== 'password' &&\n                fieldName !== 'username' &&\n                fieldName !== 'authData'\n              ) {\n                fields[fieldName] = classGraphQLCreateFields[fieldName];\n              }\n              return fields;\n            }, {});\n          },\n        }),\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the new user that was created, signed up and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { fields, authData } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const parseFields = await transformTypes('create', fields, {\n          className: '_User',\n          parseGraphQLSchema,\n          originalFields: args.fields,\n          req: { config, auth, info },\n        });\n\n        const { sessionToken, objectId, authDataResponse } = await objectsMutations.createObject(\n          '_User',\n          { ...parseFields, authData },\n          config,\n          auth,\n          info\n        );\n\n        context.info.sessionToken = sessionToken;\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logInWithMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logInWithMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logInWith', logInWithMutation, true, true);\n\n  const logInMutation = mutationWithClientMutationId({\n    name: 'LogIn',\n    description: 'The logIn mutation can be used to log in an existing user.',\n    inputFields: {\n      username: {\n        description: 'This is the username used to log in the user.',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      password: {\n        description: 'This is the password used to log in the user.',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      authData: {\n        description: 'Auth data payload, needed if some required auth adapters are configured.',\n        type: OBJECT,\n      },\n    },\n    outputFields: {\n      viewer: {\n        description: 'This is the existing user that was logged in and returned as a viewer.',\n        type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      },\n    },\n    mutateAndGetPayload: async (args, context, mutationInfo) => {\n      try {\n        const { username, password, authData } = deepcopy(args);\n        const { config, auth, info } = context;\n\n        const { sessionToken, objectId, authDataResponse } = (\n          await usersRouter.handleLogIn({\n            body: {\n              username,\n              password,\n              authData,\n            },\n            query: {},\n            config,\n            auth,\n            info,\n          })\n        ).response;\n\n        context.info.sessionToken = sessionToken;\n\n        const viewer = await getUserFromSessionToken(\n          context,\n          mutationInfo,\n          'viewer.user.',\n          objectId\n        );\n        if (authDataResponse && viewer.user) { viewer.user.authDataResponse = authDataResponse; }\n        return {\n          viewer,\n        };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logInMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logInMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logIn', logInMutation, true, true);\n\n  const logOutMutation = mutationWithClientMutationId({\n    name: 'LogOut',\n    description: 'The logOut mutation can be used to log out an existing user.',\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async (_args, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        await usersRouter.handleLogOut({\n          config,\n          auth,\n          info,\n        });\n\n        return { ok: true };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(logOutMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(logOutMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('logOut', logOutMutation, true, true);\n\n  const resetPasswordMutation = mutationWithClientMutationId({\n    name: 'ResetPassword',\n    description:\n      'The resetPassword mutation can be used to reset the password of an existing user.',\n    inputFields: {\n      email: {\n        descriptions: 'Email of the user that should receive the reset email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ email }, context) => {\n      const { config, auth, info } = context;\n\n      await usersRouter.handleResetRequest({\n        body: {\n          email,\n        },\n        config,\n        auth,\n        info,\n      });\n\n      return { ok: true };\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(resetPasswordMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(resetPasswordMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('resetPassword', resetPasswordMutation, true, true);\n\n  const confirmResetPasswordMutation = mutationWithClientMutationId({\n    name: 'ConfirmResetPassword',\n    description:\n      'The confirmResetPassword mutation can be used to reset the password of an existing user.',\n    inputFields: {\n      username: {\n        descriptions: 'Username of the user that have received the reset email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      password: {\n        descriptions: 'New password of the user',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n      token: {\n        descriptions: 'Reset token that was emailed to the user',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ password, token }, context) => {\n      const { config } = context;\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'you must provide a password');\n      }\n      if (!token) {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'you must provide a token');\n      }\n\n      const userController = config.userController;\n      await userController.updatePassword(token, password);\n      return { ok: true };\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(\n    confirmResetPasswordMutation.args.input.type.ofType,\n    true,\n    true\n  );\n  parseGraphQLSchema.addGraphQLType(confirmResetPasswordMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation(\n    'confirmResetPassword',\n    confirmResetPasswordMutation,\n    true,\n    true\n  );\n\n  const sendVerificationEmailMutation = mutationWithClientMutationId({\n    name: 'SendVerificationEmail',\n    description:\n      'The sendVerificationEmail mutation can be used to send the verification email again.',\n    inputFields: {\n      email: {\n        descriptions: 'Email of the user that should receive the verification email',\n        type: new GraphQLNonNull(GraphQLString),\n      },\n    },\n    outputFields: {\n      ok: {\n        description: \"It's always true.\",\n        type: new GraphQLNonNull(GraphQLBoolean),\n      },\n    },\n    mutateAndGetPayload: async ({ email }, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        await usersRouter.handleVerificationEmailRequest({\n          body: {\n            email,\n          },\n          config,\n          auth,\n          info,\n        });\n\n        return { ok: true };\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(\n    sendVerificationEmailMutation.args.input.type.ofType,\n    true,\n    true\n  );\n  parseGraphQLSchema.addGraphQLType(sendVerificationEmailMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation(\n    'sendVerificationEmail',\n    sendVerificationEmailMutation,\n    true,\n    true\n  );\n\n  const challengeMutation = mutationWithClientMutationId({\n    name: 'Challenge',\n    description:\n      'The challenge mutation can be used to initiate an authentication challenge when an auth adapter needs it.',\n    inputFields: {\n      username: {\n        description: 'This is the username used to log in the user.',\n        type: GraphQLString,\n      },\n      password: {\n        description: 'This is the password used to log in the user.',\n        type: GraphQLString,\n      },\n      authData: {\n        description:\n          'Auth data allow to preidentify the user if the auth adapter needs preidentification.',\n        type: OBJECT,\n      },\n      challengeData: {\n        description:\n          'Challenge data payload, can be used to post data to auth providers to auth providers if they need data for the response.',\n        type: OBJECT,\n      },\n    },\n    outputFields: {\n      challengeData: {\n        description: 'Challenge response from configured auth adapters.',\n        type: OBJECT,\n      },\n    },\n    mutateAndGetPayload: async (input, context) => {\n      try {\n        const { config, auth, info } = context;\n\n        const { response } = await usersRouter.handleChallenge({\n          body: input,\n          config,\n          auth,\n          info,\n        });\n        return response;\n      } catch (e) {\n        parseGraphQLSchema.handleError(e);\n      }\n    },\n  });\n\n  parseGraphQLSchema.addGraphQLType(challengeMutation.args.input.type.ofType, true, true);\n  parseGraphQLSchema.addGraphQLType(challengeMutation.type, true, true);\n  parseGraphQLSchema.addGraphQLMutation('challenge', challengeMutation, true, true);\n};\n\nexport { load };\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.load = exports.getUserFromSessionToken = void 0;
|
|
7
|
+
var _graphql = require("graphql");
|
|
8
|
+
var _graphqlListFields = _interopRequireDefault(require("graphql-list-fields"));
|
|
9
|
+
var _node = _interopRequireDefault(require("parse/node"));
|
|
10
|
+
var _rest = _interopRequireDefault(require("../../rest"));
|
|
11
|
+
var _parseClassTypes = require("./parseClassTypes");
|
|
12
|
+
var _Auth = require("../../Auth");
|
|
13
|
+
var _Error = require("../../Error");
|
|
14
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
15
|
+
const getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) => {
|
|
16
|
+
const {
|
|
17
|
+
info,
|
|
18
|
+
config
|
|
19
|
+
} = context;
|
|
20
|
+
if (!info || !info.sessionToken) {
|
|
21
|
+
throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);
|
|
22
|
+
}
|
|
23
|
+
const sessionToken = info.sessionToken;
|
|
24
|
+
const selectedFields = (0, _graphqlListFields.default)(queryInfo).filter(field => field.startsWith(keysPrefix)).map(field => field.replace(keysPrefix, ''));
|
|
25
|
+
const keysAndInclude = (0, _parseClassTypes.extractKeysAndInclude)(selectedFields);
|
|
26
|
+
const {
|
|
27
|
+
keys
|
|
28
|
+
} = keysAndInclude;
|
|
29
|
+
let {
|
|
30
|
+
include
|
|
31
|
+
} = keysAndInclude;
|
|
32
|
+
if (userId && !keys && !include) {
|
|
33
|
+
return {
|
|
34
|
+
sessionToken
|
|
35
|
+
};
|
|
36
|
+
} else if (keys && !include) {
|
|
37
|
+
include = 'user';
|
|
38
|
+
}
|
|
39
|
+
if (userId) {
|
|
40
|
+
// We need to re create the auth context
|
|
41
|
+
// to avoid security breach if userId is provided
|
|
42
|
+
context.auth = new _Auth.Auth({
|
|
43
|
+
config,
|
|
44
|
+
isMaster: context.auth.isMaster,
|
|
45
|
+
user: {
|
|
46
|
+
id: userId
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
const options = {};
|
|
51
|
+
if (keys) {
|
|
52
|
+
options.keys = keys.split(',').map(key => `${key}`).join(',');
|
|
53
|
+
}
|
|
54
|
+
if (include) {
|
|
55
|
+
options.include = include.split(',').map(included => `${included}`).join(',');
|
|
56
|
+
}
|
|
57
|
+
const response = await _rest.default.find(config, context.auth, '_User',
|
|
58
|
+
// Get the user it self from auth object
|
|
59
|
+
{
|
|
60
|
+
objectId: context.auth.user.id
|
|
61
|
+
}, options, info.clientVersion, info.context);
|
|
62
|
+
if (!response.results || response.results.length == 0) {
|
|
63
|
+
throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);
|
|
64
|
+
} else {
|
|
65
|
+
const user = response.results[0];
|
|
66
|
+
return {
|
|
67
|
+
sessionToken,
|
|
68
|
+
user
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
exports.getUserFromSessionToken = getUserFromSessionToken;
|
|
73
|
+
const load = parseGraphQLSchema => {
|
|
74
|
+
if (parseGraphQLSchema.isUsersClassDisabled) {
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
parseGraphQLSchema.addGraphQLQuery('viewer', {
|
|
78
|
+
description: 'The viewer query can be used to return the current user data.',
|
|
79
|
+
type: new _graphql.GraphQLNonNull(parseGraphQLSchema.viewerType),
|
|
80
|
+
async resolve(_source, _args, context, queryInfo) {
|
|
81
|
+
try {
|
|
82
|
+
return await getUserFromSessionToken(context, queryInfo, 'user.', false);
|
|
83
|
+
} catch (e) {
|
|
84
|
+
parseGraphQLSchema.handleError(e);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}, true, true);
|
|
88
|
+
};
|
|
89
|
+
exports.load = load;
|
|
90
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlListFields","_interopRequireDefault","_node","_rest","_parseClassTypes","_Auth","_Error","e","__esModule","default","getUserFromSessionToken","context","queryInfo","keysPrefix","userId","info","config","sessionToken","createSanitizedError","Parse","Error","INVALID_SESSION_TOKEN","selectedFields","getFieldNames","filter","field","startsWith","map","replace","keysAndInclude","extractKeysAndInclude","keys","include","auth","Auth","isMaster","user","id","options","split","key","join","included","response","rest","find","objectId","clientVersion","results","length","exports","load","parseGraphQLSchema","isUsersClassDisabled","addGraphQLQuery","description","type","GraphQLNonNull","viewerType","resolve","_source","_args","handleError"],"sources":["../../../src/GraphQL/loaders/usersQueries.js"],"sourcesContent":["import { GraphQLNonNull } from 'graphql';\nimport getFieldNames from 'graphql-list-fields';\nimport Parse from 'parse/node';\nimport rest from '../../rest';\nimport { extractKeysAndInclude } from './parseClassTypes';\nimport { Auth } from '../../Auth';\nimport { createSanitizedError } from '../../Error';\n\nconst getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) => {\n  const { info, config } = context;\n  if (!info || !info.sessionToken) {\n    throw  createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);\n  }\n  const sessionToken = info.sessionToken;\n  const selectedFields = getFieldNames(queryInfo)\n    .filter(field => field.startsWith(keysPrefix))\n    .map(field => field.replace(keysPrefix, ''));\n\n  const keysAndInclude = extractKeysAndInclude(selectedFields);\n  const { keys } = keysAndInclude;\n  let { include } = keysAndInclude;\n\n  if (userId && !keys && !include) {\n    return {\n      sessionToken,\n    };\n  } else if (keys && !include) {\n    include = 'user';\n  }\n\n  if (userId) {\n    // We need to re create the auth context\n    // to avoid security breach if userId is provided\n    context.auth = new Auth({\n      config,\n      isMaster: context.auth.isMaster,\n      user: { id: userId },\n    });\n  }\n\n  const options = {};\n  if (keys) {\n    options.keys = keys\n      .split(',')\n      .map(key => `${key}`)\n      .join(',');\n  }\n  if (include) {\n    options.include = include\n      .split(',')\n      .map(included => `${included}`)\n      .join(',');\n  }\n\n  const response = await rest.find(\n    config,\n    context.auth,\n    '_User',\n    // Get the user it self from auth object\n    { objectId: context.auth.user.id },\n    options,\n    info.clientVersion,\n    info.context\n  );\n  if (!response.results || response.results.length == 0) {\n    throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);\n  } else {\n    const user = response.results[0];\n    return {\n      sessionToken,\n      user,\n    };\n  }\n};\n\nconst load = parseGraphQLSchema => {\n  if (parseGraphQLSchema.isUsersClassDisabled) {\n    return;\n  }\n\n  parseGraphQLSchema.addGraphQLQuery(\n    'viewer',\n    {\n      description: 'The viewer query can be used to return the current user data.',\n      type: new GraphQLNonNull(parseGraphQLSchema.viewerType),\n      async resolve(_source, _args, context, queryInfo) {\n        try {\n          return await getUserFromSessionToken(context, queryInfo, 'user.', false);\n        } catch (e) {\n          parseGraphQLSchema.handleError(e);\n        }\n      },\n    },\n    true,\n    true\n  );\n};\n\nexport { load, getUserFromSessionToken };\n"],"mappings":"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","ignoreList":[]}
|