parse-server 5.5.4 → 5.5.5

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
@@ -98,9 +98,17 @@ const getAuthForSessionToken = async function ({
98
98
  limit: 1,
99
99
  include: 'user'
100
100
  };
101
- const query = new RestQuery(config, master(config), '_Session', {
102
- sessionToken
103
- }, restOptions);
101
+ const query = await RestQuery({
102
+ method: RestQuery.Method.get,
103
+ runBeforeFind: false,
104
+ config,
105
+ auth: master(config),
106
+ className: '_Session',
107
+ restWhere: {
108
+ sessionToken
109
+ },
110
+ restOptions
111
+ });
104
112
  results = (await query.execute()).results;
105
113
  } else {
106
114
  results = (await new Parse.Query(Parse.Session).limit(1).include('user').equalTo('sessionToken', sessionToken).find({
@@ -138,7 +146,7 @@ const getAuthForSessionToken = async function ({
138
146
  });
139
147
  };
140
148
 
141
- var getAuthForLegacySessionToken = function ({
149
+ var getAuthForLegacySessionToken = async function ({
142
150
  config,
143
151
  sessionToken,
144
152
  installationId
@@ -146,9 +154,17 @@ var getAuthForLegacySessionToken = function ({
146
154
  var restOptions = {
147
155
  limit: 1
148
156
  };
149
- var query = new RestQuery(config, master(config), '_User', {
150
- sessionToken
151
- }, restOptions);
157
+ var query = await RestQuery({
158
+ method: RestQuery.Method.get,
159
+ runBeforeFind: false,
160
+ config,
161
+ auth: master(config),
162
+ className: '_User',
163
+ restWhere: {
164
+ sessionToken
165
+ },
166
+ restOptions
167
+ });
152
168
  return query.execute().then(response => {
153
169
  var results = response.results;
154
170
 
@@ -198,7 +214,16 @@ Auth.prototype.getRolesForUser = async function () {
198
214
  objectId: this.user.id
199
215
  }
200
216
  };
201
- await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result => results.push(result));
217
+ const query = await RestQuery({
218
+ method: RestQuery.Method.find,
219
+ config: this.config,
220
+ auth: master(this.config),
221
+ runBeforeFind: false,
222
+ className: '_Role',
223
+ restWhere,
224
+ restOptions: {}
225
+ });
226
+ await query.each(result => results.push(result));
202
227
  } else {
203
228
  await new Parse.Query(Parse.Role).equalTo('users', this.user).each(result => results.push(result.toJSON()), {
204
229
  useMasterKey: true
@@ -293,7 +318,16 @@ Auth.prototype.getRolesByIds = async function (ins) {
293
318
  $in: roles
294
319
  }
295
320
  };
296
- await new RestQuery(this.config, master(this.config), '_Role', restWhere, {}).each(result => results.push(result));
321
+ const query = await RestQuery({
322
+ method: RestQuery.Method.find,
323
+ runBeforeFind: false,
324
+ config: this.config,
325
+ auth: master(this.config),
326
+ className: '_Role',
327
+ restWhere,
328
+ restOptions: {}
329
+ });
330
+ await query.each(result => results.push(result));
297
331
  }
298
332
 
299
333
  return results;
@@ -343,4 +377,4 @@ module.exports = {
343
377
  getAuthForSessionToken,
344
378
  getAuthForLegacySessionToken
345
379
  };
346
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Auth.js"],"names":["RestQuery","require","Parse","Auth","config","cacheController","undefined","isMaster","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","readOnly","nobody","getAuthForSessionToken","sessionToken","userJSON","get","cachedUser","Object","fromJSON","Promise","resolve","results","restOptions","limit","include","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","module","exports"],"mappings":"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","sourcesContent":["const RestQuery = require('./RestQuery');\nconst Parse = require('parse/node');\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  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.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.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 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\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  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.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    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    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\nmodule.exports = {\n  Auth,\n  master,\n  nobody,\n  readOnly,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n};\n"]}
380
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Auth.js"],"names":["RestQuery","require","Parse","Auth","config","cacheController","undefined","isMaster","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","readOnly","nobody","getAuthForSessionToken","sessionToken","userJSON","get","cachedUser","Object","fromJSON","Promise","resolve","results","restOptions","limit","include","query","method","Method","runBeforeFind","auth","className","restWhere","execute","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","Error","INVALID_SESSION_TOKEN","now","Date","expiresAt","iso","password","put","userObject","getAuthForLegacySessionToken","then","response","getUserRoles","_loadRoles","getRolesForUser","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","module","exports"],"mappings":"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","sourcesContent":["const RestQuery = require('./RestQuery');\nconst Parse = require('parse/node');\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  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.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.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 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\n    const query = await RestQuery({\n      method: RestQuery.Method.get,\n      runBeforeFind: false,\n      config,\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 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 = async function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  var query = await RestQuery({\n    method: RestQuery.Method.get,\n    runBeforeFind: false,\n    config,\n    auth: master(config),\n    className: '_User',\n    restWhere: { 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.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 query = await RestQuery({\n      method: RestQuery.Method.find,\n      config: this.config,\n      auth: master(this.config),\n      runBeforeFind: false,\n      className: '_Role',\n      restWhere,\n      restOptions: {},\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 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      restOptions: {},\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\nmodule.exports = {\n  Auth,\n  master,\n  nobody,\n  readOnly,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n};\n"]}
@@ -80,9 +80,16 @@ class PushController {
80
80
 
81
81
  const updateWhere = (0, _utils.applyDeviceTokenExists)(where);
82
82
 
83
- badgeUpdate = () => {
83
+ badgeUpdate = async () => {
84
84
  // Build a real RestQuery so we can use it in RestWrite
85
- const restQuery = new _RestQuery.default(config, (0, _Auth.master)(config), '_Installation', updateWhere);
85
+ const restQuery = await (0, _RestQuery.default)({
86
+ method: _RestQuery.default.Method.find,
87
+ config,
88
+ runBeforeFind: false,
89
+ auth: (0, _Auth.master)(config),
90
+ className: '_Installation',
91
+ restWhere: updateWhere
92
+ });
86
93
  return restQuery.buildRestWhere().then(() => {
87
94
  const write = new _RestWrite.default(config, (0, _Auth.master)(config), '_Installation', restQuery.restWhere, restUpdate);
88
95
  write.runOptions.many = true;
@@ -254,4 +261,4 @@ class PushController {
254
261
  exports.PushController = PushController;
255
262
  var _default = PushController;
256
263
  exports.default = _default;
257
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/PushController.js"],"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","restQuery","RestQuery","buildRestWhere","then","write","RestWrite","restWhere","runOptions","many","execute","pushStatus","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"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAEO,MAAMA,cAAN,CAAqB;AAC1BC,EAAAA,QAAQ,CAACC,IAAI,GAAG,EAAR,EAAYC,KAAK,GAAG,EAApB,EAAwBC,MAAxB,EAAgCC,IAAhC,EAAsCC,iBAAiB,GAAG,MAAM,CAAE,CAAlE,EAAoEC,GAAG,GAAG,IAAIC,IAAJ,EAA1E,EAAsF;AAC5F,QAAI,CAACJ,MAAM,CAACK,cAAZ,EAA4B;AAC1B,YAAM,IAAIC,YAAMC,KAAV,CAAgBD,YAAMC,KAAN,CAAYC,kBAA5B,EAAgD,4BAAhD,CAAN;AACD,KAH2F,CAK5F;;;AACAV,IAAAA,IAAI,CAACW,eAAL,GAAuBb,cAAc,CAACc,iBAAf,CAAiCZ,IAAjC,CAAvB;AACAA,IAAAA,IAAI,CAACa,mBAAL,GAA2Bf,cAAc,CAACgB,qBAAf,CAAqCd,IAArC,CAA3B;;AACA,QAAIA,IAAI,CAACW,eAAL,IAAwBX,IAAI,CAACa,mBAAjC,EAAsD;AACpD,YAAM,IAAIL,YAAMC,KAAV,CACJD,YAAMC,KAAN,CAAYC,kBADR,EAEJ,4DAFI,CAAN;AAID,KAb2F,CAe5F;;;AACA,QAAIV,IAAI,CAACa,mBAAL,IAA4B,CAACE,MAAM,CAACC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqClB,IAArC,EAA2C,WAA3C,CAAjC,EAA0F;AACxF,YAAMmB,KAAK,GAAGnB,IAAI,CAACa,mBAAL,GAA2B,IAAzC;AACAb,MAAAA,IAAI,CAACW,eAAL,GAAuB,IAAIL,IAAJ,CAASD,GAAG,CAACe,OAAJ,KAAgBD,KAAzB,EAAgCC,OAAhC,EAAvB;AACD;;AAED,UAAMC,QAAQ,GAAGvB,cAAc,CAACwB,WAAf,CAA2BtB,IAA3B,CAAjB;;AACA,QAAIqB,QAAQ,IAAIA,QAAQ,CAACE,IAAT,KAAkB,WAAlC,EAA+C;AAC7CvB,MAAAA,IAAI,CAAC,WAAD,CAAJ,GAAoBF,cAAc,CAAC0B,cAAf,CAA8BH,QAA9B,CAApB;AACD,KAxB2F,CA0B5F;AACA;;;AACA,QAAII,WAAW,GAAG,MAAM;AACtB,aAAOC,OAAO,CAACC,OAAR,EAAP;AACD,KAFD;;AAIA,QAAI3B,IAAI,CAAC4B,IAAL,IAAa5B,IAAI,CAAC4B,IAAL,CAAUC,KAA3B,EAAkC;AAChC,YAAMA,KAAK,GAAG7B,IAAI,CAAC4B,IAAL,CAAUC,KAAxB;AACA,UAAIC,UAAU,GAAG,EAAjB;;AACA,UAAI,OAAOD,KAAP,IAAgB,QAAhB,IAA4BA,KAAK,CAACE,WAAN,OAAwB,WAAxD,EAAqE;AACnED,QAAAA,UAAU,GAAG;AAAED,UAAAA,KAAK,EAAE;AAAEG,YAAAA,IAAI,EAAE,WAAR;AAAqBC,YAAAA,MAAM,EAAE;AAA7B;AAAT,SAAb;AACD,OAFD,MAEO,IACL,OAAOJ,KAAP,IAAgB,QAAhB,IACA,OAAOA,KAAK,CAACG,IAAb,IAAqB,QADrB,IAEAH,KAAK,CAACG,IAAN,CAAWD,WAAX,MAA4B,WAF5B,IAGAG,MAAM,CAACL,KAAK,CAACI,MAAP,CAJD,EAKL;AACAH,QAAAA,UAAU,GAAG;AAAED,UAAAA,KAAK,EAAE;AAAEG,YAAAA,IAAI,EAAE,WAAR;AAAqBC,YAAAA,MAAM,EAAEJ,KAAK,CAACI;AAAnC;AAAT,SAAb;AACD,OAPM,MAOA,IAAIC,MAAM,CAACL,KAAD,CAAV,EAAmB;AACxBC,QAAAA,UAAU,GAAG;AAAED,UAAAA,KAAK,EAAEA;AAAT,SAAb;AACD,OAFM,MAEA;AACL,cAAM,gFAAN;AACD,OAhB+B,CAkBhC;;;AACA,YAAMM,WAAW,GAAG,mCAAuBlC,KAAvB,CAApB;;AACAwB,MAAAA,WAAW,GAAG,MAAM;AAClB;AACA,cAAMW,SAAS,GAAG,IAAIC,kBAAJ,CAAcnC,MAAd,EAAsB,kBAAOA,MAAP,CAAtB,EAAsC,eAAtC,EAAuDiC,WAAvD,CAAlB;AACA,eAAOC,SAAS,CAACE,cAAV,GAA2BC,IAA3B,CAAgC,MAAM;AAC3C,gBAAMC,KAAK,GAAG,IAAIC,kBAAJ,CACZvC,MADY,EAEZ,kBAAOA,MAAP,CAFY,EAGZ,eAHY,EAIZkC,SAAS,CAACM,SAJE,EAKZZ,UALY,CAAd;AAOAU,UAAAA,KAAK,CAACG,UAAN,CAAiBC,IAAjB,GAAwB,IAAxB;AACA,iBAAOJ,KAAK,CAACK,OAAN,EAAP;AACD,SAVM,CAAP;AAWD,OAdD;AAeD;;AACD,UAAMC,UAAU,GAAG,sCAAkB5C,MAAlB,CAAnB;AACA,WAAOwB,OAAO,CAACC,OAAR,GACJY,IADI,CACC,MAAM;AACV,aAAOO,UAAU,CAACC,UAAX,CAAsB/C,IAAtB,EAA4BC,KAA5B,CAAP;AACD,KAHI,EAIJsC,IAJI,CAIC,MAAM;AACVnC,MAAAA,iBAAiB,CAAC0C,UAAU,CAACE,QAAZ,CAAjB;AACA,aAAOvB,WAAW,EAAlB;AACD,KAPI,EAQJc,IARI,CAQC,MAAM;AACV;AACA,UAAIvC,IAAI,CAACiD,WAAT,EAAsB;AACpB,cAAMC,UAAU,GAAGlD,IAAI,CAACiD,WAAxB;AAEA,YAAIE,cAAc,GAAG;AACnBC,UAAAA,QAAQ,EAAE;AAAEC,YAAAA,MAAM,EAAE,MAAV;AAAkBC,YAAAA,GAAG,EAAE,IAAIhD,IAAJ,GAAWiD,WAAX;AAAvB,WADS;AAEnBC,UAAAA,SAAS,EAAE;AAAExB,YAAAA,IAAI,EAAE,WAAR;AAAqBC,YAAAA,MAAM,EAAE;AAA7B;AAFQ,SAArB;AAIA,cAAMO,KAAK,GAAG,IAAIC,kBAAJ,CACZvC,MADY,EAEZ,kBAAOA,MAAP,CAFY,EAGZ,WAHY,EAIZ;AAAE8C,UAAAA,QAAQ,EAAEE;AAAZ,SAJY,EAKZC,cALY,CAAd;AAOAX,QAAAA,KAAK,CAACK,OAAN;AACD,OAjBS,CAkBV;;;AACA,aAAOnB,OAAO,CAACC,OAAR,EAAP;AACD,KA5BI,EA6BJY,IA7BI,CA6BC,MAAM;AACV,UACExB,MAAM,CAACC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqClB,IAArC,EAA2C,WAA3C,KACAE,MAAM,CAACuD,uBAFT,EAGE;AACA,eAAO/B,OAAO,CAACC,OAAR,EAAP;AACD;;AACD,aAAOzB,MAAM,CAACwD,mBAAP,CAA2BC,OAA3B,CAAmC3D,IAAnC,EAAyCC,KAAzC,EAAgDC,MAAhD,EAAwDC,IAAxD,EAA8D2C,UAA9D,CAAP;AACD,KArCI,EAsCJc,KAtCI,CAsCEC,GAAG,IAAI;AACZ,aAAOf,UAAU,CAACgB,IAAX,CAAgBD,GAAhB,EAAqBtB,IAArB,CAA0B,MAAM;AACrC,cAAMsB,GAAN;AACD,OAFM,CAAP;AAGD,KA1CI,CAAP;AA2CD;AAED;AACF;AACA;AACA;AACA;;;AAC0B,SAAjBjD,iBAAiB,CAACZ,IAAI,GAAG,EAAR,EAAY;AAClC,QAAI+D,iBAAiB,GAAGhD,MAAM,CAACC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqClB,IAArC,EAA2C,iBAA3C,CAAxB;;AACA,QAAI,CAAC+D,iBAAL,EAAwB;AACtB;AACD;;AACD,QAAIC,mBAAmB,GAAGhE,IAAI,CAAC,iBAAD,CAA9B;AACA,QAAIiE,cAAJ;;AACA,QAAI,OAAOD,mBAAP,KAA+B,QAAnC,EAA6C;AAC3CC,MAAAA,cAAc,GAAG,IAAI3D,IAAJ,CAAS0D,mBAAmB,GAAG,IAA/B,CAAjB;AACD,KAFD,MAEO,IAAI,OAAOA,mBAAP,KAA+B,QAAnC,EAA6C;AAClDC,MAAAA,cAAc,GAAG,IAAI3D,IAAJ,CAAS0D,mBAAT,CAAjB;AACD,KAFM,MAEA;AACL,YAAM,IAAIxD,YAAMC,KAAV,CACJD,YAAMC,KAAN,CAAYC,kBADR,EAEJV,IAAI,CAAC,iBAAD,CAAJ,GAA0B,qBAFtB,CAAN;AAID,KAhBiC,CAiBlC;;;AACA,QAAI,CAACkE,QAAQ,CAACD,cAAD,CAAb,EAA+B;AAC7B,YAAM,IAAIzD,YAAMC,KAAV,CACJD,YAAMC,KAAN,CAAYC,kBADR,EAEJV,IAAI,CAAC,iBAAD,CAAJ,GAA0B,qBAFtB,CAAN;AAID;;AACD,WAAOiE,cAAc,CAAC7C,OAAf,EAAP;AACD;;AAE2B,SAArBN,qBAAqB,CAACd,IAAI,GAAG,EAAR,EAAY;AACtC,UAAMmE,qBAAqB,GAAGpD,MAAM,CAACC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqClB,IAArC,EAA2C,qBAA3C,CAA9B;;AACA,QAAI,CAACmE,qBAAL,EAA4B;AAC1B;AACD;;AAED,QAAIC,uBAAuB,GAAGpE,IAAI,CAAC,qBAAD,CAAlC;;AACA,QAAI,OAAOoE,uBAAP,KAAmC,QAAnC,IAA+CA,uBAAuB,IAAI,CAA9E,EAAiF;AAC/E,YAAM,IAAI5D,YAAMC,KAAV,CACJD,YAAMC,KAAN,CAAYC,kBADR,EAEH,qDAFG,CAAN;AAID;;AACD,WAAO0D,uBAAP;AACD;AAED;AACF;AACA;AACA;AACA;;;AACoB,SAAX9C,WAAW,CAACtB,IAAI,GAAG,EAAR,EAAY;AAC5B,QAAIqE,WAAW,GAAGtD,MAAM,CAACC,SAAP,CAAiBC,cAAjB,CAAgCC,IAAhC,CAAqClB,IAArC,EAA2C,WAA3C,CAAlB;;AACA,QAAI,CAACqE,WAAL,EAAkB;AAChB;AACD;;AACD,QAAIC,aAAa,GAAGtE,IAAI,CAAC,WAAD,CAAxB;AACA,QAAIuB,IAAJ;AACA,QAAIgD,WAAW,GAAG,IAAlB;;AAEA,QAAI,OAAOD,aAAP,KAAyB,QAA7B,EAAuC;AACrC/C,MAAAA,IAAI,GAAG,IAAIjB,IAAJ,CAASgE,aAAa,GAAG,IAAzB,CAAP;AACD,KAFD,MAEO,IAAI,OAAOA,aAAP,KAAyB,QAA7B,EAAuC;AAC5CC,MAAAA,WAAW,GAAG,CAACzE,cAAc,CAAC0E,4BAAf,CAA4CF,aAA5C,CAAf;AACA/C,MAAAA,IAAI,GAAG,IAAIjB,IAAJ,CAASgE,aAAT,CAAP;AACD,KAHM,MAGA;AACL,YAAM,IAAI9D,YAAMC,KAAV,CACJD,YAAMC,KAAN,CAAYC,kBADR,EAEJV,IAAI,CAAC,WAAD,CAAJ,GAAoB,qBAFhB,CAAN;AAID,KAnB2B,CAoB5B;;;AACA,QAAI,CAACkE,QAAQ,CAAC3C,IAAD,CAAb,EAAqB;AACnB,YAAM,IAAIf,YAAMC,KAAV,CACJD,YAAMC,KAAN,CAAYC,kBADR,EAEJV,IAAI,CAAC,WAAD,CAAJ,GAAoB,qBAFhB,CAAN;AAID;;AAED,WAAO;AACLuB,MAAAA,IADK;AAELgD,MAAAA;AAFK,KAAP;AAID;AAED;AACF;AACA;AACA;AACA;;;AACqC,SAA5BC,4BAA4B,CAACF,aAAD,EAAiC;AAClE,UAAMG,aAAa,GAAG,sBAAtB;AACA,WACEH,aAAa,CAACI,OAAd,CAAsB,GAAtB,MAA+BJ,aAAa,CAACK,MAAd,GAAuB,CAAtD,IAA2DF,aAAa,CAACG,IAAd,CAAmBN,aAAnB,CAD7D,CAC+F;AAD/F,KAFkE,CAI/D;AACJ;AAED;AACF;AACA;AACA;AACA;AACA;;;AACuB,SAAd9C,cAAc,CAAC;AAAED,IAAAA,IAAF;AAAQgD,IAAAA;AAAR,GAAD,EAA8D;AACjF,QAAIA,WAAJ,EAAiB;AACf;AACA,YAAMM,SAAS,GAAGtD,IAAI,CAACgC,WAAL,EAAlB;AACA,aAAOsB,SAAS,CAACC,SAAV,CAAoB,CAApB,EAAuBD,SAAS,CAACH,OAAV,CAAkB,GAAlB,CAAvB,CAAP;AACD;;AACD,WAAOnD,IAAI,CAACgC,WAAL,EAAP;AACD;;AAnOyB;;;eAsObzD,c","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"]}
264
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/PushController.js"],"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","restQuery","method","RestQuery","Method","find","runBeforeFind","className","restWhere","buildRestWhere","then","write","RestWrite","runOptions","many","execute","pushStatus","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"],"mappings":"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","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"]}
@@ -64,7 +64,7 @@ class UserController extends _AdaptableController.default {
64
64
  }
65
65
  }
66
66
 
67
- verifyEmail(username, token) {
67
+ async verifyEmail(username, token) {
68
68
  if (!this.shouldVerifyEmails) {
69
69
  // Trying to verify email when not enabled
70
70
  // TODO: Better error here.
@@ -94,8 +94,15 @@ class UserController extends _AdaptableController.default {
94
94
  }
95
95
 
96
96
  const masterAuth = Auth.master(this.config);
97
- var findUserForEmailVerification = new RestQuery(this.config, Auth.master(this.config), '_User', {
98
- username: username
97
+ var findUserForEmailVerification = await RestQuery({
98
+ method: RestQuery.Method.get,
99
+ config: this.config,
100
+ runBeforeFind: false,
101
+ auth: Auth.master(this.config),
102
+ className: '_User',
103
+ restWhere: {
104
+ username
105
+ }
99
106
  });
100
107
  return findUserForEmailVerification.execute().then(result => {
101
108
  if (result.results.length && result.results[0].emailVerified) {
@@ -133,7 +140,7 @@ class UserController extends _AdaptableController.default {
133
140
  });
134
141
  }
135
142
 
136
- getUserIfNeeded(user) {
143
+ async getUserIfNeeded(user) {
137
144
  if (user.username && user.email) {
138
145
  return Promise.resolve(user);
139
146
  }
@@ -148,7 +155,14 @@ class UserController extends _AdaptableController.default {
148
155
  where.email = user.email;
149
156
  }
150
157
 
151
- var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);
158
+ var query = await RestQuery({
159
+ method: RestQuery.Method.get,
160
+ config: this.config,
161
+ runBeforeFind: false,
162
+ auth: Auth.master(this.config),
163
+ className: '_User',
164
+ restWhere: where
165
+ });
152
166
  return query.execute().then(function (result) {
153
167
  if (result.results.length != 1) {
154
168
  throw undefined;
@@ -378,4 +392,4 @@ function buildEmailLink(destination, username, token, config) {
378
392
 
379
393
  var _default = UserController;
380
394
  exports.default = _default;
381
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/UserController.js"],"names":["RestQuery","require","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","_email_verify_token","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","undefined","query","updateFields","__op","$gt","Date","masterAuth","master","findUserForEmailVerification","execute","then","result","results","length","Promise","resolve","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","email","where","sendVerificationEmail","encodeURIComponent","link","buildEmailLink","verifyEmailURL","appName","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","resendVerificationEmail","aUser","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL"],"mappings":"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","sourcesContent":["import { randomString } from '../cryptoUtils';\nimport { inflate } from '../triggers';\nimport AdaptableController from './AdaptableController';\nimport MailAdapter from '../Adapters/Email/MailAdapter';\nimport rest from '../rest';\nimport Parse from 'parse/node';\nimport AccountLockout from '../AccountLockout';\nimport Config from '../Config';\n\nvar RestQuery = require('../RestQuery');\nvar Auth = require('../Auth');\n\nexport class UserController extends AdaptableController {\n  constructor(adapter, appId, options = {}) {\n    super(adapter, appId, options);\n  }\n\n  get config() {\n    return Config.get(this.appId);\n  }\n\n  validateAdapter(adapter) {\n    // Allow no adapter\n    if (!adapter && !this.shouldVerifyEmails) {\n      return;\n    }\n    super.validateAdapter(adapter);\n  }\n\n  expectedAdapterType() {\n    return MailAdapter;\n  }\n\n  get shouldVerifyEmails() {\n    return this.options.verifyUserEmails;\n  }\n\n  setEmailVerifyToken(user) {\n    if (this.shouldVerifyEmails) {\n      user._email_verify_token = randomString(25);\n      user.emailVerified = false;\n\n      if (this.config.emailVerifyTokenValidityDuration) {\n        user._email_verify_token_expires_at = Parse._encode(\n          this.config.generateEmailVerifyTokenExpiresAt()\n        );\n      }\n    }\n  }\n\n  verifyEmail(username, token) {\n    if (!this.shouldVerifyEmails) {\n      // Trying to verify email when not enabled\n      // TODO: Better error here.\n      throw undefined;\n    }\n\n    const query = { username: username, _email_verify_token: token };\n    const updateFields = {\n      emailVerified: true,\n      _email_verify_token: { __op: 'Delete' },\n    };\n\n    // if the email verify token needs to be validated then\n    // add additional query params and additional fields that need to be updated\n    if (this.config.emailVerifyTokenValidityDuration) {\n      query.emailVerified = false;\n      query._email_verify_token_expires_at = { $gt: Parse._encode(new Date()) };\n\n      updateFields._email_verify_token_expires_at = { __op: 'Delete' };\n    }\n    const masterAuth = Auth.master(this.config);\n    var findUserForEmailVerification = new RestQuery(\n      this.config,\n      Auth.master(this.config),\n      '_User',\n      { username: username }\n    );\n    return findUserForEmailVerification.execute().then(result => {\n      if (result.results.length && result.results[0].emailVerified) {\n        return Promise.resolve(result.results.length[0]);\n      } else if (result.results.length) {\n        query.objectId = result.results[0].objectId;\n      }\n      return rest.update(this.config, masterAuth, '_User', query, updateFields);\n    });\n  }\n\n  checkResetTokenValidity(username, token) {\n    return this.config.database\n      .find(\n        '_User',\n        {\n          username: username,\n          _perishable_token: token,\n        },\n        { limit: 1 }\n      )\n      .then(results => {\n        if (results.length != 1) {\n          throw 'Failed to reset password: username / email / token is invalid';\n        }\n\n        if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n          let expiresDate = results[0]._perishable_token_expires_at;\n          if (expiresDate && expiresDate.__type == 'Date') {\n            expiresDate = new Date(expiresDate.iso);\n          }\n          if (expiresDate < new Date()) throw 'The password reset link has expired';\n        }\n        return results[0];\n      });\n  }\n\n  getUserIfNeeded(user) {\n    if (user.username && user.email) {\n      return Promise.resolve(user);\n    }\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n\n    var query = new RestQuery(this.config, Auth.master(this.config), '_User', where);\n    return query.execute().then(function (result) {\n      if (result.results.length != 1) {\n        throw undefined;\n      }\n      return result.results[0];\n    });\n  }\n\n  sendVerificationEmail(user) {\n    if (!this.shouldVerifyEmails) {\n      return;\n    }\n    const token = encodeURIComponent(user._email_verify_token);\n    // We may need to fetch the user in case of update email\n    this.getUserIfNeeded(user).then(user => {\n      const username = encodeURIComponent(user.username);\n\n      const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);\n      const options = {\n        appName: this.config.appName,\n        link: link,\n        user: inflate('_User', user),\n      };\n      if (this.adapter.sendVerificationEmail) {\n        this.adapter.sendVerificationEmail(options);\n      } else {\n        this.adapter.sendMail(this.defaultVerificationEmail(options));\n      }\n    });\n  }\n\n  /**\n   * Regenerates the given user's email verification token\n   *\n   * @param user\n   * @returns {*}\n   */\n  regenerateEmailVerifyToken(user) {\n    const { _email_verify_token } = user;\n    let { _email_verify_token_expires_at } = user;\n    if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {\n      _email_verify_token_expires_at = _email_verify_token_expires_at.iso;\n    }\n    if (\n      this.config.emailVerifyTokenReuseIfValid &&\n      this.config.emailVerifyTokenValidityDuration &&\n      _email_verify_token &&\n      new Date() < new Date(_email_verify_token_expires_at)\n    ) {\n      return Promise.resolve();\n    }\n    this.setEmailVerifyToken(user);\n    return this.config.database.update('_User', { username: user.username }, user);\n  }\n\n  resendVerificationEmail(username) {\n    return this.getUserIfNeeded({ username: username }).then(aUser => {\n      if (!aUser || aUser.emailVerified) {\n        throw undefined;\n      }\n      return this.regenerateEmailVerifyToken(aUser).then(() => {\n        this.sendVerificationEmail(aUser);\n      });\n    });\n  }\n\n  setPasswordResetToken(email) {\n    const token = { _perishable_token: randomString(25) };\n\n    if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n      token._perishable_token_expires_at = Parse._encode(\n        this.config.generatePasswordResetTokenExpiresAt()\n      );\n    }\n\n    return this.config.database.update(\n      '_User',\n      { $or: [{ email }, { username: email, email: { $exists: false } }] },\n      token,\n      {},\n      true\n    );\n  }\n\n  async sendPasswordResetEmail(email) {\n    if (!this.adapter) {\n      throw 'Trying to send a reset password but no adapter is set';\n      //  TODO: No adapter?\n    }\n    let user;\n    if (\n      this.config.passwordPolicy &&\n      this.config.passwordPolicy.resetTokenReuseIfValid &&\n      this.config.passwordPolicy.resetTokenValidityDuration\n    ) {\n      const results = await this.config.database.find(\n        '_User',\n        {\n          $or: [\n            { email, _perishable_token: { $exists: true } },\n            { username: email, email: { $exists: false }, _perishable_token: { $exists: true } },\n          ],\n        },\n        { limit: 1 }\n      );\n      if (results.length == 1) {\n        let expiresDate = results[0]._perishable_token_expires_at;\n        if (expiresDate && expiresDate.__type == 'Date') {\n          expiresDate = new Date(expiresDate.iso);\n        }\n        if (expiresDate > new Date()) {\n          user = results[0];\n        }\n      }\n    }\n    if (!user || !user._perishable_token) {\n      user = await this.setPasswordResetToken(email);\n    }\n    const token = encodeURIComponent(user._perishable_token);\n    const username = encodeURIComponent(user.username);\n\n    const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);\n    const options = {\n      appName: this.config.appName,\n      link: link,\n      user: inflate('_User', user),\n    };\n\n    if (this.adapter.sendPasswordResetEmail) {\n      this.adapter.sendPasswordResetEmail(options);\n    } else {\n      this.adapter.sendMail(this.defaultResetPasswordEmail(options));\n    }\n\n    return Promise.resolve(user);\n  }\n\n  updatePassword(username, token, password) {\n    return this.checkResetTokenValidity(username, token)\n      .then(user => updateUserPassword(user, password, this.config))\n      .then(user => {\n        const accountLockoutPolicy = new AccountLockout(user, this.config);\n        return accountLockoutPolicy.unlockAccount();\n      })\n      .catch(error => {\n        if (error && error.message) {\n          // in case of Parse.Error, fail with the error message only\n          return Promise.reject(error.message);\n        } else {\n          return Promise.reject(error);\n        }\n      });\n  }\n\n  defaultVerificationEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You are being asked to confirm the e-mail address ' +\n      user.get('email') +\n      ' with ' +\n      appName +\n      '\\n\\n' +\n      '' +\n      'Click here to confirm it:\\n' +\n      link;\n    const to = user.get('email');\n    const subject = 'Please verify your e-mail for ' + appName;\n    return { text, to, subject };\n  }\n\n  defaultResetPasswordEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You requested to reset your password for ' +\n      appName +\n      (user.get('username') ? \" (your username is '\" + user.get('username') + \"')\" : '') +\n      '.\\n\\n' +\n      '' +\n      'Click here to reset it:\\n' +\n      link;\n    const to = user.get('email') || user.get('username');\n    const subject = 'Password Reset for ' + appName;\n    return { text, to, subject };\n  }\n}\n\n// Mark this private\nfunction updateUserPassword(user, password, config) {\n  return rest\n    .update(\n      config,\n      Auth.master(config),\n      '_User',\n      { objectId: user.objectId },\n      {\n        password: password,\n      }\n    )\n    .then(() => user);\n}\n\nfunction buildEmailLink(destination, username, token, config) {\n  const usernameAndToken = `token=${token}&username=${username}`;\n\n  if (config.parseFrameURL) {\n    const destinationWithoutHost = destination.replace(config.publicServerURL, '');\n\n    return `${config.parseFrameURL}?link=${encodeURIComponent(\n      destinationWithoutHost\n    )}&${usernameAndToken}`;\n  } else {\n    return `${destination}?${usernameAndToken}`;\n  }\n}\n\nexport default UserController;\n"]}
395
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/UserController.js"],"names":["RestQuery","require","Auth","UserController","AdaptableController","constructor","adapter","appId","options","config","Config","get","validateAdapter","shouldVerifyEmails","expectedAdapterType","MailAdapter","verifyUserEmails","setEmailVerifyToken","user","_email_verify_token","emailVerified","emailVerifyTokenValidityDuration","_email_verify_token_expires_at","Parse","_encode","generateEmailVerifyTokenExpiresAt","verifyEmail","username","token","undefined","query","updateFields","__op","$gt","Date","masterAuth","master","findUserForEmailVerification","method","Method","runBeforeFind","auth","className","restWhere","execute","then","result","results","length","Promise","resolve","objectId","rest","update","checkResetTokenValidity","database","find","_perishable_token","limit","passwordPolicy","resetTokenValidityDuration","expiresDate","_perishable_token_expires_at","__type","iso","getUserIfNeeded","email","where","sendVerificationEmail","encodeURIComponent","link","buildEmailLink","verifyEmailURL","appName","sendMail","defaultVerificationEmail","regenerateEmailVerifyToken","emailVerifyTokenReuseIfValid","resendVerificationEmail","aUser","setPasswordResetToken","generatePasswordResetTokenExpiresAt","$or","$exists","sendPasswordResetEmail","resetTokenReuseIfValid","requestResetPasswordURL","defaultResetPasswordEmail","updatePassword","password","updateUserPassword","accountLockoutPolicy","AccountLockout","unlockAccount","catch","error","message","reject","text","to","subject","destination","usernameAndToken","parseFrameURL","destinationWithoutHost","replace","publicServerURL"],"mappings":"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","sourcesContent":["import { randomString } from '../cryptoUtils';\nimport { inflate } from '../triggers';\nimport AdaptableController from './AdaptableController';\nimport MailAdapter from '../Adapters/Email/MailAdapter';\nimport rest from '../rest';\nimport Parse from 'parse/node';\nimport AccountLockout from '../AccountLockout';\nimport Config from '../Config';\n\nvar RestQuery = require('../RestQuery');\nvar Auth = require('../Auth');\n\nexport class UserController extends AdaptableController {\n  constructor(adapter, appId, options = {}) {\n    super(adapter, appId, options);\n  }\n\n  get config() {\n    return Config.get(this.appId);\n  }\n\n  validateAdapter(adapter) {\n    // Allow no adapter\n    if (!adapter && !this.shouldVerifyEmails) {\n      return;\n    }\n    super.validateAdapter(adapter);\n  }\n\n  expectedAdapterType() {\n    return MailAdapter;\n  }\n\n  get shouldVerifyEmails() {\n    return this.options.verifyUserEmails;\n  }\n\n  setEmailVerifyToken(user) {\n    if (this.shouldVerifyEmails) {\n      user._email_verify_token = randomString(25);\n      user.emailVerified = false;\n\n      if (this.config.emailVerifyTokenValidityDuration) {\n        user._email_verify_token_expires_at = Parse._encode(\n          this.config.generateEmailVerifyTokenExpiresAt()\n        );\n      }\n    }\n  }\n\n  async verifyEmail(username, token) {\n    if (!this.shouldVerifyEmails) {\n      // Trying to verify email when not enabled\n      // TODO: Better error here.\n      throw undefined;\n    }\n\n    const query = { username: username, _email_verify_token: token };\n    const updateFields = {\n      emailVerified: true,\n      _email_verify_token: { __op: 'Delete' },\n    };\n\n    // if the email verify token needs to be validated then\n    // add additional query params and additional fields that need to be updated\n    if (this.config.emailVerifyTokenValidityDuration) {\n      query.emailVerified = false;\n      query._email_verify_token_expires_at = { $gt: Parse._encode(new Date()) };\n\n      updateFields._email_verify_token_expires_at = { __op: 'Delete' };\n    }\n    const masterAuth = Auth.master(this.config);\n    var findUserForEmailVerification = await RestQuery({\n      method: RestQuery.Method.get,\n      config: this.config,\n      runBeforeFind: false,\n      auth: Auth.master(this.config),\n      className: '_User',\n      restWhere: { username },\n    });\n    return findUserForEmailVerification.execute().then(result => {\n      if (result.results.length && result.results[0].emailVerified) {\n        return Promise.resolve(result.results.length[0]);\n      } else if (result.results.length) {\n        query.objectId = result.results[0].objectId;\n      }\n      return rest.update(this.config, masterAuth, '_User', query, updateFields);\n    });\n  }\n\n  checkResetTokenValidity(username, token) {\n    return this.config.database\n      .find(\n        '_User',\n        {\n          username: username,\n          _perishable_token: token,\n        },\n        { limit: 1 }\n      )\n      .then(results => {\n        if (results.length != 1) {\n          throw 'Failed to reset password: username / email / token is invalid';\n        }\n\n        if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n          let expiresDate = results[0]._perishable_token_expires_at;\n          if (expiresDate && expiresDate.__type == 'Date') {\n            expiresDate = new Date(expiresDate.iso);\n          }\n          if (expiresDate < new Date()) throw 'The password reset link has expired';\n        }\n        return results[0];\n      });\n  }\n\n  async getUserIfNeeded(user) {\n    if (user.username && user.email) {\n      return Promise.resolve(user);\n    }\n    var where = {};\n    if (user.username) {\n      where.username = user.username;\n    }\n    if (user.email) {\n      where.email = user.email;\n    }\n\n    var query = await RestQuery({\n      method: RestQuery.Method.get,\n      config: this.config,\n      runBeforeFind: false,\n      auth: Auth.master(this.config),\n      className: '_User',\n      restWhere: where,\n    });\n    return query.execute().then(function (result) {\n      if (result.results.length != 1) {\n        throw undefined;\n      }\n      return result.results[0];\n    });\n  }\n\n  sendVerificationEmail(user) {\n    if (!this.shouldVerifyEmails) {\n      return;\n    }\n    const token = encodeURIComponent(user._email_verify_token);\n    // We may need to fetch the user in case of update email\n    this.getUserIfNeeded(user).then(user => {\n      const username = encodeURIComponent(user.username);\n\n      const link = buildEmailLink(this.config.verifyEmailURL, username, token, this.config);\n      const options = {\n        appName: this.config.appName,\n        link: link,\n        user: inflate('_User', user),\n      };\n      if (this.adapter.sendVerificationEmail) {\n        this.adapter.sendVerificationEmail(options);\n      } else {\n        this.adapter.sendMail(this.defaultVerificationEmail(options));\n      }\n    });\n  }\n\n  /**\n   * Regenerates the given user's email verification token\n   *\n   * @param user\n   * @returns {*}\n   */\n  regenerateEmailVerifyToken(user) {\n    const { _email_verify_token } = user;\n    let { _email_verify_token_expires_at } = user;\n    if (_email_verify_token_expires_at && _email_verify_token_expires_at.__type === 'Date') {\n      _email_verify_token_expires_at = _email_verify_token_expires_at.iso;\n    }\n    if (\n      this.config.emailVerifyTokenReuseIfValid &&\n      this.config.emailVerifyTokenValidityDuration &&\n      _email_verify_token &&\n      new Date() < new Date(_email_verify_token_expires_at)\n    ) {\n      return Promise.resolve();\n    }\n    this.setEmailVerifyToken(user);\n    return this.config.database.update('_User', { username: user.username }, user);\n  }\n\n  resendVerificationEmail(username) {\n    return this.getUserIfNeeded({ username: username }).then(aUser => {\n      if (!aUser || aUser.emailVerified) {\n        throw undefined;\n      }\n      return this.regenerateEmailVerifyToken(aUser).then(() => {\n        this.sendVerificationEmail(aUser);\n      });\n    });\n  }\n\n  setPasswordResetToken(email) {\n    const token = { _perishable_token: randomString(25) };\n\n    if (this.config.passwordPolicy && this.config.passwordPolicy.resetTokenValidityDuration) {\n      token._perishable_token_expires_at = Parse._encode(\n        this.config.generatePasswordResetTokenExpiresAt()\n      );\n    }\n\n    return this.config.database.update(\n      '_User',\n      { $or: [{ email }, { username: email, email: { $exists: false } }] },\n      token,\n      {},\n      true\n    );\n  }\n\n  async sendPasswordResetEmail(email) {\n    if (!this.adapter) {\n      throw 'Trying to send a reset password but no adapter is set';\n      //  TODO: No adapter?\n    }\n    let user;\n    if (\n      this.config.passwordPolicy &&\n      this.config.passwordPolicy.resetTokenReuseIfValid &&\n      this.config.passwordPolicy.resetTokenValidityDuration\n    ) {\n      const results = await this.config.database.find(\n        '_User',\n        {\n          $or: [\n            { email, _perishable_token: { $exists: true } },\n            { username: email, email: { $exists: false }, _perishable_token: { $exists: true } },\n          ],\n        },\n        { limit: 1 }\n      );\n      if (results.length == 1) {\n        let expiresDate = results[0]._perishable_token_expires_at;\n        if (expiresDate && expiresDate.__type == 'Date') {\n          expiresDate = new Date(expiresDate.iso);\n        }\n        if (expiresDate > new Date()) {\n          user = results[0];\n        }\n      }\n    }\n    if (!user || !user._perishable_token) {\n      user = await this.setPasswordResetToken(email);\n    }\n    const token = encodeURIComponent(user._perishable_token);\n    const username = encodeURIComponent(user.username);\n\n    const link = buildEmailLink(this.config.requestResetPasswordURL, username, token, this.config);\n    const options = {\n      appName: this.config.appName,\n      link: link,\n      user: inflate('_User', user),\n    };\n\n    if (this.adapter.sendPasswordResetEmail) {\n      this.adapter.sendPasswordResetEmail(options);\n    } else {\n      this.adapter.sendMail(this.defaultResetPasswordEmail(options));\n    }\n\n    return Promise.resolve(user);\n  }\n\n  updatePassword(username, token, password) {\n    return this.checkResetTokenValidity(username, token)\n      .then(user => updateUserPassword(user, password, this.config))\n      .then(user => {\n        const accountLockoutPolicy = new AccountLockout(user, this.config);\n        return accountLockoutPolicy.unlockAccount();\n      })\n      .catch(error => {\n        if (error && error.message) {\n          // in case of Parse.Error, fail with the error message only\n          return Promise.reject(error.message);\n        } else {\n          return Promise.reject(error);\n        }\n      });\n  }\n\n  defaultVerificationEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You are being asked to confirm the e-mail address ' +\n      user.get('email') +\n      ' with ' +\n      appName +\n      '\\n\\n' +\n      '' +\n      'Click here to confirm it:\\n' +\n      link;\n    const to = user.get('email');\n    const subject = 'Please verify your e-mail for ' + appName;\n    return { text, to, subject };\n  }\n\n  defaultResetPasswordEmail({ link, user, appName }) {\n    const text =\n      'Hi,\\n\\n' +\n      'You requested to reset your password for ' +\n      appName +\n      (user.get('username') ? \" (your username is '\" + user.get('username') + \"')\" : '') +\n      '.\\n\\n' +\n      '' +\n      'Click here to reset it:\\n' +\n      link;\n    const to = user.get('email') || user.get('username');\n    const subject = 'Password Reset for ' + appName;\n    return { text, to, subject };\n  }\n}\n\n// Mark this private\nfunction updateUserPassword(user, password, config) {\n  return rest\n    .update(\n      config,\n      Auth.master(config),\n      '_User',\n      { objectId: user.objectId },\n      {\n        password: password,\n      }\n    )\n    .then(() => user);\n}\n\nfunction buildEmailLink(destination, username, token, config) {\n  const usernameAndToken = `token=${token}&username=${username}`;\n\n  if (config.parseFrameURL) {\n    const destinationWithoutHost = destination.replace(config.publicServerURL, '');\n\n    return `${config.parseFrameURL}?link=${encodeURIComponent(\n      destinationWithoutHost\n    )}&${usernameAndToken}`;\n  } else {\n    return `${destination}?${usernameAndToken}`;\n  }\n}\n\nexport default UserController;\n"]}