parse-server 6.3.0-alpha.7 → 6.3.0-alpha.9

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.
@@ -20,6 +20,14 @@ class RedisCacheAdapter {
20
20
  this.ttl = isValidTTL(ttl) ? ttl : DEFAULT_REDIS_TTL;
21
21
  this.client = (0, _redis.createClient)(redisCtx);
22
22
  this.queue = new _KeyPromiseQueue.KeyPromiseQueue();
23
+ this.client.on('error', err => {
24
+ _logger.default.error('RedisCacheAdapter client error', {
25
+ error: err
26
+ });
27
+ });
28
+ this.client.on('connect', () => {});
29
+ this.client.on('reconnecting', () => {});
30
+ this.client.on('ready', () => {});
23
31
  }
24
32
  async connect() {
25
33
  if (this.client.isOpen) {
@@ -99,4 +107,4 @@ class RedisCacheAdapter {
99
107
  exports.RedisCacheAdapter = RedisCacheAdapter;
100
108
  var _default = RedisCacheAdapter;
101
109
  exports.default = _default;
102
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJERUZBVUxUX1JFRElTX1RUTCIsIkZMVVNIX0RCX0tFWSIsImRlYnVnIiwiYXJncyIsIm1lc3NhZ2UiLCJhcmd1bWVudHMiLCJjb25jYXQiLCJzbGljZSIsImxlbmd0aCIsImxvZ2dlciIsImFwcGx5IiwiaXNWYWxpZFRUTCIsInR0bCIsIlJlZGlzQ2FjaGVBZGFwdGVyIiwiY29uc3RydWN0b3IiLCJyZWRpc0N0eCIsImNsaWVudCIsImNyZWF0ZUNsaWVudCIsInF1ZXVlIiwiS2V5UHJvbWlzZVF1ZXVlIiwiY29ubmVjdCIsImlzT3BlbiIsImhhbmRsZVNodXRkb3duIiwicXVpdCIsImVyciIsImVycm9yIiwiZ2V0Iiwia2V5IiwiZW5xdWV1ZSIsInJlcyIsIkpTT04iLCJwYXJzZSIsInB1dCIsInZhbHVlIiwic3RyaW5naWZ5IiwiSW5maW5pdHkiLCJzZXQiLCJQWCIsImRlbCIsImNsZWFyIiwic2VuZENvbW1hbmQiLCJnZXRBbGxLZXlzIiwia2V5cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BZGFwdGVycy9DYWNoZS9SZWRpc0NhY2hlQWRhcHRlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVDbGllbnQgfSBmcm9tICdyZWRpcyc7XG5pbXBvcnQgbG9nZ2VyIGZyb20gJy4uLy4uL2xvZ2dlcic7XG5pbXBvcnQgeyBLZXlQcm9taXNlUXVldWUgfSBmcm9tICcuLi8uLi9LZXlQcm9taXNlUXVldWUnO1xuXG5jb25zdCBERUZBVUxUX1JFRElTX1RUTCA9IDMwICogMTAwMDsgLy8gMzAgc2Vjb25kcyBpbiBtaWxsaXNlY29uZHNcbmNvbnN0IEZMVVNIX0RCX0tFWSA9ICdfX2ZsdXNoX2RiX18nO1xuXG5mdW5jdGlvbiBkZWJ1ZyguLi5hcmdzOiBhbnkpIHtcbiAgY29uc3QgbWVzc2FnZSA9IFsnUmVkaXNDYWNoZUFkYXB0ZXI6ICcgKyBhcmd1bWVudHNbMF1dLmNvbmNhdChhcmdzLnNsaWNlKDEsIGFyZ3MubGVuZ3RoKSk7XG4gIGxvZ2dlci5kZWJ1Zy5hcHBseShsb2dnZXIsIG1lc3NhZ2UpO1xufVxuXG5jb25zdCBpc1ZhbGlkVFRMID0gdHRsID0+IHR5cGVvZiB0dGwgPT09ICdudW1iZXInICYmIHR0bCA+IDA7XG5cbmV4cG9ydCBjbGFzcyBSZWRpc0NhY2hlQWRhcHRlciB7XG4gIGNvbnN0cnVjdG9yKHJlZGlzQ3R4LCB0dGwgPSBERUZBVUxUX1JFRElTX1RUTCkge1xuICAgIHRoaXMudHRsID0gaXNWYWxpZFRUTCh0dGwpID8gdHRsIDogREVGQVVMVF9SRURJU19UVEw7XG4gICAgdGhpcy5jbGllbnQgPSBjcmVhdGVDbGllbnQocmVkaXNDdHgpO1xuICAgIHRoaXMucXVldWUgPSBuZXcgS2V5UHJvbWlzZVF1ZXVlKCk7XG4gIH1cblxuICBhc3luYyBjb25uZWN0KCkge1xuICAgIGlmICh0aGlzLmNsaWVudC5pc09wZW4pIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuY2xpZW50LmNvbm5lY3QoKTtcbiAgfVxuXG4gIGFzeW5jIGhhbmRsZVNodXRkb3duKCkge1xuICAgIGlmICghdGhpcy5jbGllbnQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IHRoaXMuY2xpZW50LnF1aXQoKTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIGxvZ2dlci5lcnJvcignUmVkaXNDYWNoZUFkYXB0ZXIgZXJyb3Igb24gc2h1dGRvd24nLCB7IGVycm9yOiBlcnIgfSk7XG4gICAgfVxuICB9XG5cbiAgYXN5bmMgZ2V0KGtleSkge1xuICAgIGRlYnVnKCdnZXQnLCB7IGtleSB9KTtcbiAgICB0cnkge1xuICAgICAgYXdhaXQgdGhpcy5xdWV1ZS5lbnF1ZXVlKGtleSk7XG4gICAgICBjb25zdCByZXMgPSBhd2FpdCB0aGlzLmNsaWVudC5nZXQoa2V5KTtcbiAgICAgIGlmICghcmVzKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgICAgfVxuICAgICAgcmV0dXJuIEpTT04ucGFyc2UocmVzKTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIGxvZ2dlci5lcnJvcignUmVkaXNDYWNoZUFkYXB0ZXIgZXJyb3Igb24gZ2V0JywgeyBlcnJvcjogZXJyIH0pO1xuICAgIH1cbiAgfVxuXG4gIGFzeW5jIHB1dChrZXksIHZhbHVlLCB0dGwgPSB0aGlzLnR0bCkge1xuICAgIHZhbHVlID0gSlNPTi5zdHJpbmdpZnkodmFsdWUpO1xuICAgIGRlYnVnKCdwdXQnLCB7IGtleSwgdmFsdWUsIHR0bCB9KTtcbiAgICBhd2FpdCB0aGlzLnF1ZXVlLmVucXVldWUoa2V5KTtcbiAgICBpZiAodHRsID09PSAwKSB7XG4gICAgICAvLyB0dGwgb2YgemVybyBpcyBhIGxvZ2ljYWwgbm8tb3AsIGJ1dCByZWRpcyBjYW5ub3Qgc2V0IGV4cGlyZSB0aW1lIG9mIHplcm9cbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAodHRsID09PSBJbmZpbml0eSkge1xuICAgICAgcmV0dXJuIHRoaXMuY2xpZW50LnNldChrZXksIHZhbHVlKTtcbiAgICB9XG5cbiAgICBpZiAoIWlzVmFsaWRUVEwodHRsKSkge1xuICAgICAgdHRsID0gdGhpcy50dGw7XG4gICAgfVxuICAgIHJldHVybiB0aGlzLmNsaWVudC5zZXQoa2V5LCB2YWx1ZSwgeyBQWDogdHRsIH0pO1xuICB9XG5cbiAgYXN5bmMgZGVsKGtleSkge1xuICAgIGRlYnVnKCdkZWwnLCB7IGtleSB9KTtcbiAgICBhd2FpdCB0aGlzLnF1ZXVlLmVucXVldWUoa2V5KTtcbiAgICByZXR1cm4gdGhpcy5jbGllbnQuZGVsKGtleSk7XG4gIH1cblxuICBhc3luYyBjbGVhcigpIHtcbiAgICBkZWJ1ZygnY2xlYXInKTtcbiAgICBhd2FpdCB0aGlzLnF1ZXVlLmVucXVldWUoRkxVU0hfREJfS0VZKTtcbiAgICByZXR1cm4gdGhpcy5jbGllbnQuc2VuZENvbW1hbmQoWydGTFVTSERCJ10pO1xuICB9XG5cbiAgLy8gVXNlZCBmb3IgdGVzdGluZ1xuICBnZXRBbGxLZXlzKCkge1xuICAgIHJldHVybiB0aGlzLmNsaWVudC5rZXlzKCcqJyk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgUmVkaXNDYWNoZUFkYXB0ZXI7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUF3RDtBQUV4RCxNQUFNQSxpQkFBaUIsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUM7QUFDckMsTUFBTUMsWUFBWSxHQUFHLGNBQWM7QUFFbkMsU0FBU0MsS0FBSyxDQUFDLEdBQUdDLElBQVMsRUFBRTtFQUMzQixNQUFNQyxPQUFPLEdBQUcsQ0FBQyxxQkFBcUIsR0FBR0MsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUNDLE1BQU0sQ0FBQ0gsSUFBSSxDQUFDSSxLQUFLLENBQUMsQ0FBQyxFQUFFSixJQUFJLENBQUNLLE1BQU0sQ0FBQyxDQUFDO0VBQ3pGQyxlQUFNLENBQUNQLEtBQUssQ0FBQ1EsS0FBSyxDQUFDRCxlQUFNLEVBQUVMLE9BQU8sQ0FBQztBQUNyQztBQUVBLE1BQU1PLFVBQVUsR0FBR0MsR0FBRyxJQUFJLE9BQU9BLEdBQUcsS0FBSyxRQUFRLElBQUlBLEdBQUcsR0FBRyxDQUFDO0FBRXJELE1BQU1DLGlCQUFpQixDQUFDO0VBQzdCQyxXQUFXLENBQUNDLFFBQVEsRUFBRUgsR0FBRyxHQUFHWixpQkFBaUIsRUFBRTtJQUM3QyxJQUFJLENBQUNZLEdBQUcsR0FBR0QsVUFBVSxDQUFDQyxHQUFHLENBQUMsR0FBR0EsR0FBRyxHQUFHWixpQkFBaUI7SUFDcEQsSUFBSSxDQUFDZ0IsTUFBTSxHQUFHLElBQUFDLG1CQUFZLEVBQUNGLFFBQVEsQ0FBQztJQUNwQyxJQUFJLENBQUNHLEtBQUssR0FBRyxJQUFJQyxnQ0FBZSxFQUFFO0VBQ3BDO0VBRUEsTUFBTUMsT0FBTyxHQUFHO0lBQ2QsSUFBSSxJQUFJLENBQUNKLE1BQU0sQ0FBQ0ssTUFBTSxFQUFFO01BQ3RCO0lBQ0Y7SUFDQSxPQUFPLElBQUksQ0FBQ0wsTUFBTSxDQUFDSSxPQUFPLEVB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
110
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJERUZBVUxUX1JFRElTX1RUTCIsIkZMVVNIX0RCX0tFWSIsImRlYnVnIiwiYXJncyIsIm1lc3NhZ2UiLCJhcmd1bWVudHMiLCJjb25jYXQiLCJzbGljZSIsImxlbmd0aCIsImxvZ2dlciIsImFwcGx5IiwiaXNWYWxpZFRUTCIsInR0bCIsIlJlZGlzQ2FjaGVBZGFwdGVyIiwiY29uc3RydWN0b3IiLCJyZWRpc0N0eCIsImNsaWVudCIsImNyZWF0ZUNsaWVudCIsInF1ZXVlIiwiS2V5UHJvbWlzZVF1ZXVlIiwib24iLCJlcnIiLCJlcnJvciIsImNvbm5lY3QiLCJpc09wZW4iLCJoYW5kbGVTaHV0ZG93biIsInF1aXQiLCJnZXQiLCJrZXkiLCJlbnF1ZXVlIiwicmVzIiwiSlNPTiIsInBhcnNlIiwicHV0IiwidmFsdWUiLCJzdHJpbmdpZnkiLCJJbmZpbml0eSIsInNldCIsIlBYIiwiZGVsIiwiY2xlYXIiLCJzZW5kQ29tbWFuZCIsImdldEFsbEtleXMiLCJrZXlzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL0FkYXB0ZXJzL0NhY2hlL1JlZGlzQ2FjaGVBZGFwdGVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUNsaWVudCB9IGZyb20gJ3JlZGlzJztcbmltcG9ydCBsb2dnZXIgZnJvbSAnLi4vLi4vbG9nZ2VyJztcbmltcG9ydCB7IEtleVByb21pc2VRdWV1ZSB9IGZyb20gJy4uLy4uL0tleVByb21pc2VRdWV1ZSc7XG5cbmNvbnN0IERFRkFVTFRfUkVESVNfVFRMID0gMzAgKiAxMDAwOyAvLyAzMCBzZWNvbmRzIGluIG1pbGxpc2Vjb25kc1xuY29uc3QgRkxVU0hfREJfS0VZID0gJ19fZmx1c2hfZGJfXyc7XG5cbmZ1bmN0aW9uIGRlYnVnKC4uLmFyZ3M6IGFueSkge1xuICBjb25zdCBtZXNzYWdlID0gWydSZWRpc0NhY2hlQWRhcHRlcjogJyArIGFyZ3VtZW50c1swXV0uY29uY2F0KGFyZ3Muc2xpY2UoMSwgYXJncy5sZW5ndGgpKTtcbiAgbG9nZ2VyLmRlYnVnLmFwcGx5KGxvZ2dlciwgbWVzc2FnZSk7XG59XG5cbmNvbnN0IGlzVmFsaWRUVEwgPSB0dGwgPT4gdHlwZW9mIHR0bCA9PT0gJ251bWJlcicgJiYgdHRsID4gMDtcblxuZXhwb3J0IGNsYXNzIFJlZGlzQ2FjaGVBZGFwdGVyIHtcbiAgY29uc3RydWN0b3IocmVkaXNDdHgsIHR0bCA9IERFRkFVTFRfUkVESVNfVFRMKSB7XG4gICAgdGhpcy50dGwgPSBpc1ZhbGlkVFRMKHR0bCkgPyB0dGwgOiBERUZBVUxUX1JFRElTX1RUTDtcbiAgICB0aGlzLmNsaWVudCA9IGNyZWF0ZUNsaWVudChyZWRpc0N0eCk7XG4gICAgdGhpcy5xdWV1ZSA9IG5ldyBLZXlQcm9taXNlUXVldWUoKTtcbiAgICB0aGlzLmNsaWVudC5vbignZXJyb3InLCBlcnIgPT4geyBsb2dnZXIuZXJyb3IoJ1JlZGlzQ2FjaGVBZGFwdGVyIGNsaWVudCBlcnJvcicsIHsgZXJyb3I6IGVyciB9KSB9KTtcbiAgICB0aGlzLmNsaWVudC5vbignY29ubmVjdCcsICgpID0+IHt9KTtcbiAgICB0aGlzLmNsaWVudC5vbigncmVjb25uZWN0aW5nJywgKCkgPT4ge30pO1xuICAgIHRoaXMuY2xpZW50Lm9uKCdyZWFkeScsICgpID0+IHt9KTtcbiAgfVxuXG4gIGFzeW5jIGNvbm5lY3QoKSB7XG4gICAgaWYgKHRoaXMuY2xpZW50LmlzT3Blbikge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5jbGllbnQuY29ubmVjdCgpO1xuICB9XG5cbiAgYXN5bmMgaGFuZGxlU2h1dGRvd24oKSB7XG4gICAgaWYgKCF0aGlzLmNsaWVudCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICB0cnkge1xuICAgICAgYXdhaXQgdGhpcy5jbGllbnQucXVpdCgpO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgbG9nZ2VyLmVycm9yKCdSZWRpc0NhY2hlQWRhcHRlciBlcnJvciBvbiBzaHV0ZG93bicsIHsgZXJyb3I6IGVyciB9KTtcbiAgICB9XG4gIH1cblxuICBhc3luYyBnZXQoa2V5KSB7XG4gICAgZGVidWcoJ2dldCcsIHsga2V5IH0pO1xuICAgIHRyeSB7XG4gICAgICBhd2FpdCB0aGlzLnF1ZXVlLmVucXVldWUoa2V5KTtcbiAgICAgIGNvbnN0IHJlcyA9IGF3YWl0IHRoaXMuY2xpZW50LmdldChrZXkpO1xuICAgICAgaWYgKCFyZXMpIHtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICB9XG4gICAgICByZXR1cm4gSlNPTi5wYXJzZShyZXMpO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgbG9nZ2VyLmVycm9yKCdSZWRpc0NhY2hlQWRhcHRlciBlcnJvciBvbiBnZXQnLCB7IGVycm9yOiBlcnIgfSk7XG4gICAgfVxuICB9XG5cbiAgYXN5bmMgcHV0KGtleSwgdmFsdWUsIHR0bCA9IHRoaXMudHRsKSB7XG4gICAgdmFsdWUgPSBKU09OLnN0cmluZ2lmeSh2YWx1ZSk7XG4gICAgZGVidWcoJ3B1dCcsIHsga2V5LCB2YWx1ZSwgdHRsIH0pO1xuICAgIGF3YWl0IHRoaXMucXVldWUuZW5xdWV1ZShrZXkpO1xuICAgIGlmICh0dGwgPT09IDApIHtcbiAgICAgIC8vIHR0bCBvZiB6ZXJvIGlzIGEgbG9naWNhbCBuby1vcCwgYnV0IHJlZGlzIGNhbm5vdCBzZXQgZXhwaXJlIHRpbWUgb2YgemVyb1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGlmICh0dGwgPT09IEluZmluaXR5KSB7XG4gICAgICByZXR1cm4gdGhpcy5jbGllbnQuc2V0KGtleSwgdmFsdWUpO1xuICAgIH1cblxuICAgIGlmICghaXNWYWxpZFRUTCh0dGwpKSB7XG4gICAgICB0dGwgPSB0aGlzLnR0bDtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuY2xpZW50LnNldChrZXksIHZhbHVlLCB7IFBYOiB0dGwgfSk7XG4gIH1cblxuICBhc3luYyBkZWwoa2V5KSB7XG4gICAgZGVidWcoJ2RlbCcsIHsga2V5IH0pO1xuICAgIGF3YWl0IHRoaXMucXVldWUuZW5xdWV1ZShrZXkpO1xuICAgIHJldHVybiB0aGlzLmNsaWVudC5kZWwoa2V5KTtcbiAgfVxuXG4gIGFzeW5jIGNsZWFyKCkge1xuICAgIGRlYnVnKCdjbGVhcicpO1xuICAgIGF3YWl0IHRoaXMucXVldWUuZW5xdWV1ZShGTFVTSF9EQl9LRVkpO1xuICAgIHJldHVybiB0aGlzLmNsaWVudC5zZW5kQ29tbWFuZChbJ0ZMVVNIREInXSk7XG4gIH1cblxuICAvLyBVc2VkIGZvciB0ZXN0aW5nXG4gIGdldEFsbEtleXMoKSB7XG4gICAgcmV0dXJuIHRoaXMuY2xpZW50LmtleXMoJyonKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBSZWRpc0NhY2hlQWRhcHRlcjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBQXdEO0FBRXhELE1BQU1BLGlCQUFpQixHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztBQUNyQyxNQUFNQyxZQUFZLEdBQUcsY0FBYztBQUVuQyxTQUFTQyxLQUFLLENBQUMsR0FBR0MsSUFBUyxFQUFFO0VBQzNCLE1BQU1DLE9BQU8sR0FBRyxDQUFDLHFCQUFxQixHQUFHQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQ0MsTUFBTSxDQUFDSCxJQUFJLENBQUNJLEtBQUssQ0FBQyxDQUFDLEVBQUVKLElBQUksQ0FBQ0ssTUFBTSxDQUFDLENBQUM7RUFDekZDLGVBQU0sQ0FBQ1AsS0FBSyxDQUFDUSxLQUFLLENBQUNELGVBQU0sRUFBRUwsT0FBTyxDQUFDO0FBQ3JDO0FBRUEsTUFBTU8sVUFBVSxHQUFHQyxHQUFHLElBQUksT0FBT0EsR0FBRyxLQUFLLFFBQVEsSUFBSUEsR0FBRyxHQUFHLENBQUM7QUFFckQsTUFBTUMsaUJBQWlCLENBQUM7RUFDN0JDLFdBQVcsQ0FBQ0MsUUFBUSxFQUFFSCxHQUFHLEdBQUdaLGlCQUFpQixFQUFFO0lBQzdDLElBQUksQ0FBQ1ksR0FBRyxHQUFHRCxVQUFVLENBQUNDLEdBQUcsQ0FBQyxHQUFH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
package/lib/Auth.js CHANGED
@@ -101,13 +101,22 @@ const renewSessionIfNeeded = async ({
101
101
  try {
102
102
  var _session;
103
103
  if (!session) {
104
+ const query = await (0, _RestQuery.default)({
105
+ method: _RestQuery.default.Method.get,
106
+ config,
107
+ auth: master(config),
108
+ runBeforeFind: false,
109
+ className: '_Session',
110
+ restWhere: {
111
+ sessionToken
112
+ },
113
+ restOptions: {
114
+ limit: 1
115
+ }
116
+ });
104
117
  const {
105
118
  results
106
- } = await new _RestQuery.default(config, master(config), '_Session', {
107
- sessionToken
108
- }, {
109
- limit: 1
110
- }).execute();
119
+ } = await query.execute();
111
120
  session = results[0];
112
121
  }
113
122
  const lastUpdated = new Date((_session = session) === null || _session === void 0 ? void 0 : _session.updatedAt);
@@ -162,9 +171,17 @@ const getAuthForSessionToken = async function ({
162
171
  include: 'user'
163
172
  };
164
173
  const RestQuery = require('./RestQuery');
165
- const query = new RestQuery(config, master(config), '_Session', {
166
- sessionToken
167
- }, restOptions);
174
+ const query = await RestQuery({
175
+ method: RestQuery.Method.get,
176
+ config,
177
+ runBeforeFind: false,
178
+ auth: master(config),
179
+ className: '_Session',
180
+ restWhere: {
181
+ sessionToken
182
+ },
183
+ restOptions
184
+ });
168
185
  results = (await query.execute()).results;
169
186
  } else {
170
187
  results = (await new Parse.Query(Parse.Session).limit(1).include('user').equalTo('sessionToken', sessionToken).find({
@@ -201,7 +218,7 @@ const getAuthForSessionToken = async function ({
201
218
  user: userObject
202
219
  });
203
220
  };
204
- var getAuthForLegacySessionToken = function ({
221
+ var getAuthForLegacySessionToken = async function ({
205
222
  config,
206
223
  sessionToken,
207
224
  installationId
@@ -210,9 +227,17 @@ var getAuthForLegacySessionToken = function ({
210
227
  limit: 1
211
228
  };
212
229
  const RestQuery = require('./RestQuery');
213
- var query = new RestQuery(config, master(config), '_User', {
214
- sessionToken
215
- }, restOptions);
230
+ var query = await RestQuery({
231
+ method: RestQuery.Method.get,
232
+ config,
233
+ runBeforeFind: false,
234
+ auth: master(config),
235
+ className: '_User',
236
+ restWhere: {
237
+ _session_token: sessionToken
238
+ },
239
+ restOptions
240
+ });
216
241
  return query.execute().then(response => {
217
242
  var results = response.results;
218
243
  if (results.length !== 1) {
@@ -256,7 +281,15 @@ Auth.prototype.getRolesForUser = async function () {
256
281
  }
257
282
  };
258
283
  const RestQuery = require('./RestQuery');
259
- await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result => results.push(result));
284
+ const query = await RestQuery({
285
+ method: RestQuery.Method.find,
286
+ runBeforeFind: false,
287
+ config: this.config,
288
+ auth: master(this.config),
289
+ className: '_Role',
290
+ restWhere
291
+ });
292
+ await query.each(result => results.push(result));
260
293
  } else {
261
294
  await new Parse.Query(Parse.Role).equalTo('users', this.user).each(result => results.push(result.toJSON()), {
262
295
  useMasterKey: true
@@ -344,7 +377,15 @@ Auth.prototype.getRolesByIds = async function (ins) {
344
377
  }
345
378
  };
346
379
  const RestQuery = require('./RestQuery');
347
- await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result => results.push(result));
380
+ const query = await RestQuery({
381
+ method: RestQuery.Method.find,
382
+ config: this.config,
383
+ runBeforeFind: false,
384
+ auth: master(this.config),
385
+ className: '_Role',
386
+ restWhere
387
+ });
388
+ await query.each(result => results.push(result));
348
389
  }
349
390
  return results;
350
391
  };
@@ -560,4 +601,4 @@ module.exports = {
560
601
  checkIfUserHasProvidedConfiguredProvidersForLogin,
561
602
  handleAuthDataValidation
562
603
  };
563
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","Auth","config","cacheController","undefined","isMaster","isMaintenance","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","maintenance","readOnly","nobody","throttle","renewSessionIfNeeded","session","sessionToken","extendSessionOnUse","clearTimeout","setTimeout","results","RestQuery","limit","execute","lastUpdated","Date","updatedAt","yesterday","setDate","getDate","expiresAt","generateSessionExpiresAt","RestWrite","objectId","_encode","e","code","Error","OBJECT_NOT_FOUND","logger","error","getAuthForSessionToken","userJSON","get","cachedUser","Object","fromJSON","Promise","resolve","restOptions","include","query","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","INVALID_SESSION_TOKEN","now","iso","password","put","userObject","getAuthForLegacySessionToken","then","response","className","getUserRoles","_loadRoles","getRolesForUser","restWhere","users","__type","id","each","result","push","Role","cachedRoles","role","cacheRoles","rolesMap","reduce","m","r","names","name","ids","roleNames","_getAllRolesNamesForRoleIds","Array","clearRoleCache","del","getRolesByIds","ins","containedIn","roles","$in","roleIDs","queriedRoles","filter","roleID","wasQueried","Set","resultMap","memo","concat","findUsersWithAuthData","authData","providers","keys","provider","queryKey","q","database","$or","hasMutatedAuthData","userAuthData","mutatedAuthData","forEach","providerData","userProviderAuthData","isDeepStrictEqual","checkIfUserHasProvidedConfiguredProvidersForLogin","req","savedUserProviders","adapter","authDataManager","getValidatorForProvider","hasProvidedASoloProvider","some","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","requestObject","ip","auth","call","OTHER_CAUSE","join","handleAuthDataValidation","foundUser","User","getUserId","fetch","updatedObject","buildParseObjects","getRequestObject","acc","authDataResponse","authKeys","sort","method","validator","authProvider","enabled","Deprecator","logRuntimeDeprecation","usage","solution","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","resolveError","SCRIPT_FAILED","message","userString","data","JSON","stringify","authenticationStep","module","exports"],"sources":["../src/Auth.js"],"sourcesContent":["const Parse = require('parse/node');\nimport { isDeepStrictEqual } from 'util';\nimport { getRequestObject, resolveError } from './triggers';\nimport Deprecator from './Deprecator/Deprecator';\nimport { logger } from './logger';\nimport RestQuery from './RestQuery';\nimport RestWrite from './RestWrite';\n\n// An Auth object tells you who is requesting something and whether\n// the master key was used.\n// userObject is a Parse.User and can be null if there's no user.\nfunction Auth({\n  config,\n  cacheController = undefined,\n  isMaster = false,\n  isMaintenance = false,\n  isReadOnly = false,\n  user,\n  installationId,\n}) {\n  this.config = config;\n  this.cacheController = cacheController || (config && config.cacheController);\n  this.installationId = installationId;\n  this.isMaster = isMaster;\n  this.isMaintenance = isMaintenance;\n  this.user = user;\n  this.isReadOnly = isReadOnly;\n\n  // Assuming a users roles won't change during a single request, we'll\n  // only load them once.\n  this.userRoles = [];\n  this.fetchedRoles = false;\n  this.rolePromise = null;\n}\n\n// Whether this auth could possibly modify the given user id.\n// It still could be forbidden via ACLs even if this returns true.\nAuth.prototype.isUnauthenticated = function () {\n  if (this.isMaster) {\n    return false;\n  }\n  if (this.isMaintenance) {\n    return false;\n  }\n  if (this.user) {\n    return false;\n  }\n  return true;\n};\n\n// A helper to get a master-level Auth object\nfunction master(config) {\n  return new Auth({ config, isMaster: true });\n}\n\n// A helper to get a maintenance-level Auth object\nfunction maintenance(config) {\n  return new Auth({ config, isMaintenance: true });\n}\n\n// A helper to get a master-level Auth object\nfunction readOnly(config) {\n  return new Auth({ config, isMaster: true, isReadOnly: true });\n}\n\n// A helper to get a nobody-level Auth object\nfunction nobody(config) {\n  return new Auth({ config, isMaster: false });\n}\n\nconst throttle = {};\nconst renewSessionIfNeeded = async ({ config, session, sessionToken }) => {\n  if (!config?.extendSessionOnUse) {\n    return;\n  }\n  clearTimeout(throttle[sessionToken]);\n  throttle[sessionToken] = setTimeout(async () => {\n    try {\n      if (!session) {\n        const { results } = await new RestQuery(\n          config,\n          master(config),\n          '_Session',\n          { sessionToken },\n          { limit: 1 }\n        ).execute();\n        session = results[0];\n      }\n      const lastUpdated = new Date(session?.updatedAt);\n      const yesterday = new Date();\n      yesterday.setDate(yesterday.getDate() - 1);\n      if (lastUpdated > yesterday || !session) {\n        return;\n      }\n      const expiresAt = config.generateSessionExpiresAt();\n      await new RestWrite(\n        config,\n        master(config),\n        '_Session',\n        { objectId: session.objectId },\n        { expiresAt: Parse._encode(expiresAt) }\n      ).execute();\n    } catch (e) {\n      if (e?.code !== Parse.Error.OBJECT_NOT_FOUND) {\n        logger.error('Could not update session expiry: ', e);\n      }\n    }\n  }, 500);\n};\n\n// Returns a promise that resolves to an Auth object\nconst getAuthForSessionToken = async function ({\n  config,\n  cacheController,\n  sessionToken,\n  installationId,\n}) {\n  cacheController = cacheController || (config && config.cacheController);\n  if (cacheController) {\n    const userJSON = await cacheController.user.get(sessionToken);\n    if (userJSON) {\n      const cachedUser = Parse.Object.fromJSON(userJSON);\n      renewSessionIfNeeded({ config, sessionToken });\n      return Promise.resolve(\n        new Auth({\n          config,\n          cacheController,\n          isMaster: false,\n          installationId,\n          user: cachedUser,\n        })\n      );\n    }\n  }\n\n  let results;\n  if (config) {\n    const restOptions = {\n      limit: 1,\n      include: 'user',\n    };\n    const RestQuery = require('./RestQuery');\n    const query = new RestQuery(config, master(config), '_Session', { sessionToken }, restOptions);\n    results = (await query.execute()).results;\n  } else {\n    results = (\n      await new Parse.Query(Parse.Session)\n        .limit(1)\n        .include('user')\n        .equalTo('sessionToken', sessionToken)\n        .find({ useMasterKey: true })\n    ).map(obj => obj.toJSON());\n  }\n\n  if (results.length !== 1 || !results[0]['user']) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const session = results[0];\n  const now = new Date(),\n    expiresAt = session.expiresAt ? new Date(session.expiresAt.iso) : undefined;\n  if (expiresAt < now) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n  }\n  const obj = session.user;\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, obj);\n  }\n  renewSessionIfNeeded({ config, session, sessionToken });\n  const userObject = Parse.Object.fromJSON(obj);\n  return new Auth({\n    config,\n    cacheController,\n    isMaster: false,\n    installationId,\n    user: userObject,\n  });\n};\n\nvar getAuthForLegacySessionToken = function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  const RestQuery = require('./RestQuery');\n  var query = new RestQuery(config, master(config), '_User', { sessionToken }, restOptions);\n  return query.execute().then(response => {\n    var results = response.results;\n    if (results.length !== 1) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');\n    }\n    const obj = results[0];\n    obj.className = '_User';\n    const userObject = Parse.Object.fromJSON(obj);\n    return new Auth({\n      config,\n      isMaster: false,\n      installationId,\n      user: userObject,\n    });\n  });\n};\n\n// Returns a promise that resolves to an array of role names\nAuth.prototype.getUserRoles = function () {\n  if (this.isMaster || this.isMaintenance || !this.user) {\n    return Promise.resolve([]);\n  }\n  if (this.fetchedRoles) {\n    return Promise.resolve(this.userRoles);\n  }\n  if (this.rolePromise) {\n    return this.rolePromise;\n  }\n  this.rolePromise = this._loadRoles();\n  return this.rolePromise;\n};\n\nAuth.prototype.getRolesForUser = async function () {\n  //Stack all Parse.Role\n  const results = [];\n  if (this.config) {\n    const restWhere = {\n      users: {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: this.user.id,\n      },\n    };\n    const RestQuery = require('./RestQuery');\n    await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result =>\n      results.push(result)\n    );\n  } else {\n    await new Parse.Query(Parse.Role)\n      .equalTo('users', this.user)\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  }\n  return results;\n};\n\n// Iterates through the role tree and compiles a user's roles\nAuth.prototype._loadRoles = async function () {\n  if (this.cacheController) {\n    const cachedRoles = await this.cacheController.role.get(this.user.id);\n    if (cachedRoles != null) {\n      this.fetchedRoles = true;\n      this.userRoles = cachedRoles;\n      return cachedRoles;\n    }\n  }\n\n  // First get the role ids this user is directly a member of\n  const results = await this.getRolesForUser();\n  if (!results.length) {\n    this.userRoles = [];\n    this.fetchedRoles = true;\n    this.rolePromise = null;\n\n    this.cacheRoles();\n    return this.userRoles;\n  }\n\n  const rolesMap = results.reduce(\n    (m, r) => {\n      m.names.push(r.name);\n      m.ids.push(r.objectId);\n      return m;\n    },\n    { ids: [], names: [] }\n  );\n\n  // run the recursive finding\n  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);\n  this.userRoles = roleNames.map(r => {\n    return 'role:' + r;\n  });\n  this.fetchedRoles = true;\n  this.rolePromise = null;\n  this.cacheRoles();\n  return this.userRoles;\n};\n\nAuth.prototype.cacheRoles = function () {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.put(this.user.id, Array(...this.userRoles));\n  return true;\n};\n\nAuth.prototype.clearRoleCache = function (sessionToken) {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.del(this.user.id);\n  this.cacheController.user.del(sessionToken);\n  return true;\n};\n\nAuth.prototype.getRolesByIds = async function (ins) {\n  const results = [];\n  // Build an OR query across all parentRoles\n  if (!this.config) {\n    await new Parse.Query(Parse.Role)\n      .containedIn(\n        'roles',\n        ins.map(id => {\n          const role = new Parse.Object(Parse.Role);\n          role.id = id;\n          return role;\n        })\n      )\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  } else {\n    const roles = ins.map(id => {\n      return {\n        __type: 'Pointer',\n        className: '_Role',\n        objectId: id,\n      };\n    });\n    const restWhere = { roles: { $in: roles } };\n    const RestQuery = require('./RestQuery');\n    await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result =>\n      results.push(result)\n    );\n  }\n  return results;\n};\n\n// Given a list of roleIds, find all the parent roles, returns a promise with all names\nAuth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {\n  const ins = roleIDs.filter(roleID => {\n    const wasQueried = queriedRoles[roleID] !== true;\n    queriedRoles[roleID] = true;\n    return wasQueried;\n  });\n\n  // all roles are accounted for, return the names\n  if (ins.length == 0) {\n    return Promise.resolve([...new Set(names)]);\n  }\n\n  return this.getRolesByIds(ins)\n    .then(results => {\n      // Nothing found\n      if (!results.length) {\n        return Promise.resolve(names);\n      }\n      // Map the results with all Ids and names\n      const resultMap = results.reduce(\n        (memo, role) => {\n          memo.names.push(role.name);\n          memo.ids.push(role.objectId);\n          return memo;\n        },\n        { ids: [], names: [] }\n      );\n      // store the new found names\n      names = names.concat(resultMap.names);\n      // find the next ones, circular roles will be cut\n      return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);\n    })\n    .then(names => {\n      return Promise.resolve([...new Set(names)]);\n    });\n};\n\nconst findUsersWithAuthData = (config, authData) => {\n  const providers = Object.keys(authData);\n  const query = providers\n    .reduce((memo, provider) => {\n      if (!authData[provider] || (authData && !authData[provider].id)) {\n        return memo;\n      }\n      const queryKey = `authData.${provider}.id`;\n      const query = {};\n      query[queryKey] = authData[provider].id;\n      memo.push(query);\n      return memo;\n    }, [])\n    .filter(q => {\n      return typeof q !== 'undefined';\n    });\n\n  return query.length > 0\n    ? config.database.find('_User', { $or: query }, { limit: 2 })\n    : Promise.resolve([]);\n};\n\nconst hasMutatedAuthData = (authData, userAuthData) => {\n  if (!userAuthData) return { hasMutatedAuthData: true, mutatedAuthData: authData };\n  const mutatedAuthData = {};\n  Object.keys(authData).forEach(provider => {\n    // Anonymous provider is not handled this way\n    if (provider === 'anonymous') return;\n    const providerData = authData[provider];\n    const userProviderAuthData = userAuthData[provider];\n    if (!isDeepStrictEqual(providerData, userProviderAuthData)) {\n      mutatedAuthData[provider] = providerData;\n    }\n  });\n  const hasMutatedAuthData = Object.keys(mutatedAuthData).length !== 0;\n  return { hasMutatedAuthData, mutatedAuthData };\n};\n\nconst checkIfUserHasProvidedConfiguredProvidersForLogin = (\n  req = {},\n  authData = {},\n  userAuthData = {},\n  config\n) => {\n  const savedUserProviders = Object.keys(userAuthData).map(provider => ({\n    name: provider,\n    adapter: config.authDataManager.getValidatorForProvider(provider).adapter,\n  }));\n\n  const hasProvidedASoloProvider = savedUserProviders.some(\n    provider =>\n      provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]\n  );\n\n  // Solo providers can be considered as safe, so we do not have to check if the user needs\n  // to provide an additional provider to login. An auth adapter with \"solo\" (like webauthn) means\n  // no \"additional\" auth needs to be provided to login (like OTP, MFA)\n  if (hasProvidedASoloProvider) {\n    return;\n  }\n\n  const additionProvidersNotFound = [];\n  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {\n    let policy = provider.adapter.policy;\n    if (typeof policy === 'function') {\n      const requestObject = {\n        ip: req.config.ip,\n        user: req.auth.user,\n        master: req.auth.isMaster,\n      };\n      policy = policy.call(provider.adapter, requestObject, userAuthData[provider.name]);\n    }\n    if (policy === 'additional') {\n      if (authData[provider.name]) {\n        return true;\n      } else {\n        // Push missing provider for error message\n        additionProvidersNotFound.push(provider.name);\n      }\n    }\n  });\n  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {\n    return;\n  }\n\n  throw new Parse.Error(\n    Parse.Error.OTHER_CAUSE,\n    `Missing additional authData ${additionProvidersNotFound.join(',')}`\n  );\n};\n\n// Validate each authData step-by-step and return the provider responses\nconst handleAuthDataValidation = async (authData, req, foundUser) => {\n  let user;\n  if (foundUser) {\n    user = Parse.User.fromJSON({ className: '_User', ...foundUser });\n    // Find user by session and current objectId; only pass user if it's the current user or master key is provided\n  } else if (\n    (req.auth &&\n      req.auth.user &&\n      typeof req.getUserId === 'function' &&\n      req.getUserId() === req.auth.user.id) ||\n    (req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId())\n  ) {\n    user = new Parse.User();\n    user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;\n    await user.fetch({ useMasterKey: true });\n  }\n\n  const { updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(undefined, req.auth, updatedObject, user, req.config);\n  // Perform validation as step-by-step pipeline for better error consistency\n  // and also to avoid to trigger a provider (like OTP SMS) if another one fails\n  const acc = { authData: {}, authDataResponse: {} };\n  const authKeys = Object.keys(authData).sort();\n  for (const provider of authKeys) {\n    let method = '';\n    try {\n      if (authData[provider] === null) {\n        acc.authData[provider] = null;\n        continue;\n      }\n      const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n      const authProvider = (req.config.auth || {})[provider] || {};\n      if (authProvider.enabled == null) {\n        Deprecator.logRuntimeDeprecation({\n          usage: `Using the authentication adapter \"${provider}\" without explicitly enabling it`,\n          solution: `Enable the authentication adapter by setting the Parse Server option \"auth.${provider}.enabled: true\".`,\n        });\n      }\n      if (!validator || authProvider.enabled === false) {\n        throw new Parse.Error(\n          Parse.Error.UNSUPPORTED_SERVICE,\n          'This authentication method is unsupported.'\n        );\n      }\n      let validationResult = await validator(authData[provider], req, user, requestObject);\n      method = validationResult && validationResult.method;\n      requestObject.triggerName = method;\n      if (validationResult && validationResult.validator) {\n        validationResult = await validationResult.validator();\n      }\n      if (!validationResult) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n      if (!Object.keys(validationResult).length) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n\n      if (validationResult.response) {\n        acc.authDataResponse[provider] = validationResult.response;\n      }\n      // Some auth providers after initialization will avoid to replace authData already stored\n      if (!validationResult.doNotSave) {\n        acc.authData[provider] = validationResult.save || authData[provider];\n      }\n    } catch (err) {\n      const e = resolveError(err, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: 'Auth failed. Unknown error.',\n      });\n      const userString =\n        req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;\n      logger.error(\n        `Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` +\n          JSON.stringify(e),\n        {\n          authenticationStep: method,\n          error: e,\n          user: userString,\n          provider,\n        }\n      );\n      throw e;\n    }\n  }\n  return acc;\n};\n\nmodule.exports = {\n  Auth,\n  master,\n  maintenance,\n  nobody,\n  readOnly,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"],"mappings":"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"}
604
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","Auth","config","cacheController","undefined","isMaster","isMaintenance","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","maintenance","readOnly","nobody","throttle","renewSessionIfNeeded","session","sessionToken","extendSessionOnUse","clearTimeout","setTimeout","query","RestQuery","method","Method","get","auth","runBeforeFind","className","restWhere","restOptions","limit","results","execute","lastUpdated","Date","updatedAt","yesterday","setDate","getDate","expiresAt","generateSessionExpiresAt","RestWrite","objectId","_encode","e","code","Error","OBJECT_NOT_FOUND","logger","error","getAuthForSessionToken","userJSON","cachedUser","Object","fromJSON","Promise","resolve","include","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","INVALID_SESSION_TOKEN","now","iso","password","put","userObject","getAuthForLegacySessionToken","_session_token","then","response","getUserRoles","_loadRoles","getRolesForUser","users","__type","id","each","result","push","Role","cachedRoles","role","cacheRoles","rolesMap","reduce","m","r","names","name","ids","roleNames","_getAllRolesNamesForRoleIds","Array","clearRoleCache","del","getRolesByIds","ins","containedIn","roles","$in","roleIDs","queriedRoles","filter","roleID","wasQueried","Set","resultMap","memo","concat","findUsersWithAuthData","authData","providers","keys","provider","queryKey","q","database","$or","hasMutatedAuthData","userAuthData","mutatedAuthData","forEach","providerData","userProviderAuthData","isDeepStrictEqual","checkIfUserHasProvidedConfiguredProvidersForLogin","req","savedUserProviders","adapter","authDataManager","getValidatorForProvider","hasProvidedASoloProvider","some","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","requestObject","ip","call","OTHER_CAUSE","join","handleAuthDataValidation","foundUser","User","getUserId","fetch","updatedObject","buildParseObjects","getRequestObject","acc","authDataResponse","authKeys","sort","validator","authProvider","enabled","Deprecator","logRuntimeDeprecation","usage","solution","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","resolveError","SCRIPT_FAILED","message","userString","data","JSON","stringify","authenticationStep","module","exports"],"sources":["../src/Auth.js"],"sourcesContent":["const Parse = require('parse/node');\nimport { isDeepStrictEqual } from 'util';\nimport { getRequestObject, resolveError } from './triggers';\nimport Deprecator from './Deprecator/Deprecator';\nimport { logger } from './logger';\nimport RestQuery from './RestQuery';\nimport RestWrite from './RestWrite';\n\n// An Auth object tells you who is requesting something and whether\n// the master key was used.\n// userObject is a Parse.User and can be null if there's no user.\nfunction Auth({\n  config,\n  cacheController = undefined,\n  isMaster = false,\n  isMaintenance = false,\n  isReadOnly = false,\n  user,\n  installationId,\n}) {\n  this.config = config;\n  this.cacheController = cacheController || (config && config.cacheController);\n  this.installationId = installationId;\n  this.isMaster = isMaster;\n  this.isMaintenance = isMaintenance;\n  this.user = user;\n  this.isReadOnly = isReadOnly;\n\n  // Assuming a users roles won't change during a single request, we'll\n  // only load them once.\n  this.userRoles = [];\n  this.fetchedRoles = false;\n  this.rolePromise = null;\n}\n\n// Whether this auth could possibly modify the given user id.\n// It still could be forbidden via ACLs even if this returns true.\nAuth.prototype.isUnauthenticated = function () {\n  if (this.isMaster) {\n    return false;\n  }\n  if (this.isMaintenance) {\n    return false;\n  }\n  if (this.user) {\n    return false;\n  }\n  return true;\n};\n\n// A helper to get a master-level Auth object\nfunction master(config) {\n  return new Auth({ config, isMaster: true });\n}\n\n// A helper to get a maintenance-level Auth object\nfunction maintenance(config) {\n  return new Auth({ config, isMaintenance: true });\n}\n\n// A helper to get a master-level Auth object\nfunction readOnly(config) {\n  return new Auth({ config, isMaster: true, isReadOnly: true });\n}\n\n// A helper to get a nobody-level Auth object\nfunction nobody(config) {\n  return new Auth({ config, isMaster: false });\n}\n\nconst throttle = {};\nconst renewSessionIfNeeded = async ({ config, session, sessionToken }) => {\n  if (!config?.extendSessionOnUse) {\n    return;\n  }\n  clearTimeout(throttle[sessionToken]);\n  throttle[sessionToken] = setTimeout(async () => {\n    try {\n      if (!session) {\n        const query = await RestQuery({\n          method: RestQuery.Method.get,\n          config,\n          auth: master(config),\n          runBeforeFind: false,\n          className: '_Session',\n          restWhere: { sessionToken },\n          restOptions: { limit: 1 },\n        });\n        const { results } = await query.execute();\n        session = results[0];\n      }\n      const lastUpdated = new Date(session?.updatedAt);\n      const yesterday = new Date();\n      yesterday.setDate(yesterday.getDate() - 1);\n      if (lastUpdated > yesterday || !session) {\n        return;\n      }\n      const expiresAt = config.generateSessionExpiresAt();\n      await new RestWrite(\n        config,\n        master(config),\n        '_Session',\n        { objectId: session.objectId },\n        { expiresAt: Parse._encode(expiresAt) }\n      ).execute();\n    } catch (e) {\n      if (e?.code !== Parse.Error.OBJECT_NOT_FOUND) {\n        logger.error('Could not update session expiry: ', e);\n      }\n    }\n  }, 500);\n};\n\n// Returns a promise that resolves to an Auth object\nconst getAuthForSessionToken = async function ({\n  config,\n  cacheController,\n  sessionToken,\n  installationId,\n}) {\n  cacheController = cacheController || (config && config.cacheController);\n  if (cacheController) {\n    const userJSON = await cacheController.user.get(sessionToken);\n    if (userJSON) {\n      const cachedUser = Parse.Object.fromJSON(userJSON);\n      renewSessionIfNeeded({ config, sessionToken });\n      return Promise.resolve(\n        new Auth({\n          config,\n          cacheController,\n          isMaster: false,\n          installationId,\n          user: cachedUser,\n        })\n      );\n    }\n  }\n\n  let results;\n  if (config) {\n    const restOptions = {\n      limit: 1,\n      include: 'user',\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.get,\n      config,\n      runBeforeFind: false,\n      auth: master(config),\n      className: '_Session',\n      restWhere: { sessionToken },\n      restOptions,\n    });\n    results = (await query.execute()).results;\n  } else {\n    results = (\n      await new Parse.Query(Parse.Session)\n        .limit(1)\n        .include('user')\n        .equalTo('sessionToken', sessionToken)\n        .find({ useMasterKey: true })\n    ).map(obj => obj.toJSON());\n  }\n\n  if (results.length !== 1 || !results[0]['user']) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const session = results[0];\n  const now = new Date(),\n    expiresAt = session.expiresAt ? new Date(session.expiresAt.iso) : undefined;\n  if (expiresAt < now) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n  }\n  const obj = session.user;\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, obj);\n  }\n  renewSessionIfNeeded({ config, session, sessionToken });\n  const userObject = Parse.Object.fromJSON(obj);\n  return new Auth({\n    config,\n    cacheController,\n    isMaster: false,\n    installationId,\n    user: userObject,\n  });\n};\n\nvar getAuthForLegacySessionToken = async function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  const RestQuery = require('./RestQuery');\n  var query = await RestQuery({\n    method: RestQuery.Method.get,\n    config,\n    runBeforeFind: false,\n    auth: master(config),\n    className: '_User',\n    restWhere: { _session_token: sessionToken },\n    restOptions,\n  });\n  return query.execute().then(response => {\n    var results = response.results;\n    if (results.length !== 1) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');\n    }\n    const obj = results[0];\n    obj.className = '_User';\n    const userObject = Parse.Object.fromJSON(obj);\n    return new Auth({\n      config,\n      isMaster: false,\n      installationId,\n      user: userObject,\n    });\n  });\n};\n\n// Returns a promise that resolves to an array of role names\nAuth.prototype.getUserRoles = function () {\n  if (this.isMaster || this.isMaintenance || !this.user) {\n    return Promise.resolve([]);\n  }\n  if (this.fetchedRoles) {\n    return Promise.resolve(this.userRoles);\n  }\n  if (this.rolePromise) {\n    return this.rolePromise;\n  }\n  this.rolePromise = this._loadRoles();\n  return this.rolePromise;\n};\n\nAuth.prototype.getRolesForUser = async function () {\n  //Stack all Parse.Role\n  const results = [];\n  if (this.config) {\n    const restWhere = {\n      users: {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: this.user.id,\n      },\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      runBeforeFind: false,\n      config: this.config,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  } else {\n    await new Parse.Query(Parse.Role)\n      .equalTo('users', this.user)\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  }\n  return results;\n};\n\n// Iterates through the role tree and compiles a user's roles\nAuth.prototype._loadRoles = async function () {\n  if (this.cacheController) {\n    const cachedRoles = await this.cacheController.role.get(this.user.id);\n    if (cachedRoles != null) {\n      this.fetchedRoles = true;\n      this.userRoles = cachedRoles;\n      return cachedRoles;\n    }\n  }\n\n  // First get the role ids this user is directly a member of\n  const results = await this.getRolesForUser();\n  if (!results.length) {\n    this.userRoles = [];\n    this.fetchedRoles = true;\n    this.rolePromise = null;\n\n    this.cacheRoles();\n    return this.userRoles;\n  }\n\n  const rolesMap = results.reduce(\n    (m, r) => {\n      m.names.push(r.name);\n      m.ids.push(r.objectId);\n      return m;\n    },\n    { ids: [], names: [] }\n  );\n\n  // run the recursive finding\n  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);\n  this.userRoles = roleNames.map(r => {\n    return 'role:' + r;\n  });\n  this.fetchedRoles = true;\n  this.rolePromise = null;\n  this.cacheRoles();\n  return this.userRoles;\n};\n\nAuth.prototype.cacheRoles = function () {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.put(this.user.id, Array(...this.userRoles));\n  return true;\n};\n\nAuth.prototype.clearRoleCache = function (sessionToken) {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.del(this.user.id);\n  this.cacheController.user.del(sessionToken);\n  return true;\n};\n\nAuth.prototype.getRolesByIds = async function (ins) {\n  const results = [];\n  // Build an OR query across all parentRoles\n  if (!this.config) {\n    await new Parse.Query(Parse.Role)\n      .containedIn(\n        'roles',\n        ins.map(id => {\n          const role = new Parse.Object(Parse.Role);\n          role.id = id;\n          return role;\n        })\n      )\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  } else {\n    const roles = ins.map(id => {\n      return {\n        __type: 'Pointer',\n        className: '_Role',\n        objectId: id,\n      };\n    });\n    const restWhere = { roles: { $in: roles } };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      config: this.config,\n      runBeforeFind: false,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  }\n  return results;\n};\n\n// Given a list of roleIds, find all the parent roles, returns a promise with all names\nAuth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {\n  const ins = roleIDs.filter(roleID => {\n    const wasQueried = queriedRoles[roleID] !== true;\n    queriedRoles[roleID] = true;\n    return wasQueried;\n  });\n\n  // all roles are accounted for, return the names\n  if (ins.length == 0) {\n    return Promise.resolve([...new Set(names)]);\n  }\n\n  return this.getRolesByIds(ins)\n    .then(results => {\n      // Nothing found\n      if (!results.length) {\n        return Promise.resolve(names);\n      }\n      // Map the results with all Ids and names\n      const resultMap = results.reduce(\n        (memo, role) => {\n          memo.names.push(role.name);\n          memo.ids.push(role.objectId);\n          return memo;\n        },\n        { ids: [], names: [] }\n      );\n      // store the new found names\n      names = names.concat(resultMap.names);\n      // find the next ones, circular roles will be cut\n      return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);\n    })\n    .then(names => {\n      return Promise.resolve([...new Set(names)]);\n    });\n};\n\nconst findUsersWithAuthData = (config, authData) => {\n  const providers = Object.keys(authData);\n  const query = providers\n    .reduce((memo, provider) => {\n      if (!authData[provider] || (authData && !authData[provider].id)) {\n        return memo;\n      }\n      const queryKey = `authData.${provider}.id`;\n      const query = {};\n      query[queryKey] = authData[provider].id;\n      memo.push(query);\n      return memo;\n    }, [])\n    .filter(q => {\n      return typeof q !== 'undefined';\n    });\n\n  return query.length > 0\n    ? config.database.find('_User', { $or: query }, { limit: 2 })\n    : Promise.resolve([]);\n};\n\nconst hasMutatedAuthData = (authData, userAuthData) => {\n  if (!userAuthData) return { hasMutatedAuthData: true, mutatedAuthData: authData };\n  const mutatedAuthData = {};\n  Object.keys(authData).forEach(provider => {\n    // Anonymous provider is not handled this way\n    if (provider === 'anonymous') return;\n    const providerData = authData[provider];\n    const userProviderAuthData = userAuthData[provider];\n    if (!isDeepStrictEqual(providerData, userProviderAuthData)) {\n      mutatedAuthData[provider] = providerData;\n    }\n  });\n  const hasMutatedAuthData = Object.keys(mutatedAuthData).length !== 0;\n  return { hasMutatedAuthData, mutatedAuthData };\n};\n\nconst checkIfUserHasProvidedConfiguredProvidersForLogin = (\n  req = {},\n  authData = {},\n  userAuthData = {},\n  config\n) => {\n  const savedUserProviders = Object.keys(userAuthData).map(provider => ({\n    name: provider,\n    adapter: config.authDataManager.getValidatorForProvider(provider).adapter,\n  }));\n\n  const hasProvidedASoloProvider = savedUserProviders.some(\n    provider =>\n      provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]\n  );\n\n  // Solo providers can be considered as safe, so we do not have to check if the user needs\n  // to provide an additional provider to login. An auth adapter with \"solo\" (like webauthn) means\n  // no \"additional\" auth needs to be provided to login (like OTP, MFA)\n  if (hasProvidedASoloProvider) {\n    return;\n  }\n\n  const additionProvidersNotFound = [];\n  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {\n    let policy = provider.adapter.policy;\n    if (typeof policy === 'function') {\n      const requestObject = {\n        ip: req.config.ip,\n        user: req.auth.user,\n        master: req.auth.isMaster,\n      };\n      policy = policy.call(provider.adapter, requestObject, userAuthData[provider.name]);\n    }\n    if (policy === 'additional') {\n      if (authData[provider.name]) {\n        return true;\n      } else {\n        // Push missing provider for error message\n        additionProvidersNotFound.push(provider.name);\n      }\n    }\n  });\n  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {\n    return;\n  }\n\n  throw new Parse.Error(\n    Parse.Error.OTHER_CAUSE,\n    `Missing additional authData ${additionProvidersNotFound.join(',')}`\n  );\n};\n\n// Validate each authData step-by-step and return the provider responses\nconst handleAuthDataValidation = async (authData, req, foundUser) => {\n  let user;\n  if (foundUser) {\n    user = Parse.User.fromJSON({ className: '_User', ...foundUser });\n    // Find user by session and current objectId; only pass user if it's the current user or master key is provided\n  } else if (\n    (req.auth &&\n      req.auth.user &&\n      typeof req.getUserId === 'function' &&\n      req.getUserId() === req.auth.user.id) ||\n    (req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId())\n  ) {\n    user = new Parse.User();\n    user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;\n    await user.fetch({ useMasterKey: true });\n  }\n\n  const { updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(undefined, req.auth, updatedObject, user, req.config);\n  // Perform validation as step-by-step pipeline for better error consistency\n  // and also to avoid to trigger a provider (like OTP SMS) if another one fails\n  const acc = { authData: {}, authDataResponse: {} };\n  const authKeys = Object.keys(authData).sort();\n  for (const provider of authKeys) {\n    let method = '';\n    try {\n      if (authData[provider] === null) {\n        acc.authData[provider] = null;\n        continue;\n      }\n      const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n      const authProvider = (req.config.auth || {})[provider] || {};\n      if (authProvider.enabled == null) {\n        Deprecator.logRuntimeDeprecation({\n          usage: `Using the authentication adapter \"${provider}\" without explicitly enabling it`,\n          solution: `Enable the authentication adapter by setting the Parse Server option \"auth.${provider}.enabled: true\".`,\n        });\n      }\n      if (!validator || authProvider.enabled === false) {\n        throw new Parse.Error(\n          Parse.Error.UNSUPPORTED_SERVICE,\n          'This authentication method is unsupported.'\n        );\n      }\n      let validationResult = await validator(authData[provider], req, user, requestObject);\n      method = validationResult && validationResult.method;\n      requestObject.triggerName = method;\n      if (validationResult && validationResult.validator) {\n        validationResult = await validationResult.validator();\n      }\n      if (!validationResult) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n      if (!Object.keys(validationResult).length) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n\n      if (validationResult.response) {\n        acc.authDataResponse[provider] = validationResult.response;\n      }\n      // Some auth providers after initialization will avoid to replace authData already stored\n      if (!validationResult.doNotSave) {\n        acc.authData[provider] = validationResult.save || authData[provider];\n      }\n    } catch (err) {\n      const e = resolveError(err, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: 'Auth failed. Unknown error.',\n      });\n      const userString =\n        req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;\n      logger.error(\n        `Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` +\n          JSON.stringify(e),\n        {\n          authenticationStep: method,\n          error: e,\n          user: userString,\n          provider,\n        }\n      );\n      throw e;\n    }\n  }\n  return acc;\n};\n\nmodule.exports = {\n  Auth,\n  master,\n  maintenance,\n  nobody,\n  readOnly,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"],"mappings":"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"}
@@ -66,9 +66,16 @@ class PushController {
66
66
 
67
67
  // Force filtering on only valid device tokens
68
68
  const updateWhere = (0, _utils.applyDeviceTokenExists)(where);
69
- badgeUpdate = () => {
69
+ badgeUpdate = async () => {
70
70
  // Build a real RestQuery so we can use it in RestWrite
71
- const restQuery = new _RestQuery.default(config, (0, _Auth.master)(config), '_Installation', updateWhere);
71
+ const restQuery = await (0, _RestQuery.default)({
72
+ method: _RestQuery.default.Method.find,
73
+ config,
74
+ runBeforeFind: false,
75
+ auth: (0, _Auth.master)(config),
76
+ className: '_Installation',
77
+ restWhere: updateWhere
78
+ });
72
79
  return restQuery.buildRestWhere().then(() => {
73
80
  const write = new _RestWrite.default(config, (0, _Auth.master)(config), '_Installation', restQuery.restWhere, restUpdate);
74
81
  write.runOptions.many = true;
@@ -215,4 +222,4 @@ class PushController {
215
222
  exports.PushController = PushController;
216
223
  var _default = PushController;
217
224
  exports.default = _default;
218
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["PushController","sendPush","body","where","config","auth","onPushStatusSaved","now","Date","hasPushSupport","Parse","Error","PUSH_MISCONFIGURED","expiration_time","getExpirationTime","expiration_interval","getExpirationInterval","Object","prototype","hasOwnProperty","call","ttlMs","valueOf","pushTime","getPushTime","date","formatPushTime","badgeUpdate","Promise","resolve","data","badge","restUpdate","toLowerCase","__op","amount","Number","updateWhere","applyDeviceTokenExists","restQuery","RestQuery","master","buildRestWhere","then","write","RestWrite","restWhere","runOptions","many","execute","pushStatus","pushStatusHandler","setInitial","objectId","audience_id","audienceId","updateAudience","lastUsed","__type","iso","toISOString","timesUsed","hasPushScheduledSupport","pushControllerQueue","enqueue","catch","err","fail","hasExpirationTime","expirationTimeParam","expirationTime","isFinite","hasExpirationInterval","expirationIntervalParam","hasPushTime","pushTimeParam","isLocalTime","pushTimeHasTimezoneComponent","offsetPattern","indexOf","length","test","isoString","substring"],"sources":["../../src/Controllers/PushController.js"],"sourcesContent":["import { Parse } from 'parse/node';\nimport RestQuery from '../RestQuery';\nimport RestWrite from '../RestWrite';\nimport { master } from '../Auth';\nimport { pushStatusHandler } from '../StatusHandler';\nimport { applyDeviceTokenExists } from '../Push/utils';\n\nexport class PushController {\n  sendPush(body = {}, where = {}, config, auth, onPushStatusSaved = () => {}, now = new Date()) {\n    if (!config.hasPushSupport) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Missing push configuration');\n    }\n\n    // Replace the expiration_time and push_time with a valid Unix epoch milliseconds time\n    body.expiration_time = PushController.getExpirationTime(body);\n    body.expiration_interval = PushController.getExpirationInterval(body);\n    if (body.expiration_time && body.expiration_interval) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Both expiration_time and expiration_interval cannot be set'\n      );\n    }\n\n    // Immediate push\n    if (body.expiration_interval && !Object.prototype.hasOwnProperty.call(body, 'push_time')) {\n      const ttlMs = body.expiration_interval * 1000;\n      body.expiration_time = new Date(now.valueOf() + ttlMs).valueOf();\n    }\n\n    const pushTime = PushController.getPushTime(body);\n    if (pushTime && pushTime.date !== 'undefined') {\n      body['push_time'] = PushController.formatPushTime(pushTime);\n    }\n\n    // TODO: If the req can pass the checking, we return immediately instead of waiting\n    // pushes to be sent. We probably change this behaviour in the future.\n    let badgeUpdate = () => {\n      return Promise.resolve();\n    };\n\n    if (body.data && body.data.badge) {\n      const badge = body.data.badge;\n      let restUpdate = {};\n      if (typeof badge == 'string' && badge.toLowerCase() === 'increment') {\n        restUpdate = { badge: { __op: 'Increment', amount: 1 } };\n      } else if (\n        typeof badge == 'object' &&\n        typeof badge.__op == 'string' &&\n        badge.__op.toLowerCase() == 'increment' &&\n        Number(badge.amount)\n      ) {\n        restUpdate = { badge: { __op: 'Increment', amount: badge.amount } };\n      } else if (Number(badge)) {\n        restUpdate = { badge: badge };\n      } else {\n        throw \"Invalid value for badge, expected number or 'Increment' or {increment: number}\";\n      }\n\n      // Force filtering on only valid device tokens\n      const updateWhere = applyDeviceTokenExists(where);\n      badgeUpdate = () => {\n        // Build a real RestQuery so we can use it in RestWrite\n        const restQuery = new RestQuery(config, master(config), '_Installation', updateWhere);\n        return restQuery.buildRestWhere().then(() => {\n          const write = new RestWrite(\n            config,\n            master(config),\n            '_Installation',\n            restQuery.restWhere,\n            restUpdate\n          );\n          write.runOptions.many = true;\n          return write.execute();\n        });\n      };\n    }\n    const pushStatus = pushStatusHandler(config);\n    return Promise.resolve()\n      .then(() => {\n        return pushStatus.setInitial(body, where);\n      })\n      .then(() => {\n        onPushStatusSaved(pushStatus.objectId);\n        return badgeUpdate();\n      })\n      .then(() => {\n        // Update audience lastUsed and timesUsed\n        if (body.audience_id) {\n          const audienceId = body.audience_id;\n\n          var updateAudience = {\n            lastUsed: { __type: 'Date', iso: new Date().toISOString() },\n            timesUsed: { __op: 'Increment', amount: 1 },\n          };\n          const write = new RestWrite(\n            config,\n            master(config),\n            '_Audience',\n            { objectId: audienceId },\n            updateAudience\n          );\n          write.execute();\n        }\n        // Don't wait for the audience update promise to resolve.\n        return Promise.resolve();\n      })\n      .then(() => {\n        if (\n          Object.prototype.hasOwnProperty.call(body, 'push_time') &&\n          config.hasPushScheduledSupport\n        ) {\n          return Promise.resolve();\n        }\n        return config.pushControllerQueue.enqueue(body, where, config, auth, pushStatus);\n      })\n      .catch(err => {\n        return pushStatus.fail(err).then(() => {\n          throw err;\n        });\n      });\n  }\n\n  /**\n   * Get expiration time from the request body.\n   * @param {Object} request A request object\n   * @returns {Number|undefined} The expiration time if it exists in the request\n   */\n  static getExpirationTime(body = {}) {\n    var hasExpirationTime = Object.prototype.hasOwnProperty.call(body, 'expiration_time');\n    if (!hasExpirationTime) {\n      return;\n    }\n    var expirationTimeParam = body['expiration_time'];\n    var expirationTime;\n    if (typeof expirationTimeParam === 'number') {\n      expirationTime = new Date(expirationTimeParam * 1000);\n    } else if (typeof expirationTimeParam === 'string') {\n      expirationTime = new Date(expirationTimeParam);\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['expiration_time'] + ' is not valid time.'\n      );\n    }\n    // Check expirationTime is valid or not, if it is not valid, expirationTime is NaN\n    if (!isFinite(expirationTime)) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['expiration_time'] + ' is not valid time.'\n      );\n    }\n    return expirationTime.valueOf();\n  }\n\n  static getExpirationInterval(body = {}) {\n    const hasExpirationInterval = Object.prototype.hasOwnProperty.call(body, 'expiration_interval');\n    if (!hasExpirationInterval) {\n      return;\n    }\n\n    var expirationIntervalParam = body['expiration_interval'];\n    if (typeof expirationIntervalParam !== 'number' || expirationIntervalParam <= 0) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        `expiration_interval must be a number greater than 0`\n      );\n    }\n    return expirationIntervalParam;\n  }\n\n  /**\n   * Get push time from the request body.\n   * @param {Object} request A request object\n   * @returns {Number|undefined} The push time if it exists in the request\n   */\n  static getPushTime(body = {}) {\n    var hasPushTime = Object.prototype.hasOwnProperty.call(body, 'push_time');\n    if (!hasPushTime) {\n      return;\n    }\n    var pushTimeParam = body['push_time'];\n    var date;\n    var isLocalTime = true;\n\n    if (typeof pushTimeParam === 'number') {\n      date = new Date(pushTimeParam * 1000);\n    } else if (typeof pushTimeParam === 'string') {\n      isLocalTime = !PushController.pushTimeHasTimezoneComponent(pushTimeParam);\n      date = new Date(pushTimeParam);\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['push_time'] + ' is not valid time.'\n      );\n    }\n    // Check pushTime is valid or not, if it is not valid, pushTime is NaN\n    if (!isFinite(date)) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['push_time'] + ' is not valid time.'\n      );\n    }\n\n    return {\n      date,\n      isLocalTime,\n    };\n  }\n\n  /**\n   * Checks if a ISO8601 formatted date contains a timezone component\n   * @param pushTimeParam {string}\n   * @returns {boolean}\n   */\n  static pushTimeHasTimezoneComponent(pushTimeParam: string): boolean {\n    const offsetPattern = /(.+)([+-])\\d\\d:\\d\\d$/;\n    return (\n      pushTimeParam.indexOf('Z') === pushTimeParam.length - 1 || offsetPattern.test(pushTimeParam) // 2007-04-05T12:30Z\n    ); // 2007-04-05T12:30.000+02:00, 2007-04-05T12:30.000-02:00\n  }\n\n  /**\n   * Converts a date to ISO format in UTC time and strips the timezone if `isLocalTime` is true\n   * @param date {Date}\n   * @param isLocalTime {boolean}\n   * @returns {string}\n   */\n  static formatPushTime({ date, isLocalTime }: { date: Date, isLocalTime: boolean }) {\n    if (isLocalTime) {\n      // Strip 'Z'\n      const isoString = date.toISOString();\n      return isoString.substring(0, isoString.indexOf('Z'));\n    }\n    return date.toISOString();\n  }\n}\n\nexport default PushController;\n"],"mappings":"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"}
225
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["PushController","sendPush","body","where","config","auth","onPushStatusSaved","now","Date","hasPushSupport","Parse","Error","PUSH_MISCONFIGURED","expiration_time","getExpirationTime","expiration_interval","getExpirationInterval","Object","prototype","hasOwnProperty","call","ttlMs","valueOf","pushTime","getPushTime","date","formatPushTime","badgeUpdate","Promise","resolve","data","badge","restUpdate","toLowerCase","__op","amount","Number","updateWhere","applyDeviceTokenExists","restQuery","RestQuery","method","Method","find","runBeforeFind","master","className","restWhere","buildRestWhere","then","write","RestWrite","runOptions","many","execute","pushStatus","pushStatusHandler","setInitial","objectId","audience_id","audienceId","updateAudience","lastUsed","__type","iso","toISOString","timesUsed","hasPushScheduledSupport","pushControllerQueue","enqueue","catch","err","fail","hasExpirationTime","expirationTimeParam","expirationTime","isFinite","hasExpirationInterval","expirationIntervalParam","hasPushTime","pushTimeParam","isLocalTime","pushTimeHasTimezoneComponent","offsetPattern","indexOf","length","test","isoString","substring"],"sources":["../../src/Controllers/PushController.js"],"sourcesContent":["import { Parse } from 'parse/node';\nimport RestQuery from '../RestQuery';\nimport RestWrite from '../RestWrite';\nimport { master } from '../Auth';\nimport { pushStatusHandler } from '../StatusHandler';\nimport { applyDeviceTokenExists } from '../Push/utils';\n\nexport class PushController {\n  sendPush(body = {}, where = {}, config, auth, onPushStatusSaved = () => {}, now = new Date()) {\n    if (!config.hasPushSupport) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Missing push configuration');\n    }\n\n    // Replace the expiration_time and push_time with a valid Unix epoch milliseconds time\n    body.expiration_time = PushController.getExpirationTime(body);\n    body.expiration_interval = PushController.getExpirationInterval(body);\n    if (body.expiration_time && body.expiration_interval) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Both expiration_time and expiration_interval cannot be set'\n      );\n    }\n\n    // Immediate push\n    if (body.expiration_interval && !Object.prototype.hasOwnProperty.call(body, 'push_time')) {\n      const ttlMs = body.expiration_interval * 1000;\n      body.expiration_time = new Date(now.valueOf() + ttlMs).valueOf();\n    }\n\n    const pushTime = PushController.getPushTime(body);\n    if (pushTime && pushTime.date !== 'undefined') {\n      body['push_time'] = PushController.formatPushTime(pushTime);\n    }\n\n    // TODO: If the req can pass the checking, we return immediately instead of waiting\n    // pushes to be sent. We probably change this behaviour in the future.\n    let badgeUpdate = () => {\n      return Promise.resolve();\n    };\n\n    if (body.data && body.data.badge) {\n      const badge = body.data.badge;\n      let restUpdate = {};\n      if (typeof badge == 'string' && badge.toLowerCase() === 'increment') {\n        restUpdate = { badge: { __op: 'Increment', amount: 1 } };\n      } else if (\n        typeof badge == 'object' &&\n        typeof badge.__op == 'string' &&\n        badge.__op.toLowerCase() == 'increment' &&\n        Number(badge.amount)\n      ) {\n        restUpdate = { badge: { __op: 'Increment', amount: badge.amount } };\n      } else if (Number(badge)) {\n        restUpdate = { badge: badge };\n      } else {\n        throw \"Invalid value for badge, expected number or 'Increment' or {increment: number}\";\n      }\n\n      // Force filtering on only valid device tokens\n      const updateWhere = applyDeviceTokenExists(where);\n      badgeUpdate = async () => {\n        // Build a real RestQuery so we can use it in RestWrite\n        const restQuery = await RestQuery({\n          method: RestQuery.Method.find,\n          config,\n          runBeforeFind: false,\n          auth: master(config),\n          className: '_Installation',\n          restWhere: updateWhere,\n        });\n        return restQuery.buildRestWhere().then(() => {\n          const write = new RestWrite(\n            config,\n            master(config),\n            '_Installation',\n            restQuery.restWhere,\n            restUpdate\n          );\n          write.runOptions.many = true;\n          return write.execute();\n        });\n      };\n    }\n    const pushStatus = pushStatusHandler(config);\n    return Promise.resolve()\n      .then(() => {\n        return pushStatus.setInitial(body, where);\n      })\n      .then(() => {\n        onPushStatusSaved(pushStatus.objectId);\n        return badgeUpdate();\n      })\n      .then(() => {\n        // Update audience lastUsed and timesUsed\n        if (body.audience_id) {\n          const audienceId = body.audience_id;\n\n          var updateAudience = {\n            lastUsed: { __type: 'Date', iso: new Date().toISOString() },\n            timesUsed: { __op: 'Increment', amount: 1 },\n          };\n          const write = new RestWrite(\n            config,\n            master(config),\n            '_Audience',\n            { objectId: audienceId },\n            updateAudience\n          );\n          write.execute();\n        }\n        // Don't wait for the audience update promise to resolve.\n        return Promise.resolve();\n      })\n      .then(() => {\n        if (\n          Object.prototype.hasOwnProperty.call(body, 'push_time') &&\n          config.hasPushScheduledSupport\n        ) {\n          return Promise.resolve();\n        }\n        return config.pushControllerQueue.enqueue(body, where, config, auth, pushStatus);\n      })\n      .catch(err => {\n        return pushStatus.fail(err).then(() => {\n          throw err;\n        });\n      });\n  }\n\n  /**\n   * Get expiration time from the request body.\n   * @param {Object} request A request object\n   * @returns {Number|undefined} The expiration time if it exists in the request\n   */\n  static getExpirationTime(body = {}) {\n    var hasExpirationTime = Object.prototype.hasOwnProperty.call(body, 'expiration_time');\n    if (!hasExpirationTime) {\n      return;\n    }\n    var expirationTimeParam = body['expiration_time'];\n    var expirationTime;\n    if (typeof expirationTimeParam === 'number') {\n      expirationTime = new Date(expirationTimeParam * 1000);\n    } else if (typeof expirationTimeParam === 'string') {\n      expirationTime = new Date(expirationTimeParam);\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['expiration_time'] + ' is not valid time.'\n      );\n    }\n    // Check expirationTime is valid or not, if it is not valid, expirationTime is NaN\n    if (!isFinite(expirationTime)) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['expiration_time'] + ' is not valid time.'\n      );\n    }\n    return expirationTime.valueOf();\n  }\n\n  static getExpirationInterval(body = {}) {\n    const hasExpirationInterval = Object.prototype.hasOwnProperty.call(body, 'expiration_interval');\n    if (!hasExpirationInterval) {\n      return;\n    }\n\n    var expirationIntervalParam = body['expiration_interval'];\n    if (typeof expirationIntervalParam !== 'number' || expirationIntervalParam <= 0) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        `expiration_interval must be a number greater than 0`\n      );\n    }\n    return expirationIntervalParam;\n  }\n\n  /**\n   * Get push time from the request body.\n   * @param {Object} request A request object\n   * @returns {Number|undefined} The push time if it exists in the request\n   */\n  static getPushTime(body = {}) {\n    var hasPushTime = Object.prototype.hasOwnProperty.call(body, 'push_time');\n    if (!hasPushTime) {\n      return;\n    }\n    var pushTimeParam = body['push_time'];\n    var date;\n    var isLocalTime = true;\n\n    if (typeof pushTimeParam === 'number') {\n      date = new Date(pushTimeParam * 1000);\n    } else if (typeof pushTimeParam === 'string') {\n      isLocalTime = !PushController.pushTimeHasTimezoneComponent(pushTimeParam);\n      date = new Date(pushTimeParam);\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['push_time'] + ' is not valid time.'\n      );\n    }\n    // Check pushTime is valid or not, if it is not valid, pushTime is NaN\n    if (!isFinite(date)) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        body['push_time'] + ' is not valid time.'\n      );\n    }\n\n    return {\n      date,\n      isLocalTime,\n    };\n  }\n\n  /**\n   * Checks if a ISO8601 formatted date contains a timezone component\n   * @param pushTimeParam {string}\n   * @returns {boolean}\n   */\n  static pushTimeHasTimezoneComponent(pushTimeParam: string): boolean {\n    const offsetPattern = /(.+)([+-])\\d\\d:\\d\\d$/;\n    return (\n      pushTimeParam.indexOf('Z') === pushTimeParam.length - 1 || offsetPattern.test(pushTimeParam) // 2007-04-05T12:30Z\n    ); // 2007-04-05T12:30.000+02:00, 2007-04-05T12:30.000-02:00\n  }\n\n  /**\n   * Converts a date to ISO format in UTC time and strips the timezone if `isLocalTime` is true\n   * @param date {Date}\n   * @param isLocalTime {boolean}\n   * @returns {string}\n   */\n  static formatPushTime({ date, isLocalTime }: { date: Date, isLocalTime: boolean }) {\n    if (isLocalTime) {\n      // Strip 'Z'\n      const isoString = date.toISOString();\n      return isoString.substring(0, isoString.indexOf('Z'));\n    }\n    return date.toISOString();\n  }\n}\n\nexport default PushController;\n"],"mappings":"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"}