| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 | "use strict";Object.defineProperty(exports, "__esModule", {  value: true});exports.getPushStatus = getPushStatus;exports.send = send;var _CoreManager = _interopRequireDefault(require("./CoreManager"));var _ParseQuery = _interopRequireDefault(require("./ParseQuery"));function _interopRequireDefault(obj) {  return obj && obj.__esModule ? obj : {    default: obj  };}/** * @flow *//*:: import type { WhereClause } from './ParseQuery';*//*:: import type { FullOptions } from './RESTController';*//*:: export type PushData = {  where?: WhereClause | ParseQuery,  push_time?: Date | string,  expiration_time?: Date | string,  expiration_interval?: number,};*//** * Contains functions to deal with Push in Parse. * * @class Parse.Push * @static * @hideconstructor *//** * Sends a push notification. * **Available in Cloud Code only.** * * See {@link https://docs.parseplatform.org/js/guide/#push-notifications Push Notification Guide} * * @function send * @name Parse.Push.send * @param {object} data -  The data of the push notification. Valid fields * are: *   <ol> *     <li>channels - An Array of channels to push to.</li> *     <li>push_time - A Date object for when to send the push.</li> *     <li>expiration_time -  A Date object for when to expire *         the push.</li> *     <li>expiration_interval - The seconds from now to expire the push.</li> *     <li>where - A Parse.Query over Parse.Installation that is used to match *         a set of installations to push to.</li> *     <li>data - The data to send as part of the push.</li> *   <ol> * @param {object} options Valid options * are:<ul> *   <li>useMasterKey: In Cloud Code and Node only, causes the Master Key to *     be used for this request. * </ul> * @returns {Promise} A promise that is fulfilled when the push request *     completes. */function send(data /*: PushData*/, options /*:: ?: FullOptions*/ = {}) /*: Promise*/{  if (data.where && data.where instanceof _ParseQuery.default) {    data.where = data.where.toJSON().where;  }  if (data.push_time && typeof data.push_time === 'object') {    data.push_time = data.push_time.toJSON();  }  if (data.expiration_time && typeof data.expiration_time === 'object') {    data.expiration_time = data.expiration_time.toJSON();  }  if (data.expiration_time && data.expiration_interval) {    throw new Error('expiration_time and expiration_interval cannot both be set.');  }  const pushOptions = {    useMasterKey: true  };  if (options.hasOwnProperty('useMasterKey')) {    pushOptions.useMasterKey = options.useMasterKey;  }  return _CoreManager.default.getPushController().send(data, pushOptions);}/** * Gets push status by Id * * @function getPushStatus * @name Parse.Push.getPushStatus * @param {string} pushStatusId The Id of Push Status. * @param {object} options Valid options * are:<ul> *   <li>useMasterKey: In Cloud Code and Node only, causes the Master Key to *     be used for this request. * </ul> * @returns {Parse.Object} Status of Push. */function getPushStatus(pushStatusId /*: string*/, options /*:: ?: FullOptions*/ = {}) /*: Promise<string>*/{  const pushOptions = {    useMasterKey: true  };  if (options.hasOwnProperty('useMasterKey')) {    pushOptions.useMasterKey = options.useMasterKey;  }  const query = new _ParseQuery.default('_PushStatus');  return query.get(pushStatusId, pushOptions);}const DefaultController = {  send(data /*: PushData*/, options /*:: ?: FullOptions*/) {    return _CoreManager.default.getRESTController().request('POST', 'push', data, options);  }};_CoreManager.default.setPushController(DefaultController);
 |