parse-server 6.2.0 → 6.3.0-alpha.2

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/Auth.js CHANGED
@@ -4,6 +4,8 @@ var _util = require("util");
4
4
  var _triggers = require("./triggers");
5
5
  var _Deprecator = _interopRequireDefault(require("./Deprecator/Deprecator"));
6
6
  var _logger = require("./logger");
7
+ var _RestQuery = _interopRequireDefault(require("./RestQuery"));
8
+ var _RestWrite = _interopRequireDefault(require("./RestWrite"));
7
9
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
8
10
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
9
11
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
@@ -85,6 +87,48 @@ function nobody(config) {
85
87
  isMaster: false
86
88
  });
87
89
  }
90
+ const throttle = {};
91
+ const renewSessionIfNeeded = async ({
92
+ config,
93
+ session,
94
+ sessionToken
95
+ }) => {
96
+ if (!(config !== null && config !== void 0 && config.extendSessionOnUse)) {
97
+ return;
98
+ }
99
+ clearTimeout(throttle[sessionToken]);
100
+ throttle[sessionToken] = setTimeout(async () => {
101
+ try {
102
+ var _session;
103
+ if (!session) {
104
+ const {
105
+ results
106
+ } = await new _RestQuery.default(config, master(config), '_Session', {
107
+ sessionToken
108
+ }, {
109
+ limit: 1
110
+ }).execute();
111
+ session = results[0];
112
+ }
113
+ const lastUpdated = new Date((_session = session) === null || _session === void 0 ? void 0 : _session.updatedAt);
114
+ const yesterday = new Date();
115
+ yesterday.setDate(yesterday.getDate() - 1);
116
+ if (lastUpdated > yesterday || !session) {
117
+ return;
118
+ }
119
+ const expiresAt = config.generateSessionExpiresAt();
120
+ await new _RestWrite.default(config, master(config), '_Session', {
121
+ objectId: session.objectId
122
+ }, {
123
+ expiresAt: Parse._encode(expiresAt)
124
+ }).execute();
125
+ } catch (e) {
126
+ if ((e === null || e === void 0 ? void 0 : e.code) !== Parse.Error.OBJECT_NOT_FOUND) {
127
+ _logger.logger.error('Could not update session expiry: ', e);
128
+ }
129
+ }
130
+ }, 500);
131
+ };
88
132
 
89
133
  // Returns a promise that resolves to an Auth object
90
134
  const getAuthForSessionToken = async function ({
@@ -98,6 +142,10 @@ const getAuthForSessionToken = async function ({
98
142
  const userJSON = await cacheController.user.get(sessionToken);
99
143
  if (userJSON) {
100
144
  const cachedUser = Parse.Object.fromJSON(userJSON);
145
+ renewSessionIfNeeded({
146
+ config,
147
+ sessionToken
148
+ });
101
149
  return Promise.resolve(new Auth({
102
150
  config,
103
151
  cacheController,
@@ -126,18 +174,24 @@ const getAuthForSessionToken = async function ({
126
174
  if (results.length !== 1 || !results[0]['user']) {
127
175
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
128
176
  }
177
+ const session = results[0];
129
178
  const now = new Date(),
130
- expiresAt = results[0].expiresAt ? new Date(results[0].expiresAt.iso) : undefined;
179
+ expiresAt = session.expiresAt ? new Date(session.expiresAt.iso) : undefined;
131
180
  if (expiresAt < now) {
132
181
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');
133
182
  }
134
- const obj = results[0]['user'];
183
+ const obj = session.user;
135
184
  delete obj.password;
136
185
  obj['className'] = '_User';
137
186
  obj['sessionToken'] = sessionToken;
138
187
  if (cacheController) {
139
188
  cacheController.user.put(sessionToken, obj);
140
189
  }
190
+ renewSessionIfNeeded({
191
+ config,
192
+ session,
193
+ sessionToken
194
+ });
141
195
  const userObject = Parse.Object.fromJSON(obj);
142
196
  return new Auth({
143
197
  config,
@@ -498,4 +552,4 @@ module.exports = {
498
552
  checkIfUserHasProvidedConfiguredProvidersForLogin,
499
553
  handleAuthDataValidation
500
554
  };
501
- //# 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","getAuthForSessionToken","sessionToken","userJSON","get","cachedUser","Object","fromJSON","Promise","resolve","results","restOptions","limit","include","RestQuery","query","execute","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","Error","INVALID_SESSION_TOKEN","now","Date","expiresAt","iso","password","put","userObject","getAuthForLegacySessionToken","then","response","className","getUserRoles","_loadRoles","getRolesForUser","restWhere","users","__type","objectId","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","savedUserProviders","adapter","authDataManager","getValidatorForProvider","hasProvidedASoloProvider","some","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","OTHER_CAUSE","join","handleAuthDataValidation","req","foundUser","User","auth","getUserId","fetch","originalObject","updatedObject","buildParseObjects","requestObject","getRequestObject","acc","authDataResponse","authKeys","sort","method","validator","authProvider","enabled","Deprecator","logRuntimeDeprecation","usage","solution","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","e","resolveError","code","SCRIPT_FAILED","message","userString","data","logger","error","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';\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\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      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 now = new Date(),\n    expiresAt = results[0].expiresAt ? new Date(results[0].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 = results[0]['user'];\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, obj);\n  }\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  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    if (provider && provider.adapter && provider.adapter.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 { originalObject, updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(\n    undefined,\n    req.auth,\n    updatedObject,\n    originalObject || user,\n    req.config\n  );\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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"}
555
+ //# 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","savedUserProviders","adapter","authDataManager","getValidatorForProvider","hasProvidedASoloProvider","some","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","OTHER_CAUSE","join","handleAuthDataValidation","req","foundUser","User","auth","getUserId","fetch","originalObject","updatedObject","buildParseObjects","requestObject","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  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    if (provider && provider.adapter && provider.adapter.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 { originalObject, updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(\n    undefined,\n    req.auth,\n    updatedObject,\n    originalObject || user,\n    req.config\n  );\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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"}