"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:
*
* - channels - An Array of channels to push to.
* - push_time - A Date object for when to send the push.
* - expiration_time - A Date object for when to expire
* the push.
* - expiration_interval - The seconds from now to expire the push.
* - where - A Parse.Query over Parse.Installation that is used to match
* a set of installations to push to.
* - data - The data to send as part of the push
*
* @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);