usersQueries.js 11 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.load = exports.getUserFromSessionToken = void 0;
  6. var _graphql = require("graphql");
  7. var _graphqlListFields = _interopRequireDefault(require("graphql-list-fields"));
  8. var _node = _interopRequireDefault(require("parse/node"));
  9. var _rest = _interopRequireDefault(require("../../rest"));
  10. var _parseClassTypes = require("./parseClassTypes");
  11. var _Auth = require("../../Auth");
  12. function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
  13. const getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) => {
  14. const {
  15. info,
  16. config
  17. } = context;
  18. if (!info || !info.sessionToken) {
  19. throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
  20. }
  21. const sessionToken = info.sessionToken;
  22. const selectedFields = (0, _graphqlListFields.default)(queryInfo).filter(field => field.startsWith(keysPrefix)).map(field => field.replace(keysPrefix, ''));
  23. const keysAndInclude = (0, _parseClassTypes.extractKeysAndInclude)(selectedFields);
  24. const {
  25. keys
  26. } = keysAndInclude;
  27. let {
  28. include
  29. } = keysAndInclude;
  30. if (userId && !keys && !include) {
  31. return {
  32. sessionToken
  33. };
  34. } else if (keys && !include) {
  35. include = 'user';
  36. }
  37. if (userId) {
  38. // We need to re create the auth context
  39. // to avoid security breach if userId is provided
  40. context.auth = new _Auth.Auth({
  41. config,
  42. isMaster: context.auth.isMaster,
  43. user: {
  44. id: userId
  45. }
  46. });
  47. }
  48. const options = {};
  49. if (keys) {
  50. options.keys = keys.split(',').map(key => `${key}`).join(',');
  51. }
  52. if (include) {
  53. options.include = include.split(',').map(included => `${included}`).join(',');
  54. }
  55. const response = await _rest.default.find(config, context.auth, '_User',
  56. // Get the user it self from auth object
  57. {
  58. objectId: context.auth.user.id
  59. }, options, info.clientVersion, info.context);
  60. if (!response.results || response.results.length == 0) {
  61. throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
  62. } else {
  63. const user = response.results[0];
  64. return {
  65. sessionToken,
  66. user
  67. };
  68. }
  69. };
  70. exports.getUserFromSessionToken = getUserFromSessionToken;
  71. const load = parseGraphQLSchema => {
  72. if (parseGraphQLSchema.isUsersClassDisabled) {
  73. return;
  74. }
  75. parseGraphQLSchema.addGraphQLQuery('viewer', {
  76. description: 'The viewer query can be used to return the current user data.',
  77. type: new _graphql.GraphQLNonNull(parseGraphQLSchema.viewerType),
  78. async resolve(_source, _args, context, queryInfo) {
  79. try {
  80. return await getUserFromSessionToken(context, queryInfo, 'user.', false);
  81. } catch (e) {
  82. parseGraphQLSchema.handleError(e);
  83. }
  84. }
  85. }, true, true);
  86. };
  87. exports.load = load;
  88. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_graphql","require","_graphqlListFields","_interopRequireDefault","_node","_rest","_parseClassTypes","_Auth","e","__esModule","default","getUserFromSessionToken","context","queryInfo","keysPrefix","userId","info","config","sessionToken","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';\n\nconst getUserFromSessionToken = async (context, queryInfo, keysPrefix, userId) => {\n  const { info, config } = context;\n  if (!info || !info.sessionToken) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\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 new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\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":[]}