parse-server 9.8.0-alpha.7 → 9.8.0-alpha.8

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.
@@ -47,7 +47,7 @@ class SessionsRouter extends _ClassesRouter.default {
47
47
  response: response.results[0]
48
48
  };
49
49
  }
50
- handleUpdateToRevocableSession(req) {
50
+ async handleUpdateToRevocableSession(req) {
51
51
  const config = req.config;
52
52
  const user = req.auth.user;
53
53
  // Issue #2720
@@ -65,20 +65,35 @@ class SessionsRouter extends _ClassesRouter.default {
65
65
  },
66
66
  installationId: req.auth.installationId
67
67
  });
68
- return createSession().then(() => {
69
- // delete the session token, use the db to skip beforeSave
70
- return config.database.update('_User', {
68
+ await createSession();
69
+ // delete the session token, use the db to skip beforeSave
70
+ await config.database.update('_User', {
71
+ objectId: user.id
72
+ }, {
73
+ sessionToken: {
74
+ __op: 'Delete'
75
+ }
76
+ });
77
+ // Re-fetch the session with the caller's auth context so that
78
+ // protectedFields filtering applies correctly
79
+ const userAuth = new _Auth.default.Auth({
80
+ config,
81
+ isMaster: false,
82
+ user: _node.default.Object.fromJSON({
83
+ className: '_User',
71
84
  objectId: user.id
72
- }, {
73
- sessionToken: {
74
- __op: 'Delete'
75
- }
76
- });
77
- }).then(() => {
78
- return Promise.resolve({
79
- response: sessionData
80
- });
85
+ }),
86
+ installationId: req.auth.installationId
81
87
  });
88
+ const response = await _rest.default.find(config, userAuth, '_Session', {
89
+ sessionToken: sessionData.sessionToken
90
+ }, {}, req.info.clientSDK, req.info.context);
91
+ if (!response.results || response.results.length === 0) {
92
+ throw new _node.default.Error(_node.default.Error.INTERNAL_SERVER_ERROR, 'Failed to load upgraded session.');
93
+ }
94
+ return {
95
+ response: response.results[0]
96
+ };
82
97
  }
83
98
  mountRoutes() {
84
99
  this.route('GET', '/sessions/me', req => {
@@ -106,4 +121,4 @@ class SessionsRouter extends _ClassesRouter.default {
106
121
  }
107
122
  exports.SessionsRouter = SessionsRouter;
108
123
  var _default = exports.default = SessionsRouter;
109
- //# 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","sessionResponse","rest","find","config","Auth","master","clientSDK","context","results","length","user","sessionObjectId","objectId","userId","userAuth","isMaster","Object","fromJSON","installationId","response","get","handleUpdateToRevocableSession","auth","OBJECT_NOT_FOUND","sessionData","createSession","RestWrite","id","createdWith","action","then","database","update","__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  async handleMe(req) {\n    if (!req.info || !req.info.sessionToken) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token required.');\n    }\n    const sessionToken = req.info.sessionToken;\n    // Query with master key to validate the session token and get the session objectId\n    const sessionResponse = await rest.find(\n      req.config,\n      Auth.master(req.config),\n      '_Session',\n      { sessionToken },\n      {},\n      req.info.clientSDK,\n      req.info.context\n    );\n    if (\n      !sessionResponse.results ||\n      sessionResponse.results.length == 0 ||\n      !sessionResponse.results[0].user\n    ) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token not found.');\n    }\n    const sessionObjectId = sessionResponse.results[0].objectId;\n    const userId = sessionResponse.results[0].user.objectId;\n    // Re-fetch the session with the caller's auth context so that\n    // protectedFields and CLP apply correctly\n    const userAuth = new Auth.Auth({\n      config: req.config,\n      isMaster: false,\n      user: Parse.Object.fromJSON({ className: '_User', objectId: userId }),\n      installationId: req.info.installationId,\n    });\n    const response = await rest.get(\n      req.config,\n      userAuth,\n      '_Session',\n      sessionObjectId,\n      {},\n      req.info.clientSDK,\n      req.info.context\n    );\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  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":[]}
124
+ //# 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","sessionResponse","rest","find","config","Auth","master","clientSDK","context","results","length","user","sessionObjectId","objectId","userId","userAuth","isMaster","Object","fromJSON","installationId","response","get","handleUpdateToRevocableSession","auth","OBJECT_NOT_FOUND","sessionData","createSession","RestWrite","id","createdWith","action","database","update","__op","INTERNAL_SERVER_ERROR","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  async handleMe(req) {\n    if (!req.info || !req.info.sessionToken) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token required.');\n    }\n    const sessionToken = req.info.sessionToken;\n    // Query with master key to validate the session token and get the session objectId\n    const sessionResponse = await rest.find(\n      req.config,\n      Auth.master(req.config),\n      '_Session',\n      { sessionToken },\n      {},\n      req.info.clientSDK,\n      req.info.context\n    );\n    if (\n      !sessionResponse.results ||\n      sessionResponse.results.length == 0 ||\n      !sessionResponse.results[0].user\n    ) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token not found.');\n    }\n    const sessionObjectId = sessionResponse.results[0].objectId;\n    const userId = sessionResponse.results[0].user.objectId;\n    // Re-fetch the session with the caller's auth context so that\n    // protectedFields and CLP apply correctly\n    const userAuth = new Auth.Auth({\n      config: req.config,\n      isMaster: false,\n      user: Parse.Object.fromJSON({ className: '_User', objectId: userId }),\n      installationId: req.info.installationId,\n    });\n    const response = await rest.get(\n      req.config,\n      userAuth,\n      '_Session',\n      sessionObjectId,\n      {},\n      req.info.clientSDK,\n      req.info.context\n    );\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  async 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    await createSession();\n    // delete the session token, use the db to skip beforeSave\n    await config.database.update(\n      '_User',\n      { objectId: user.id },\n      { sessionToken: { __op: 'Delete' } }\n    );\n    // Re-fetch the session with the caller's auth context so that\n    // protectedFields filtering applies correctly\n    const userAuth = new Auth.Auth({\n      config,\n      isMaster: false,\n      user: Parse.Object.fromJSON({ className: '_User', objectId: user.id }),\n      installationId: req.auth.installationId,\n    });\n    const response = await rest.find(\n      config,\n      userAuth,\n      '_Session',\n      { sessionToken: sessionData.sessionToken },\n      {},\n      req.info.clientSDK,\n      req.info.context\n    );\n    if (!response.results || response.results.length === 0) {\n      throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Failed to load upgraded session.');\n    }\n    return { response: response.results[0] };\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":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-server",
3
- "version": "9.8.0-alpha.7",
3
+ "version": "9.8.0-alpha.8",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {