Okechi Onyeje 544a7baa87 Working on posting a listing to ebay
Paypal sandbox account not linking, so cannot proceed until able to get this working
2016-08-17 10:22:15 -04:00

319 lines
16 KiB
Objective-C
Executable File

/*
* Firebase iOS Client Library
*
* Copyright © 2013 Firebase - All Rights Reserved
* https://www.firebase.com
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* 2. Redistributions in binaryform must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY FIREBASE AS IS AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
* EVENT SHALL FIREBASE BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#import <Foundation/Foundation.h>
#import "FIRDataEventType.h"
#import "FIRDataSnapshot.h"
NS_ASSUME_NONNULL_BEGIN
typedef NSUInteger FIRDatabaseHandle;
/**
* A FIRDatabaseQuery instance represents a query over the data at a particular location.
*
* You create one by calling one of the query methods (queryOrderedByChild:, queryStartingAtValue:, etc.)
* on a FIRDatabaseReference. The query methods can be chained to further specify the data you are interested in
* observing
*/
@interface FIRDatabaseQuery : NSObject
/** @name Attach observers to read data */
/**
* observeEventType:withBlock: is used to listen for data changes at a particular location.
* This is the primary way to read data from the Firebase Database. Your block will be triggered
* for the initial data and again whenever the data changes.
*
* Use removeObserverWithHandle: to stop receiving updates.
* @param eventType The type of event to listen for.
* @param block The block that should be called with initial data and updates. It is passed the data as a FIRDataSnapshot.
* @return A handle used to unregister this block later using removeObserverWithHandle:
*/
- (FIRDatabaseHandle)observeEventType:(FIRDataEventType)eventType withBlock:(void (^)(FIRDataSnapshot *snapshot))block;
/**
* observeEventType:andPreviousSiblingKeyWithBlock: is used to listen for data changes at a particular location.
* This is the primary way to read data from the Firebase Database. Your block will be triggered
* for the initial data and again whenever the data changes. In addition, for FIRDataEventTypeChildAdded, FIRDataEventTypeChildMoved, and
* FIRDataEventTypeChildChanged events, your block will be passed the key of the previous node by priority order.
*
* Use removeObserverWithHandle: to stop receiving updates.
*
* @param eventType The type of event to listen for.
* @param block The block that should be called with initial data and updates. It is passed the data as a FIRDataSnapshot
* and the previous child's key.
* @return A handle used to unregister this block later using removeObserverWithHandle:
*/
- (FIRDatabaseHandle)observeEventType:(FIRDataEventType)eventType andPreviousSiblingKeyWithBlock:(void (^)(FIRDataSnapshot *snapshot, NSString *__nullable prevKey))block;
/**
* observeEventType:withBlock: is used to listen for data changes at a particular location.
* This is the primary way to read data from the Firebase Database. Your block will be triggered
* for the initial data and again whenever the data changes.
*
* The cancelBlock will be called if you will no longer receive new events due to no longer having permission.
*
* Use removeObserverWithHandle: to stop receiving updates.
*
* @param eventType The type of event to listen for.
* @param block The block that should be called with initial data and updates. It is passed the data as a FIRDataSnapshot.
* @param cancelBlock The block that should be called if this client no longer has permission to receive these events
* @return A handle used to unregister this block later using removeObserverWithHandle:
*/
- (FIRDatabaseHandle)observeEventType:(FIRDataEventType)eventType withBlock:(void (^)(FIRDataSnapshot *snapshot))block withCancelBlock:(nullable void (^)(NSError* error))cancelBlock;
/**
* observeEventType:andPreviousSiblingKeyWithBlock: is used to listen for data changes at a particular location.
* This is the primary way to read data from the Firebase Database. Your block will be triggered
* for the initial data and again whenever the data changes. In addition, for FIRDataEventTypeChildAdded, FIRDataEventTypeChildMoved, and
* FIRDataEventTypeChildChanged events, your block will be passed the key of the previous node by priority order.
*
* The cancelBlock will be called if you will no longer receive new events due to no longer having permission.
*
* Use removeObserverWithHandle: to stop receiving updates.
*
* @param eventType The type of event to listen for.
* @param block The block that should be called with initial data and updates. It is passed the data as a FIRDataSnapshot
* and the previous child's key.
* @param cancelBlock The block that should be called if this client no longer has permission to receive these events
* @return A handle used to unregister this block later using removeObserverWithHandle:
*/
- (FIRDatabaseHandle)observeEventType:(FIRDataEventType)eventType andPreviousSiblingKeyWithBlock:(void (^)(FIRDataSnapshot *snapshot, NSString *__nullable prevKey))block withCancelBlock:(nullable void (^)(NSError* error))cancelBlock;
/**
* This is equivalent to observeEventType:withBlock:, except the block is immediately canceled after the initial data is returned.
*
* @param eventType The type of event to listen for.
* @param block The block that should be called. It is passed the data as a FIRDataSnapshot.
*/
- (void)observeSingleEventOfType:(FIRDataEventType)eventType withBlock:(void (^)(FIRDataSnapshot *snapshot))block;
/**
* This is equivalent to observeEventType:withBlock:, except the block is immediately canceled after the initial data is returned. In addition, for FIRDataEventTypeChildAdded, FIRDataEventTypeChildMoved, and
* FIRDataEventTypeChildChanged events, your block will be passed the key of the previous node by priority order.
*
* @param eventType The type of event to listen for.
* @param block The block that should be called. It is passed the data as a FIRDataSnapshot and the previous child's key.
*/
- (void)observeSingleEventOfType:(FIRDataEventType)eventType andPreviousSiblingKeyWithBlock:(void (^)(FIRDataSnapshot *snapshot, NSString *__nullable prevKey))block;
/**
* This is equivalent to observeEventType:withBlock:, except the block is immediately canceled after the initial data is returned.
*
* The cancelBlock will be called if you do not have permission to read data at this location.
*
* @param eventType The type of event to listen for.
* @param block The block that should be called. It is passed the data as a FIRDataSnapshot.
* @param cancelBlock The block that will be called if you don't have permission to access this data
*/
- (void)observeSingleEventOfType:(FIRDataEventType)eventType withBlock:(void (^)(FIRDataSnapshot *snapshot))block withCancelBlock:(nullable void (^)(NSError* error))cancelBlock;
/**
* This is equivalent to observeEventType:withBlock:, except the block is immediately canceled after the initial data is returned. In addition, for FIRDataEventTypeChildAdded, FIRDataEventTypeChildMoved, and
* FIRDataEventTypeChildChanged events, your block will be passed the key of the previous node by priority order.
*
* The cancelBlock will be called if you do not have permission to read data at this location.
*
* @param eventType The type of event to listen for.
* @param block The block that should be called. It is passed the data as a FIRDataSnapshot and the previous child's key.
* @param cancelBlock The block that will be called if you don't have permission to access this data
*/
- (void)observeSingleEventOfType:(FIRDataEventType)eventType andPreviousSiblingKeyWithBlock:(void (^)(FIRDataSnapshot *snapshot, NSString *__nullable prevKey))block withCancelBlock:(nullable void (^)(NSError* error))cancelBlock;
/** @name Detaching observers */
/**
* Detach a block previously attached with observeEventType:withBlock:.
*
* @param handle The handle returned by the call to observeEventType:withBlock: which we are trying to remove.
*/
- (void) removeObserverWithHandle:(FIRDatabaseHandle)handle;
/**
* Detach all blocks previously attached to this Firebase Database location with observeEventType:withBlock:
*/
- (void) removeAllObservers;
/**
* By calling `keepSynced:YES` on a location, the data for that location will automatically be downloaded and
* kept in sync, even when no listeners are attached for that location. Additionally, while a location is kept
* synced, it will not be evicted from the persistent disk cache.
*
* @param keepSynced Pass YES to keep this location synchronized, pass NO to stop synchronization.
*/
- (void) keepSynced:(BOOL)keepSynced;
/** @name Querying and limiting */
/**
* queryLimitedToFirst: is used to generate a reference to a limited view of the data at this location.
* The FIRDatabaseQuery instance returned by queryLimitedToFirst: will respond to at most the first limit child nodes.
*
* @param limit The upper bound, inclusive, for the number of child nodes to receive events for
* @return A FIRDatabaseQuery instance, limited to at most limit child nodes.
*/
- (FIRDatabaseQuery *)queryLimitedToFirst:(NSUInteger)limit;
/**
* queryLimitedToLast: is used to generate a reference to a limited view of the data at this location.
* The FIRDatabaseQuery instance returned by queryLimitedToLast: will respond to at most the last limit child nodes.
*
* @param limit The upper bound, inclusive, for the number of child nodes to receive events for
* @return A FIRDatabaseQuery instance, limited to at most limit child nodes.
*/
- (FIRDatabaseQuery *)queryLimitedToLast:(NSUInteger)limit;
/**
* queryOrderBy: is used to generate a reference to a view of the data that's been sorted by the values of
* a particular child key. This method is intended to be used in combination with queryStartingAtValue:,
* queryEndingAtValue:, or queryEqualToValue:.
*
* @param key The child key to use in ordering data visible to the returned FIRDatabaseQuery
* @return A FIRDatabaseQuery instance, ordered by the values of the specified child key.
*/
- (FIRDatabaseQuery *)queryOrderedByChild:(NSString *)key;
/**
* queryOrderedByKey: is used to generate a reference to a view of the data that's been sorted by child key.
* This method is intended to be used in combination with queryStartingAtValue:, queryEndingAtValue:,
* or queryEqualToValue:.
*
* @return A FIRDatabaseQuery instance, ordered by child keys.
*/
- (FIRDatabaseQuery *) queryOrderedByKey;
/**
* queryOrderedByValue: is used to generate a reference to a view of the data that's been sorted by child value.
* This method is intended to be used in combination with queryStartingAtValue:, queryEndingAtValue:,
* or queryEqualToValue:.
*
* @return A FIRDatabaseQuery instance, ordered by child value.
*/
- (FIRDatabaseQuery *) queryOrderedByValue;
/**
* queryOrderedByPriority: is used to generate a reference to a view of the data that's been sorted by child
* priority. This method is intended to be used in combination with queryStartingAtValue:, queryEndingAtValue:,
* or queryEqualToValue:.
*
* @return A FIRDatabaseQuery instance, ordered by child priorities.
*/
- (FIRDatabaseQuery *) queryOrderedByPriority;
/**
* queryStartingAtValue: is used to generate a reference to a limited view of the data at this location.
* The FIRDatabaseQuery instance returned by queryStartingAtValue: will respond to events at nodes with a value
* greater than or equal to startValue.
*
* @param startValue The lower bound, inclusive, for the value of data visible to the returned FIRDatabaseQuery
* @return A FIRDatabaseQuery instance, limited to data with value greater than or equal to startValue
*/
- (FIRDatabaseQuery *)queryStartingAtValue:(nullable id)startValue;
/**
* queryStartingAtValue:childKey: is used to generate a reference to a limited view of the data at this location.
* The FIRDatabaseQuery instance returned by queryStartingAtValue:childKey will respond to events at nodes with a value
* greater than startValue, or equal to startValue and with a key greater than or equal to childKey.
*
* @param startValue The lower bound, inclusive, for the value of data visible to the returned FIRDatabaseQuery
* @param childKey The lower bound, inclusive, for the key of nodes with value equal to startValue
* @return A FIRDatabaseQuery instance, limited to data with value greater than or equal to startValue
*/
- (FIRDatabaseQuery *)queryStartingAtValue:(nullable id)startValue childKey:(nullable NSString *)childKey;
/**
* queryEndingAtValue: is used to generate a reference to a limited view of the data at this location.
* The FIRDatabaseQuery instance returned by queryEndingAtValue: will respond to events at nodes with a value
* less than or equal to endValue.
*
* @param endValue The upper bound, inclusive, for the value of data visible to the returned FIRDatabaseQuery
* @return A FIRDatabaseQuery instance, limited to data with value less than or equal to endValue
*/
- (FIRDatabaseQuery *)queryEndingAtValue:(nullable id)endValue;
/**
* queryEndingAtValue:childKey: is used to generate a reference to a limited view of the data at this location.
* The FIRDatabaseQuery instance returned by queryEndingAtValue:childKey will respond to events at nodes with a value
* less than endValue, or equal to endValue and with a key less than or equal to childKey.
*
* @param endValue The upper bound, inclusive, for the value of data visible to the returned FIRDatabaseQuery
* @param childKey The upper bound, inclusive, for the key of nodes with value equal to endValue
* @return A FIRDatabaseQuery instance, limited to data with value less than or equal to endValue
*/
- (FIRDatabaseQuery *)queryEndingAtValue:(nullable id)endValue childKey:(nullable NSString *)childKey;
/**
* queryEqualToValue: is used to generate a reference to a limited view of the data at this location.
* The FIRDatabaseQuery instance returned by queryEqualToValue: will respond to events at nodes with a value equal
* to the supplied argument.
*
* @param value The value that the data returned by this FIRDatabaseQuery will have
* @return A FIRDatabaseQuery instance, limited to data with the supplied value.
*/
- (FIRDatabaseQuery *)queryEqualToValue:(nullable id)value;
/**
* queryEqualToValue:childKey: is used to generate a reference to a limited view of the data at this location.
* The FIRDatabaseQuery instance returned by queryEqualToValue:childKey will respond to events at nodes with a value
* equal to the supplied argument with a name equal to childKey. There will be at most one node that matches because
* child keys are unique.
*
* @param value The value that the data returned by this FIRDatabaseQuery will have
* @param childKey The name of nodes with the right value
* @return A FIRDatabaseQuery instance, limited to data with the supplied value and the key.
*/
- (FIRDatabaseQuery *)queryEqualToValue:(nullable id)value childKey:(nullable NSString *)childKey;
/** @name Properties */
/**
* Gets a FIRDatabaseReference for the location of this query.
*
* @return A FIRDatabaseReference for the location of this query.
*/
@property (nonatomic, readonly, strong) FIRDatabaseReference * ref;
@end
NS_ASSUME_NONNULL_END