react-native-udp/ios/UdpSocketClient.h
Andy Prock e8050d3fe8 Fixes #15
Refactor the UdpSockets module _clients array to be a member variable.
Make the UdpSocketClient's delegate a weak reference.
remove reload notificaiton, and rely on dealloc to close all open sockets.
2015-12-21 19:45:38 -08:00

92 lines
2.4 KiB
Objective-C

//
// RCTUDPClient.h
// react-native-udp
//
// Created by Mark Vayngrib on 5/9/15.
// Copyright (c) 2015 Tradle, Inc. All rights reserved.
//
#import <Foundation/Foundation.h>
#import "RCTBridgeModule.h"
extern NSString *const RCTUDPErrorDomain;
enum RCTUDPError
{
RCTUDPNoError = 0, // Never used
RCTUDPInvalidInvocationError,// Invalid method invocation
RCTUDPBadConfigError, // Invalid configuration
RCTUDPBadParamError, // Invalid parameter was passed
RCTUDPSendTimeoutError, // A send operation timed out
RCTUDPSendFailedError, // A send operation failed
RCTUDPClosedError, // The socket was closed
RCTUDPOtherError, // Description provided in userInfo
};
typedef enum RCTUDPError RCTUDPError;
@class UdpSocketClient;
@protocol SocketClientDelegate <NSObject>
- (void)onData:(UdpSocketClient*) client data:(NSData *)data host:(NSString*) host port:(uint16_t) port;
@end
@interface UdpSocketClient : NSObject
@property (nonatomic, retain) NSString* id;
@property (nonatomic, retain) NSString* host;
@property (nonatomic) u_int16_t port;
@property (nonatomic, weak) id<SocketClientDelegate> clientDelegate;
///---------------------------------------------------------------------------------------
/// @name Class Methods
///---------------------------------------------------------------------------------------
/**
* Initializes a new RCTUDPClient
*
* @param delegate The object holding the callbacks, usually 'self'.
*
* @return New RCTUDPClient
*/
+ (id)socketClientWithConfig:(id<SocketClientDelegate>) delegate;
///---------------------------------------------------------------------------------------
/// @name Instance Methods
///---------------------------------------------------------------------------------------
/**
* Binds to a host and port
*
* @param port
* @param host ip address
* @return true if bound, false if there was an error
*/
- (BOOL)bind:(u_int16_t) port address:(NSString*) address error:(NSError**)error;
/**
* send data to another host and port
*
* @param port
* @param host ip address
*/
- (void)send:(NSData*) data remotePort:(u_int16_t) port remoteAddress:(NSString*) address callback:(RCTResponseSenderBlock) callback;
/**
* @return { address: ip, port: port }
*/
- (NSDictionary *)address;
/**
* close client
*/
- (void)close;
/**
* Enable broadcast
*/
- (BOOL)setBroadcast:(BOOL) flag error:(NSError **) error;
@end