// // PFInstallation.h // Parse // // Created by Brian Jacokes on 6/4/12. // Copyright (c) 2012 Parse, Inc. All rights reserved. // #import #import "PFObject.h" #import "PFSubclassing.h" /*! A Parse Framework Installation Object that is a local representation of an installation persisted to the Parse cloud. This class is a subclass of a PFObject, and retains the same functionality of a PFObject, but also extends it with installation-specific fields and related immutability and validity checks. A valid PFInstallation can only be instantiated via [PFInstallation currentInstallation] because the required identifier fields are readonly. The timeZone and badge fields are also readonly properties which are automatically updated to match the device's time zone and application badge when the PFInstallation is saved, thus these fields might not reflect the latest device state if the installation has not recently been saved. PFInstallation objects which have a valid deviceToken and are saved to the Parse cloud can be used to target push notifications. This class is currently for iOS only. There is no PFInstallation for Parse applications running on OS X, because they cannot receive push notifications. */ @interface PFInstallation : PFObject /*! The name of the Installation class in the REST API. This is a required * PFSubclassing method */ + (NSString *)parseClassName; /** @name Targeting Installations */ /*! Creates a query for PFInstallation objects. The resulting query can only be used for targeting a PFPush. Calling find methods on the resulting query will raise an exception. */ + (PFQuery *)query; /** @name Accessing the Current Installation */ /*! Gets the currently-running installation from disk and returns an instance of it. If this installation is not stored on disk, returns a PFInstallation with deviceType and installationId fields set to those of the current installation. @result Returns a PFInstallation that represents the currently-running installation. */ + (instancetype)currentInstallation; /*! Sets the device token string property from an NSData-encoded token. @param deviceTokenData A token that identifies the device. */ - (void)setDeviceTokenFromData:(NSData *)deviceTokenData; /** @name Properties */ /// The device type for the PFInstallation. @property (nonatomic, strong, readonly) NSString *deviceType; /// The installationId for the PFInstallation. @property (nonatomic, strong, readonly) NSString *installationId; /// The device token for the PFInstallation. @property (nonatomic, strong) NSString *deviceToken; /// The badge for the PFInstallation. @property (nonatomic, assign) NSInteger badge; /// The timeZone for the PFInstallation. @property (nonatomic, strong, readonly) NSString *timeZone; /// The channels for the PFInstallation. @property (nonatomic, strong) NSArray *channels; @end