ParseSession.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = void 0;
  6. var _CoreManager = _interopRequireDefault(require("./CoreManager"));
  7. var _isRevocableSession = _interopRequireDefault(require("./isRevocableSession"));
  8. var _ParseObject = _interopRequireDefault(require("./ParseObject"));
  9. var _ParseUser = _interopRequireDefault(require("./ParseUser"));
  10. function _interopRequireDefault(e) {
  11. return e && e.__esModule ? e : {
  12. default: e
  13. };
  14. }
  15. /**
  16. * <p>A Parse.Session object is a local representation of a revocable session.
  17. * This class is a subclass of a Parse.Object, and retains the same
  18. * functionality of a Parse.Object.</p>
  19. *
  20. * @alias Parse.Session
  21. * @augments Parse.Object
  22. */
  23. class ParseSession extends _ParseObject.default {
  24. /**
  25. * @param {object} attributes The initial set of data to store in the user.
  26. */
  27. constructor(attributes) {
  28. super('_Session');
  29. if (attributes && typeof attributes === 'object') {
  30. if (!this.set(attributes || {})) {
  31. throw new Error("Can't create an invalid Session");
  32. }
  33. }
  34. }
  35. /**
  36. * Returns the session token string.
  37. *
  38. * @returns {string}
  39. */
  40. getSessionToken() {
  41. const token = this.get('sessionToken');
  42. if (typeof token === 'string') {
  43. return token;
  44. }
  45. return '';
  46. }
  47. static readOnlyAttributes() {
  48. return ['createdWith', 'expiresAt', 'installationId', 'restricted', 'sessionToken', 'user'];
  49. }
  50. /**
  51. * Retrieves the Session object for the currently logged in session.
  52. *
  53. * @param {object} options useMasterKey
  54. * @static
  55. * @returns {Promise} A promise that is resolved with the Parse.Session
  56. * object after it has been fetched. If there is no current user, the
  57. * promise will be rejected.
  58. */
  59. static current(options) {
  60. options = options || {};
  61. const controller = _CoreManager.default.getSessionController();
  62. const sessionOptions = {};
  63. if (options.hasOwnProperty('useMasterKey')) {
  64. sessionOptions.useMasterKey = options.useMasterKey;
  65. }
  66. return _ParseUser.default.currentAsync().then(user => {
  67. if (!user) {
  68. return Promise.reject('There is no current user.');
  69. }
  70. sessionOptions.sessionToken = user.getSessionToken();
  71. return controller.getSession(sessionOptions);
  72. });
  73. }
  74. /**
  75. * Determines whether the current session token is revocable.
  76. * This method is useful for migrating Express.js or Node.js web apps to
  77. * use revocable sessions. If you are migrating an app that uses the Parse
  78. * SDK in the browser only, please use Parse.User.enableRevocableSession()
  79. * instead, so that sessions can be automatically upgraded.
  80. *
  81. * @static
  82. * @returns {boolean}
  83. */
  84. static isCurrentSessionRevocable() {
  85. const currentUser = _ParseUser.default.current();
  86. if (currentUser) {
  87. return (0, _isRevocableSession.default)(currentUser.getSessionToken() || '');
  88. }
  89. return false;
  90. }
  91. }
  92. _ParseObject.default.registerSubclass('_Session', ParseSession);
  93. const DefaultController = {
  94. getSession(options) {
  95. const RESTController = _CoreManager.default.getRESTController();
  96. const session = new ParseSession();
  97. return RESTController.request('GET', 'sessions/me', {}, options).then(sessionData => {
  98. session._finishFetch(sessionData);
  99. session._setExisted(true);
  100. return session;
  101. });
  102. }
  103. };
  104. _CoreManager.default.setSessionController(DefaultController);
  105. var _default = exports.default = ParseSession;