parse-server 2.8.4 → 8.6.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (240) hide show
  1. package/LICENSE +167 -25
  2. package/NOTICE +10 -0
  3. package/README.md +929 -278
  4. package/lib/AccountLockout.js +47 -30
  5. package/lib/Adapters/AdapterLoader.js +21 -6
  6. package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
  7. package/lib/Adapters/Auth/AuthAdapter.js +116 -13
  8. package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
  9. package/lib/Adapters/Auth/OAuth1Client.js +27 -46
  10. package/lib/Adapters/Auth/apple.js +123 -0
  11. package/lib/Adapters/Auth/facebook.js +162 -35
  12. package/lib/Adapters/Auth/gcenter.js +217 -0
  13. package/lib/Adapters/Auth/github.js +118 -48
  14. package/lib/Adapters/Auth/google.js +160 -51
  15. package/lib/Adapters/Auth/gpgames.js +125 -0
  16. package/lib/Adapters/Auth/httpsRequest.js +6 -7
  17. package/lib/Adapters/Auth/index.js +170 -62
  18. package/lib/Adapters/Auth/instagram.js +114 -40
  19. package/lib/Adapters/Auth/janraincapture.js +52 -23
  20. package/lib/Adapters/Auth/janrainengage.js +19 -36
  21. package/lib/Adapters/Auth/keycloak.js +148 -0
  22. package/lib/Adapters/Auth/ldap.js +167 -0
  23. package/lib/Adapters/Auth/line.js +125 -0
  24. package/lib/Adapters/Auth/linkedin.js +111 -55
  25. package/lib/Adapters/Auth/meetup.js +24 -34
  26. package/lib/Adapters/Auth/mfa.js +324 -0
  27. package/lib/Adapters/Auth/microsoft.js +111 -0
  28. package/lib/Adapters/Auth/oauth2.js +97 -162
  29. package/lib/Adapters/Auth/phantauth.js +53 -0
  30. package/lib/Adapters/Auth/qq.js +108 -49
  31. package/lib/Adapters/Auth/spotify.js +107 -55
  32. package/lib/Adapters/Auth/twitter.js +188 -48
  33. package/lib/Adapters/Auth/utils.js +28 -0
  34. package/lib/Adapters/Auth/vkontakte.js +26 -39
  35. package/lib/Adapters/Auth/wechat.js +106 -44
  36. package/lib/Adapters/Auth/weibo.js +132 -58
  37. package/lib/Adapters/Cache/CacheAdapter.js +13 -8
  38. package/lib/Adapters/Cache/InMemoryCache.js +3 -13
  39. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
  40. package/lib/Adapters/Cache/LRUCache.js +13 -27
  41. package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
  42. package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
  43. package/lib/Adapters/Cache/SchemaCache.js +25 -0
  44. package/lib/Adapters/Email/MailAdapter.js +10 -8
  45. package/lib/Adapters/Files/FilesAdapter.js +83 -25
  46. package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
  47. package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
  48. package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
  49. package/lib/Adapters/Logger/WinstonLogger.js +69 -88
  50. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
  51. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
  52. package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
  53. package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
  54. package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
  55. package/lib/Adapters/Push/PushAdapter.js +14 -7
  56. package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
  57. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
  58. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
  59. package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
  60. package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
  61. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
  62. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
  63. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
  64. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  65. package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
  66. package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
  67. package/lib/Auth.js +488 -125
  68. package/lib/ClientSDK.js +2 -6
  69. package/lib/Config.js +525 -94
  70. package/lib/Controllers/AdaptableController.js +5 -25
  71. package/lib/Controllers/AnalyticsController.js +22 -23
  72. package/lib/Controllers/CacheController.js +10 -31
  73. package/lib/Controllers/DatabaseController.js +767 -313
  74. package/lib/Controllers/FilesController.js +49 -54
  75. package/lib/Controllers/HooksController.js +80 -84
  76. package/lib/Controllers/LiveQueryController.js +35 -22
  77. package/lib/Controllers/LoggerController.js +22 -58
  78. package/lib/Controllers/ParseGraphQLController.js +293 -0
  79. package/lib/Controllers/PushController.js +58 -49
  80. package/lib/Controllers/SchemaController.js +916 -422
  81. package/lib/Controllers/UserController.js +265 -180
  82. package/lib/Controllers/index.js +90 -125
  83. package/lib/Controllers/types.js +1 -1
  84. package/lib/Deprecator/Deprecations.js +30 -0
  85. package/lib/Deprecator/Deprecator.js +127 -0
  86. package/lib/Error.js +48 -0
  87. package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
  88. package/lib/GraphQL/ParseGraphQLServer.js +214 -0
  89. package/lib/GraphQL/helpers/objectsMutations.js +30 -0
  90. package/lib/GraphQL/helpers/objectsQueries.js +246 -0
  91. package/lib/GraphQL/loaders/configMutations.js +87 -0
  92. package/lib/GraphQL/loaders/configQueries.js +79 -0
  93. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
  94. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
  95. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
  96. package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
  97. package/lib/GraphQL/loaders/filesMutations.js +107 -0
  98. package/lib/GraphQL/loaders/functionsMutations.js +78 -0
  99. package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
  100. package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
  101. package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
  102. package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
  103. package/lib/GraphQL/loaders/schemaMutations.js +162 -0
  104. package/lib/GraphQL/loaders/schemaQueries.js +81 -0
  105. package/lib/GraphQL/loaders/schemaTypes.js +341 -0
  106. package/lib/GraphQL/loaders/usersMutations.js +433 -0
  107. package/lib/GraphQL/loaders/usersQueries.js +90 -0
  108. package/lib/GraphQL/parseGraphQLUtils.js +63 -0
  109. package/lib/GraphQL/transformers/className.js +14 -0
  110. package/lib/GraphQL/transformers/constraintType.js +53 -0
  111. package/lib/GraphQL/transformers/inputType.js +51 -0
  112. package/lib/GraphQL/transformers/mutation.js +274 -0
  113. package/lib/GraphQL/transformers/outputType.js +51 -0
  114. package/lib/GraphQL/transformers/query.js +237 -0
  115. package/lib/GraphQL/transformers/schemaFields.js +99 -0
  116. package/lib/KeyPromiseQueue.js +48 -0
  117. package/lib/LiveQuery/Client.js +25 -33
  118. package/lib/LiveQuery/Id.js +2 -5
  119. package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
  120. package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
  121. package/lib/LiveQuery/ParsePubSub.js +7 -16
  122. package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
  123. package/lib/LiveQuery/QueryTools.js +76 -15
  124. package/lib/LiveQuery/RequestSchema.js +111 -97
  125. package/lib/LiveQuery/SessionTokenCache.js +23 -36
  126. package/lib/LiveQuery/Subscription.js +8 -17
  127. package/lib/LiveQuery/equalObjects.js +2 -3
  128. package/lib/Options/Definitions.js +1355 -382
  129. package/lib/Options/docs.js +301 -62
  130. package/lib/Options/index.js +11 -1
  131. package/lib/Options/parsers.js +14 -10
  132. package/lib/Page.js +44 -0
  133. package/lib/ParseMessageQueue.js +6 -13
  134. package/lib/ParseServer.js +474 -235
  135. package/lib/ParseServerRESTController.js +102 -40
  136. package/lib/PromiseRouter.js +39 -50
  137. package/lib/Push/PushQueue.js +24 -30
  138. package/lib/Push/PushWorker.js +32 -56
  139. package/lib/Push/utils.js +22 -35
  140. package/lib/RestQuery.js +361 -139
  141. package/lib/RestWrite.js +713 -344
  142. package/lib/Routers/AggregateRouter.js +97 -71
  143. package/lib/Routers/AnalyticsRouter.js +8 -14
  144. package/lib/Routers/AudiencesRouter.js +16 -35
  145. package/lib/Routers/ClassesRouter.js +86 -72
  146. package/lib/Routers/CloudCodeRouter.js +28 -37
  147. package/lib/Routers/FeaturesRouter.js +22 -25
  148. package/lib/Routers/FilesRouter.js +266 -171
  149. package/lib/Routers/FunctionsRouter.js +87 -103
  150. package/lib/Routers/GlobalConfigRouter.js +94 -33
  151. package/lib/Routers/GraphQLRouter.js +41 -0
  152. package/lib/Routers/HooksRouter.js +43 -47
  153. package/lib/Routers/IAPValidationRouter.js +57 -70
  154. package/lib/Routers/InstallationsRouter.js +17 -25
  155. package/lib/Routers/LogsRouter.js +10 -25
  156. package/lib/Routers/PagesRouter.js +647 -0
  157. package/lib/Routers/PublicAPIRouter.js +104 -112
  158. package/lib/Routers/PurgeRouter.js +19 -29
  159. package/lib/Routers/PushRouter.js +14 -28
  160. package/lib/Routers/RolesRouter.js +7 -14
  161. package/lib/Routers/SchemasRouter.js +63 -42
  162. package/lib/Routers/SecurityRouter.js +34 -0
  163. package/lib/Routers/SessionsRouter.js +25 -38
  164. package/lib/Routers/UsersRouter.js +463 -190
  165. package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
  166. package/lib/SchemaMigrations/Migrations.js +30 -0
  167. package/lib/Security/Check.js +109 -0
  168. package/lib/Security/CheckGroup.js +44 -0
  169. package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
  170. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
  171. package/lib/Security/CheckGroups/CheckGroups.js +21 -0
  172. package/lib/Security/CheckRunner.js +213 -0
  173. package/lib/SharedRest.js +29 -0
  174. package/lib/StatusHandler.js +96 -93
  175. package/lib/TestUtils.js +70 -14
  176. package/lib/Utils.js +468 -0
  177. package/lib/batch.js +74 -40
  178. package/lib/cache.js +8 -8
  179. package/lib/cli/definitions/parse-live-query-server.js +4 -3
  180. package/lib/cli/definitions/parse-server.js +4 -3
  181. package/lib/cli/parse-live-query-server.js +9 -17
  182. package/lib/cli/parse-server.js +49 -47
  183. package/lib/cli/utils/commander.js +20 -29
  184. package/lib/cli/utils/runner.js +31 -32
  185. package/lib/cloud-code/Parse.Cloud.js +711 -36
  186. package/lib/cloud-code/Parse.Server.js +21 -0
  187. package/lib/cryptoUtils.js +6 -11
  188. package/lib/defaults.js +21 -15
  189. package/lib/deprecated.js +1 -1
  190. package/lib/index.js +78 -67
  191. package/lib/logger.js +12 -20
  192. package/lib/middlewares.js +484 -160
  193. package/lib/password.js +10 -6
  194. package/lib/request.js +175 -0
  195. package/lib/requiredParameter.js +4 -3
  196. package/lib/rest.js +157 -82
  197. package/lib/triggers.js +627 -185
  198. package/lib/vendor/README.md +3 -3
  199. package/lib/vendor/mongodbUrl.js +224 -137
  200. package/package.json +135 -57
  201. package/postinstall.js +38 -50
  202. package/public_html/invalid_verification_link.html +3 -3
  203. package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
  204. package/types/@types/deepcopy/index.d.ts +5 -0
  205. package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
  206. package/types/Options/index.d.ts +301 -0
  207. package/types/ParseServer.d.ts +65 -0
  208. package/types/eslint.config.mjs +30 -0
  209. package/types/index.d.ts +21 -0
  210. package/types/logger.d.ts +2 -0
  211. package/types/tests.ts +44 -0
  212. package/types/tsconfig.json +24 -0
  213. package/CHANGELOG.md +0 -1246
  214. package/PATENTS +0 -37
  215. package/bin/dev +0 -37
  216. package/lib/.DS_Store +0 -0
  217. package/lib/Adapters/Auth/common.js +0 -2
  218. package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
  219. package/lib/Controllers/SchemaCache.js +0 -97
  220. package/lib/LiveQuery/.DS_Store +0 -0
  221. package/lib/cli/utils/parsers.js +0 -77
  222. package/lib/cloud-code/.DS_Store +0 -0
  223. package/lib/cloud-code/HTTPResponse.js +0 -57
  224. package/lib/cloud-code/Untitled-1 +0 -123
  225. package/lib/cloud-code/httpRequest.js +0 -102
  226. package/lib/cloud-code/team.html +0 -123
  227. package/lib/graphql/ParseClass.js +0 -234
  228. package/lib/graphql/Schema.js +0 -197
  229. package/lib/graphql/index.js +0 -1
  230. package/lib/graphql/types/ACL.js +0 -35
  231. package/lib/graphql/types/Date.js +0 -25
  232. package/lib/graphql/types/File.js +0 -24
  233. package/lib/graphql/types/GeoPoint.js +0 -35
  234. package/lib/graphql/types/JSONObject.js +0 -30
  235. package/lib/graphql/types/NumberInput.js +0 -43
  236. package/lib/graphql/types/NumberQuery.js +0 -42
  237. package/lib/graphql/types/Pointer.js +0 -35
  238. package/lib/graphql/types/QueryConstraint.js +0 -61
  239. package/lib/graphql/types/StringQuery.js +0 -39
  240. package/lib/graphql/types/index.js +0 -110
@@ -0,0 +1,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":[]}