You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

543 lines
21 KiB

/**
* 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.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
#import <Parse/PFInstallation.h>
PF_TV_UNAVAILABLE_WARNING
PF_WATCH_UNAVAILABLE_WARNING
@class PFQuery PF_GENERIC(PFGenericObject : PFObject *);
NS_ASSUME_NONNULL_BEGIN
/**
The `PFPush` class defines a push notification that can be sent from a client device.
The preferred way of modifying or retrieving channel subscriptions is to use
the `PFInstallation` class, instead of the class methods in `PFPush`.
*/
PF_TV_UNAVAILABLE PF_WATCH_UNAVAILABLE @interface PFPush : NSObject <NSCopying>
///--------------------------------------
/// @name Creating a Push Notification
///--------------------------------------
+ (instancetype)push;
///--------------------------------------
/// @name Configuring a Push Notification
///--------------------------------------
/**
Sets the channel on which this push notification will be sent.
@param channel The channel to set for this push.
The channel name must start with a letter and contain only letters, numbers, dashes, and underscores.
*/
- (void)setChannel:(nullable NSString *)channel;
/**
Sets the array of channels on which this push notification will be sent.
@param channels The array of channels to set for this push.
Each channel name must start with a letter and contain only letters, numbers, dashes, and underscores.
*/
- (void)setChannels:(nullable NSArray PF_GENERIC(NSString *)*)channels;
/**
Sets an installation query to which this push notification will be sent.
The query should be created via `PFInstallation.+query` and should not specify a skip, limit, or order.
@param query The installation query to set for this push.
*/
- (void)setQuery:(nullable PFQuery PF_GENERIC(PFInstallation *)*)query;
/**
Sets an alert message for this push notification.
@warning This will overwrite any data specified in setData.
@param message The message to send in this push.
*/
- (void)setMessage:(nullable NSString *)message;
/**
Sets an arbitrary data payload for this push notification.
See the guide for information about the dictionary structure.
@warning This will overwrite any data specified in setMessage.
@param data The data to send in this push.
*/
- (void)setData:(nullable NSDictionary *)data;
/**
Sets whether this push will go to Android devices.
@param pushToAndroid Whether this push will go to Android devices.
@deprecated Please use a `PFInstallation.+query` with a constraint on deviceType instead.
*/
- (void)setPushToAndroid:(BOOL)pushToAndroid PARSE_DEPRECATED("Please use a [PFInstallation query] with a constraint on deviceType. This method is deprecated and won't do anything.");
/**
Sets whether this push will go to iOS devices.
@param pushToIOS Whether this push will go to iOS devices.
@deprecated Please use a `PFInstallation.+query` with a constraint on deviceType instead.
*/
- (void)setPushToIOS:(BOOL)pushToIOS PARSE_DEPRECATED("Please use a [PFInstallation query] with a constraint on deviceType. This method is deprecated and won't do anything.");
/**
Sets the expiration time for this notification.
The notification will be sent to devices which are either online
at the time the notification is sent, or which come online before the expiration time is reached.
Because device clocks are not guaranteed to be accurate,
most applications should instead use `-expireAfterTimeInterval:`.
@see expireAfterTimeInterval:
@param date The time at which the notification should expire.
*/
- (void)expireAtDate:(nullable NSDate *)date;
/**
Sets the time interval after which this notification should expire.
This notification will be sent to devices which are either online at
the time the notification is sent, or which come online within the given
time interval of the notification being received by Parse's server.
An interval which is less than or equal to zero indicates that the
message should only be sent to devices which are currently online.
@param timeInterval The interval after which the notification should expire.
*/
- (void)expireAfterTimeInterval:(NSTimeInterval)timeInterval;
/**
Clears both expiration values, indicating that the notification should never expire.
*/
- (void)clearExpiration;
/**
Date at which to send this push notification.
Push notificaitons with this date will be delivered at the local time matching the `PFInstallation.timeZone`.
@warning The date cannot be in the past, and can be up to two weeks in the future.
*/
@property (nullable, nonatomic, strong) NSDate *pushDate;
///--------------------------------------
/// @name Sending Push Notifications
///--------------------------------------
/**
*Synchronously* send a push message to a channel.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param message The message to send.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the send succeeded.
*/
+ (BOOL)sendPushMessageToChannel:(NSString *)channel
withMessage:(NSString *)message
error:(NSError **)error;
/**
*Asynchronously* send a push message to a channel.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param message The message to send.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)sendPushMessageToChannelInBackground:(NSString *)channel
withMessage:(NSString *)message;
/**
*Asynchronously* sends a push message to a channel and calls the given block.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param message The message to send.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)sendPushMessageToChannelInBackground:(NSString *)channel
withMessage:(NSString *)message
block:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* send a push message to a channel.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param message The message to send.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)sendPushMessageToChannelInBackground:(NSString *)channel
withMessage:(NSString *)message
target:(__nullable id)target
selector:(__nullable SEL)selector;
/**
Send a push message to a query.
@param query The query to send to. The query must be a `PFInstallation` query created with `PFInstallation.+query`.
@param message The message to send.
@param error Pointer to an NSError that will be set if necessary.
@return Returns whether the send succeeded.
*/
+ (BOOL)sendPushMessageToQuery:(PFQuery PF_GENERIC(PFInstallation *)*)query
withMessage:(NSString *)message
error:(NSError **)error;
/**
*Asynchronously* send a push message to a query.
@param query The query to send to. The query must be a `PFInstallation` query created with `PFInstallation.+query`.
@param message The message to send.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)sendPushMessageToQueryInBackground:(PFQuery PF_GENERIC(PFInstallation *)*)query
withMessage:(NSString *)message;
/**
*Asynchronously* sends a push message to a query and calls the given block.
@param query The query to send to. The query must be a PFInstallation query
created with [PFInstallation query].
@param message The message to send.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)sendPushMessageToQueryInBackground:(PFQuery PF_GENERIC(PFInstallation *)*)query
withMessage:(NSString *)message
block:(nullable PFBooleanResultBlock)block;
/**
*Synchronously* send this push message.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the send succeeded.
*/
- (BOOL)sendPush:(NSError **)error;
/**
*Asynchronously* send this push message.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSNumber *)*)sendPushInBackground;
/**
*Asynchronously* send this push message and executes the given callback block.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
- (void)sendPushInBackgroundWithBlock:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* send this push message and calls the given callback.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
- (void)sendPushInBackgroundWithTarget:(__nullable id)target selector:(__nullable SEL)selector;
/**
*Synchronously* send a push message with arbitrary data to a channel.
See the guide for information about the dictionary structure.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param data The data to send.
@param error Pointer to an NSError that will be set if necessary.
@return Returns whether the send succeeded.
*/
+ (BOOL)sendPushDataToChannel:(NSString *)channel
withData:(NSDictionary *)data
error:(NSError **)error;
/**
*Asynchronously* send a push message with arbitrary data to a channel.
See the guide for information about the dictionary structure.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param data The data to send.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)sendPushDataToChannelInBackground:(NSString *)channel
withData:(NSDictionary *)data;
/**
Asynchronously sends a push message with arbitrary data to a channel and calls the given block.
See the guide for information about the dictionary structure.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param data The data to send.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
+ (void)sendPushDataToChannelInBackground:(NSString *)channel
withData:(NSDictionary *)data
block:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* send a push message with arbitrary data to a channel.
See the guide for information about the dictionary structure.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param data The data to send.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)sendPushDataToChannelInBackground:(NSString *)channel
withData:(NSDictionary *)data
target:(__nullable id)target
selector:(__nullable SEL)selector;
/**
*Synchronously* send a push message with arbitrary data to a query.
See the guide for information about the dictionary structure.
@param query The query to send to. The query must be a `PFInstallation` query
created with `PFInstallation.+query`.
@param data The data to send.
@param error Pointer to an NSError that will be set if necessary.
@return Returns whether the send succeeded.
*/
+ (BOOL)sendPushDataToQuery:(PFQuery PF_GENERIC(PFInstallation *)*)query
withData:(NSDictionary *)data
error:(NSError **)error;
/**
Asynchronously send a push message with arbitrary data to a query.
See the guide for information about the dictionary structure.
@param query The query to send to. The query must be a `PFInstallation` query
created with `PFInstallation.+query`.
@param data The data to send.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)sendPushDataToQueryInBackground:(PFQuery PF_GENERIC(PFInstallation *)*)query
withData:(NSDictionary *)data;
/**
*Asynchronously* sends a push message with arbitrary data to a query and calls the given block.
See the guide for information about the dictionary structure.
@param query The query to send to. The query must be a `PFInstallation` query
created with `PFInstallation.+query`.
@param data The data to send.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
+ (void)sendPushDataToQueryInBackground:(PFQuery PF_GENERIC(PFInstallation *)*)query
withData:(NSDictionary *)data
block:(nullable PFBooleanResultBlock)block;
///--------------------------------------
/// @name Handling Notifications
///--------------------------------------
/**
A default handler for push notifications while the app is active that
could be used to mimic the behavior of iOS push notifications while the app is backgrounded or not running.
Call this from `application:didReceiveRemoteNotification:`.
If push has a dictionary containing loc-key and loc-args in the alert,
we support up to 10 items in loc-args (`NSRangeException` if limit exceeded).
@warning This method is available only on iOS.
@param userInfo The userInfo dictionary you get in `appplication:didReceiveRemoteNotification:`.
*/
+ (void)handlePush:(nullable NSDictionary *)userInfo NS_AVAILABLE_IOS(3_0) PF_EXTENSION_UNAVAILABLE("");
///--------------------------------------
/// @name Managing Channel Subscriptions
///--------------------------------------
/**
Store the device token locally for push notifications.
Usually called from you main app delegate's `didRegisterForRemoteNotificationsWithDeviceToken:`.
@param deviceToken Either as an `NSData` straight from `application:didRegisterForRemoteNotificationsWithDeviceToken:`
or as an `NSString` if you converted it yourself.
*/
+ (void)storeDeviceToken:(id)deviceToken;
/**
*Synchronously* get all the channels that this device is subscribed to.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns an `NSSet` containing all the channel names this device is subscribed to.
*/
+ (nullable NSSet PF_GENERIC(NSString *)*)getSubscribedChannels:(NSError **)error;
/**
*Asynchronously* get all the channels that this device is subscribed to.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSSet<NSString *> *)*)getSubscribedChannelsInBackground;
/**
*Asynchronously* get all the channels that this device is subscribed to.
@param block The block to execute.
It should have the following argument signature: `^(NSSet *channels, NSError *error)`.
*/
+ (void)getSubscribedChannelsInBackgroundWithBlock:(PFSetResultBlock)block;
/*
*Asynchronously* get all the channels that this device is subscribed to.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSSet *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
*/
+ (void)getSubscribedChannelsInBackgroundWithTarget:(id)target selector:(SEL)selector;
/**
*Synchrnously* subscribes the device to a channel of push notifications.
@param channel The channel to subscribe to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the subscribe succeeded.
*/
+ (BOOL)subscribeToChannel:(NSString *)channel error:(NSError **)error;
/**
*Asynchronously* subscribes the device to a channel of push notifications.
@param channel The channel to subscribe to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)subscribeToChannelInBackground:(NSString *)channel;
/**
*Asynchronously* subscribes the device to a channel of push notifications and calls the given block.
@param channel The channel to subscribe to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)subscribeToChannelInBackground:(NSString *)channel
block:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* subscribes the device to a channel of push notifications and calls the given callback.
@param channel The channel to subscribe to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)subscribeToChannelInBackground:(NSString *)channel
target:(nullable id)target
selector:(nullable SEL)selector;
/**
*Synchronously* unsubscribes the device to a channel of push notifications.
@param channel The channel to unsubscribe from.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the unsubscribe succeeded.
*/
+ (BOOL)unsubscribeFromChannel:(NSString *)channel error:(NSError **)error;
/**
*Asynchronously* unsubscribes the device from a channel of push notifications.
@param channel The channel to unsubscribe from.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)unsubscribeFromChannelInBackground:(NSString *)channel;
/**
*Asynchronously* unsubscribes the device from a channel of push notifications and calls the given block.
@param channel The channel to unsubscribe from.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
+ (void)unsubscribeFromChannelInBackground:(NSString *)channel
block:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* unsubscribes the device from a channel of push notifications and calls the given callback.
@param channel The channel to unsubscribe from.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)unsubscribeFromChannelInBackground:(NSString *)channel
target:(nullable id)target
selector:(nullable SEL)selector;
@end
NS_ASSUME_NONNULL_END