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.
@@ -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
- return _rest.default.find(req.config, _Auth.default.master(req.config), '_Session', {
23
- sessionToken: req.info.sessionToken
24
- }, undefined, req.info.clientSDK, req.info.context).then(response => {
25
- if (!response.results || response.results.length == 0) {
26
- throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Session token not found.');
27
- }
28
- return {
29
- response: response.results[0]
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":";;;;;;AAAA,IAAAA,cAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,KAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,KAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,KAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,UAAA,GAAAL,sBAAA,CAAAC,OAAA;AAAqC,SAAAD,uBAAAM,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAE9B,MAAMG,cAAc,SAASC,sBAAa,CAAC;EAChDC,SAASA,CAAA,EAAG;IACV,OAAO,UAAU;EACnB;EAEA,MAAMC,QAAQA,CAACC,GAAG,EAAE;IAClB,IAAI,CAACA,GAAG,CAACC,IAAI,IAAI,CAACD,GAAG,CAACC,IAAI,CAACC,YAAY,EAAE;MACvC,MAAM,IAAIC,aAAK,CAACC,KAAK,CAACD,aAAK,CAACC,KAAK,CAACC,qBAAqB,EAAE,yBAAyB,CAAC;IACrF;IACA,MAAMH,YAAY,GAAGF,GAAG,CAACC,IAAI,CAACC,YAAY;IAC1C;IACA,MAAMI,eAAe,GAAG,MAAMC,aAAI,CAACC,IAAI,CACrCR,GAAG,CAACS,MAAM,EACVC,aAAI,CAACC,MAAM,CAACX,GAAG,CAACS,MAAM,CAAC,EACvB,UAAU,EACV;MAAEP;IAAa,CAAC,EAChB,CAAC,CAAC,EACFF,GAAG,CAACC,IAAI,CAACW,SAAS,EAClBZ,GAAG,CAACC,IAAI,CAACY,OACX,CAAC;IACD,IACE,CAACP,eAAe,CAACQ,OAAO,IACxBR,eAAe,CAACQ,OAAO,CAACC,MAAM,IAAI,CAAC,IACnC,CAACT,eAAe,CAACQ,OAAO,CAAC,CAAC,CAAC,CAACE,IAAI,EAChC;MACA,MAAM,IAAIb,aAAK,CAACC,KAAK,CAACD,aAAK,CAACC,KAAK,CAACC,qBAAqB,EAAE,0BAA0B,CAAC;IACtF;IACA,MAAMY,eAAe,GAAGX,eAAe,CAACQ,OAAO,CAAC,CAAC,CAAC,CAACI,QAAQ;IAC3D,MAAMC,MAAM,GAAGb,eAAe,CAACQ,OAAO,CAAC,CAAC,CAAC,CAACE,IAAI,CAACE,QAAQ;IACvD;IACA;IACA,MAAME,QAAQ,GAAG,IAAIV,aAAI,CAACA,IAAI,CAAC;MAC7BD,MAAM,EAAET,GAAG,CAACS,MAAM;MAClBY,QAAQ,EAAE,KAAK;MACfL,IAAI,EAAEb,aAAK,CAACmB,MAAM,CAACC,QAAQ,CAAC;QAAEzB,SAAS,EAAE,OAAO;QAAEoB,QAAQ,EAAEC;MAAO,CAAC,CAAC;MACrEK,cAAc,EAAExB,GAAG,CAACC,IAAI,CAACuB;IAC3B,CAAC,CAAC;IACF,MAAMC,QAAQ,GAAG,MAAMlB,aAAI,CAACmB,GAAG,CAC7B1B,GAAG,CAACS,MAAM,EACVW,QAAQ,EACR,UAAU,EACVH,eAAe,EACf,CAAC,CAAC,EACFjB,GAAG,CAACC,IAAI,CAACW,SAAS,EAClBZ,GAAG,CAACC,IAAI,CAACY,OACX,CAAC;IACD,IAAI,CAACY,QAAQ,CAACX,OAAO,IAAIW,QAAQ,CAACX,OAAO,CAACC,MAAM,IAAI,CAAC,EAAE;MACrD,MAAM,IAAIZ,aAAK,CAACC,KAAK,CAACD,aAAK,CAACC,KAAK,CAACC,qBAAqB,EAAE,0BAA0B,CAAC;IACtF;IACA,OAAO;MACLoB,QAAQ,EAAEA,QAAQ,CAACX,OAAO,CAAC,CAAC;IAC9B,CAAC;EACH;EAEAa,8BAA8BA,CAAC3B,GAAG,EAAE;IAClC,MAAMS,MAAM,GAAGT,GAAG,CAACS,MAAM;IACzB,MAAMO,IAAI,GAAGhB,GAAG,CAAC4B,IAAI,CAACZ,IAAI;IAC1B;IACA;IACA,IAAI,CAACA,IAAI,EAAE;MACT,MAAM,IAAIb,aAAK,CAACC,KAAK,CAACD,aAAK,CAACC,KAAK,CAACyB,gBAAgB,EAAE,iBAAiB,CAAC;IACxE;IACA,MAAM;MAAEC,WAAW;MAAEC;IAAc,CAAC,GAAGC,kBAAS,CAACD,aAAa,CAACtB,MAAM,EAAE;MACrEU,MAAM,EAAEH,IAAI,CAACiB,EAAE;MACfC,WAAW,EAAE;QACXC,MAAM,EAAE;MACV,CAAC;MACDX,cAAc,EAAExB,GAAG,CAAC4B,IAAI,CAACJ;IAC3B,CAAC,CAAC;IAEF,OAAOO,aAAa,CAAC,CAAC,CACnBK,IAAI,CAAC,MAAM;MACV;MACA,OAAO3B,MAAM,CAAC4B,QAAQ,CAACC,MAAM,CAC3B,OAAO,EACP;QACEpB,QAAQ,EAAEF,IAAI,CAACiB;MACjB,CAAC,EACD;QACE/B,YAAY,EAAE;UAAEqC,IAAI,EAAE;QAAS;MACjC,CACF,CAAC;IACH,CAAC,CAAC,CACDH,IAAI,CAAC,MAAM;MACV,OAAOI,OAAO,CAACC,OAAO,CAAC;QAAEhB,QAAQ,EAAEK;MAAY,CAAC,CAAC;IACnD,CAAC,CAAC;EACN;EAEAY,WAAWA,CAAA,EAAG;IACZ,IAAI,CAACC,KAAK,CAAC,KAAK,EAAE,cAAc,EAAE3C,GAAG,IAAI;MACvC,OAAO,IAAI,CAACD,QAAQ,CAACC,GAAG,CAAC;IAC3B,CAAC,CAAC;IACF,IAAI,CAAC2C,KAAK,CAAC,KAAK,EAAE,WAAW,EAAE3C,GAAG,IAAI;MACpC,OAAO,IAAI,CAAC4C,UAAU,CAAC5C,GAAG,CAAC;IAC7B,CAAC,CAAC;IACF,IAAI,CAAC2C,KAAK,CAAC,KAAK,EAAE,qBAAqB,EAAE3C,GAAG,IAAI;MAC9C,OAAO,IAAI,CAAC6C,SAAS,CAAC7C,GAAG,CAAC;IAC5B,CAAC,CAAC;IACF,IAAI,CAAC2C,KAAK,CAAC,MAAM,EAAE,WAAW,EAAE3C,GAAG,IAAI;MACrC,OAAO,IAAI,CAAC8C,YAAY,CAAC9C,GAAG,CAAC;IAC/B,CAAC,CAAC;IACF,IAAI,CAAC2C,KAAK,CAAC,KAAK,EAAE,qBAAqB,EAAE3C,GAAG,IAAI;MAC9C,OAAO,IAAI,CAAC+C,YAAY,CAAC/C,GAAG,CAAC;IAC/B,CAAC,CAAC;IACF,IAAI,CAAC2C,KAAK,CAAC,QAAQ,EAAE,qBAAqB,EAAE3C,GAAG,IAAI;MACjD,OAAO,IAAI,CAACgD,YAAY,CAAChD,GAAG,CAAC;IAC/B,CAAC,CAAC;IACF,IAAI,CAAC2C,KAAK,CAAC,MAAM,EAAE,4BAA4B,EAAE3C,GAAG,IAAI;MACtD,OAAO,IAAI,CAAC2B,8BAA8B,CAAC3B,GAAG,CAAC;IACjD,CAAC,CAAC;EACJ;AACF;AAACiD,OAAA,CAAArD,cAAA,GAAAA,cAAA;AAAA,IAAAsD,QAAA,GAAAD,OAAA,CAAAtD,OAAA,GAEcC,cAAc","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-server",
3
- "version": "9.8.0-alpha.6",
3
+ "version": "9.8.0-alpha.7",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {