SessionsRouter.js 11 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = exports.SessionsRouter = void 0;
  6. var _ClassesRouter = _interopRequireDefault(require("./ClassesRouter"));
  7. var _node = _interopRequireDefault(require("parse/node"));
  8. var _rest = _interopRequireDefault(require("../rest"));
  9. var _Auth = _interopRequireDefault(require("../Auth"));
  10. var _RestWrite = _interopRequireDefault(require("../RestWrite"));
  11. function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
  12. class SessionsRouter extends _ClassesRouter.default {
  13. className() {
  14. return '_Session';
  15. }
  16. handleMe(req) {
  17. // TODO: Verify correct behavior
  18. if (!req.info || !req.info.sessionToken) {
  19. throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Session token required.');
  20. }
  21. return _rest.default.find(req.config, _Auth.default.master(req.config), '_Session', {
  22. sessionToken: req.info.sessionToken
  23. }, undefined, req.info.clientSDK, req.info.context).then(response => {
  24. if (!response.results || response.results.length == 0) {
  25. throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Session token not found.');
  26. }
  27. return {
  28. response: response.results[0]
  29. };
  30. });
  31. }
  32. handleUpdateToRevocableSession(req) {
  33. const config = req.config;
  34. const user = req.auth.user;
  35. // Issue #2720
  36. // Calling without a session token would result in a not found user
  37. if (!user) {
  38. throw new _node.default.Error(_node.default.Error.OBJECT_NOT_FOUND, 'invalid session');
  39. }
  40. const {
  41. sessionData,
  42. createSession
  43. } = _RestWrite.default.createSession(config, {
  44. userId: user.id,
  45. createdWith: {
  46. action: 'upgrade'
  47. },
  48. installationId: req.auth.installationId
  49. });
  50. return createSession().then(() => {
  51. // delete the session token, use the db to skip beforeSave
  52. return config.database.update('_User', {
  53. objectId: user.id
  54. }, {
  55. sessionToken: {
  56. __op: 'Delete'
  57. }
  58. });
  59. }).then(() => {
  60. return Promise.resolve({
  61. response: sessionData
  62. });
  63. });
  64. }
  65. mountRoutes() {
  66. this.route('GET', '/sessions/me', req => {
  67. return this.handleMe(req);
  68. });
  69. this.route('GET', '/sessions', req => {
  70. return this.handleFind(req);
  71. });
  72. this.route('GET', '/sessions/:objectId', req => {
  73. return this.handleGet(req);
  74. });
  75. this.route('POST', '/sessions', req => {
  76. return this.handleCreate(req);
  77. });
  78. this.route('PUT', '/sessions/:objectId', req => {
  79. return this.handleUpdate(req);
  80. });
  81. this.route('DELETE', '/sessions/:objectId', req => {
  82. return this.handleDelete(req);
  83. });
  84. this.route('POST', '/upgradeToRevocableSession', req => {
  85. return this.handleUpdateToRevocableSession(req);
  86. });
  87. }
  88. }
  89. exports.SessionsRouter = SessionsRouter;
  90. var _default = exports.default = SessionsRouter;
  91. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_ClassesRouter","_interopRequireDefault","require","_node","_rest","_Auth","_RestWrite","e","__esModule","default","SessionsRouter","ClassesRouter","className","handleMe","req","info","sessionToken","Parse","Error","INVALID_SESSION_TOKEN","rest","find","config","Auth","master","undefined","clientSDK","context","then","response","results","length","handleUpdateToRevocableSession","user","auth","OBJECT_NOT_FOUND","sessionData","createSession","RestWrite","userId","id","createdWith","action","installationId","database","update","objectId","__op","Promise","resolve","mountRoutes","route","handleFind","handleGet","handleCreate","handleUpdate","handleDelete","exports","_default"],"sources":["../../src/Routers/SessionsRouter.js"],"sourcesContent":["import ClassesRouter from './ClassesRouter';\nimport Parse from 'parse/node';\nimport rest from '../rest';\nimport Auth from '../Auth';\nimport RestWrite from '../RestWrite';\n\nexport class SessionsRouter extends ClassesRouter {\n  className() {\n    return '_Session';\n  }\n\n  handleMe(req) {\n    // TODO: Verify correct behavior\n    if (!req.info || !req.info.sessionToken) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token required.');\n    }\n    return rest\n      .find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken: req.info.sessionToken },\n        undefined,\n        req.info.clientSDK,\n        req.info.context\n      )\n      .then(response => {\n        if (!response.results || response.results.length == 0) {\n          throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token not found.');\n        }\n        return {\n          response: response.results[0],\n        };\n      });\n  }\n\n  handleUpdateToRevocableSession(req) {\n    const config = req.config;\n    const user = req.auth.user;\n    // Issue #2720\n    // Calling without a session token would result in a not found user\n    if (!user) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'invalid session');\n    }\n    const { sessionData, createSession } = RestWrite.createSession(config, {\n      userId: user.id,\n      createdWith: {\n        action: 'upgrade',\n      },\n      installationId: req.auth.installationId,\n    });\n\n    return createSession()\n      .then(() => {\n        // delete the session token, use the db to skip beforeSave\n        return config.database.update(\n          '_User',\n          {\n            objectId: user.id,\n          },\n          {\n            sessionToken: { __op: 'Delete' },\n          }\n        );\n      })\n      .then(() => {\n        return Promise.resolve({ response: sessionData });\n      });\n  }\n\n  mountRoutes() {\n    this.route('GET', '/sessions/me', req => {\n      return this.handleMe(req);\n    });\n    this.route('GET', '/sessions', req => {\n      return this.handleFind(req);\n    });\n    this.route('GET', '/sessions/:objectId', req => {\n      return this.handleGet(req);\n    });\n    this.route('POST', '/sessions', req => {\n      return this.handleCreate(req);\n    });\n    this.route('PUT', '/sessions/:objectId', req => {\n      return this.handleUpdate(req);\n    });\n    this.route('DELETE', '/sessions/:objectId', req => {\n      return this.handleDelete(req);\n    });\n    this.route('POST', '/upgradeToRevocableSession', req => {\n      return this.handleUpdateToRevocableSession(req);\n    });\n  }\n}\n\nexport default SessionsRouter;\n"],"mappings":"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","ignoreList":[]}