blob: b88b5702ef54f0549c39ec14a8d51c3effff1c30 [file] [log] [blame]
tkchin@webrtc.org87776a82014-12-09 19:32:35 +00001/*
2 * libjingle
jlmiller@webrtc.org5f93d0a2015-01-20 21:36:13 +00003 * Copyright 2014 Google Inc.
tkchin@webrtc.org87776a82014-12-09 19:32:35 +00004 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
7 *
8 * 1. Redistributions of source code must retain the above copyright notice,
9 * this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright notice,
11 * this list of conditions and the following disclaimer in the documentation
12 * and/or other materials provided with the distribution.
13 * 3. The name of the author may not be used to endorse or promote products
14 * derived from this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
22 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
23 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */
27
28#import <Foundation/Foundation.h>
29
30#import "RTCVideoTrack.h"
31
32typedef NS_ENUM(NSInteger, ARDAppClientState) {
33 // Disconnected from servers.
34 kARDAppClientStateDisconnected,
35 // Connecting to servers.
36 kARDAppClientStateConnecting,
37 // Connected to servers.
38 kARDAppClientStateConnected,
39};
40
41@class ARDAppClient;
tkchin@webrtc.org8cc47e92015-03-18 23:38:04 +000042// The delegate is informed of pertinent events and will be called on the
43// main queue.
tkchin@webrtc.org87776a82014-12-09 19:32:35 +000044@protocol ARDAppClientDelegate <NSObject>
45
46- (void)appClient:(ARDAppClient *)client
47 didChangeState:(ARDAppClientState)state;
48
49- (void)appClient:(ARDAppClient *)client
tkchin@webrtc.org3a63a3c2015-01-06 07:21:34 +000050 didChangeConnectionState:(RTCICEConnectionState)state;
51
52- (void)appClient:(ARDAppClient *)client
tkchin@webrtc.org87776a82014-12-09 19:32:35 +000053 didReceiveLocalVideoTrack:(RTCVideoTrack *)localVideoTrack;
54
55- (void)appClient:(ARDAppClient *)client
56 didReceiveRemoteVideoTrack:(RTCVideoTrack *)remoteVideoTrack;
57
58- (void)appClient:(ARDAppClient *)client
59 didError:(NSError *)error;
60
61@end
62
tkchin@webrtc.org8cc47e92015-03-18 23:38:04 +000063// Handles connections to the AppRTC server for a given room. Methods on this
64// class should only be called from the main queue.
tkchin@webrtc.org87776a82014-12-09 19:32:35 +000065@interface ARDAppClient : NSObject
66
67@property(nonatomic, readonly) ARDAppClientState state;
68@property(nonatomic, weak) id<ARDAppClientDelegate> delegate;
69
tkchin@webrtc.org8cc47e92015-03-18 23:38:04 +000070// Convenience constructor since all expected use cases will need a delegate
71// in order to receive remote tracks.
tkchin@webrtc.org87776a82014-12-09 19:32:35 +000072- (instancetype)initWithDelegate:(id<ARDAppClientDelegate>)delegate;
73
74// Establishes a connection with the AppRTC servers for the given room id.
75// TODO(tkchin): provide available keys/values for options. This will be used
76// for call configurations such as overriding server choice, specifying codecs
77// and so on.
78- (void)connectToRoomWithId:(NSString *)roomId
79 options:(NSDictionary *)options;
80
81// Disconnects from the AppRTC servers and any connected clients.
82- (void)disconnect;
83
84@end