parse-server 9.8.0-alpha.6 → 9.8.0-alpha.7
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.
- package/lib/Routers/SessionsRouter.js +29 -12
- package/package.json +1 -1
|
@@ -14,21 +14,38 @@ class SessionsRouter extends _ClassesRouter.default {
|
|
|
14
14
|
className() {
|
|
15
15
|
return '_Session';
|
|
16
16
|
}
|
|
17
|
-
handleMe(req) {
|
|
18
|
-
// TODO: Verify correct behavior
|
|
17
|
+
async handleMe(req) {
|
|
19
18
|
if (!req.info || !req.info.sessionToken) {
|
|
20
19
|
throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Session token required.');
|
|
21
20
|
}
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
21
|
+
const sessionToken = req.info.sessionToken;
|
|
22
|
+
// Query with master key to validate the session token and get the session objectId
|
|
23
|
+
const sessionResponse = await _rest.default.find(req.config, _Auth.default.master(req.config), '_Session', {
|
|
24
|
+
sessionToken
|
|
25
|
+
}, {}, req.info.clientSDK, req.info.context);
|
|
26
|
+
if (!sessionResponse.results || sessionResponse.results.length == 0 || !sessionResponse.results[0].user) {
|
|
27
|
+
throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Session token not found.');
|
|
28
|
+
}
|
|
29
|
+
const sessionObjectId = sessionResponse.results[0].objectId;
|
|
30
|
+
const userId = sessionResponse.results[0].user.objectId;
|
|
31
|
+
// Re-fetch the session with the caller's auth context so that
|
|
32
|
+
// protectedFields and CLP apply correctly
|
|
33
|
+
const userAuth = new _Auth.default.Auth({
|
|
34
|
+
config: req.config,
|
|
35
|
+
isMaster: false,
|
|
36
|
+
user: _node.default.Object.fromJSON({
|
|
37
|
+
className: '_User',
|
|
38
|
+
objectId: userId
|
|
39
|
+
}),
|
|
40
|
+
installationId: req.info.installationId
|
|
31
41
|
});
|
|
42
|
+
const response = await _rest.default.get(req.config, userAuth, '_Session', sessionObjectId, {}, req.info.clientSDK, req.info.context);
|
|
43
|
+
if (!response.results || response.results.length == 0) {
|
|
44
|
+
throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Session token not found.');
|
|
45
|
+
}
|
|
46
|
+
return {
|
|
47
|
+
response: response.results[0]
|
|
48
|
+
};
|
|
32
49
|
}
|
|
33
50
|
handleUpdateToRevocableSession(req) {
|
|
34
51
|
const config = req.config;
|
|
@@ -89,4 +106,4 @@ class SessionsRouter extends _ClassesRouter.default {
|
|
|
89
106
|
}
|
|
90
107
|
exports.SessionsRouter = SessionsRouter;
|
|
91
108
|
var _default = exports.default = SessionsRouter;
|
|
92
|
-
//# 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":[]}
|
|
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":[]}
|