123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.send = send;
- var _CoreManager = _interopRequireDefault(require("./CoreManager"));
- var _ParseQuery = _interopRequireDefault(require("./ParseQuery"));
- function _interopRequireDefault(obj) {
- return obj && obj.__esModule ? obj : {
- default: obj
- };
- }
- /**
- * Copyright (c) 2015-present, Parse, LLC.
- * All rights reserved.
- *
- * This source code is licensed under the BSD-style license found in the
- * LICENSE file in the root directory of this source tree. An additional grant
- * of patent rights can be found in the PATENTS file in the same directory.
- *
- * @flow
- */
- /**
- * Contains functions to deal with Push in Parse.
- * @class Parse.Push
- * @static
- * @hideconstructor
- */
- /**
- * Sends a push notification.
- * @method 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 An object that has an optional success function,
- * that takes no arguments and will be called on a successful push, and
- * an error function that takes a Parse.Error and will be called if the push
- * failed.
- * @return {Promise} A promise that is fulfilled when the push request
- * completes.
- */
- function send(data
- /*: PushData*/
- , options
- /*:: ?: { useMasterKey?: boolean, success?: any, error?: any }*/
- )
- /*: Promise*/
- {
- options = options || {};
- 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.');
- }
- return _CoreManager.default.getPushController().send(data, {
- useMasterKey: options.useMasterKey
- });
- }
- const DefaultController = {
- send(data
- /*: PushData*/
- , options
- /*: RequestOptions*/
- ) {
- const RESTController = _CoreManager.default.getRESTController();
- const request = RESTController.request('POST', 'push', data, {
- useMasterKey: !!options.useMasterKey
- });
- return request;
- }
- };
- _CoreManager.default.setPushController(DefaultController);
|