Skip to content

Getting Started 1.x

Marco Brescianini edited this page Aug 30, 2024 · 5 revisions

This guide will show you the basic steps you need to make in order to integrate the BandyerSDK in your iOS app. From now on we are assuming you already have obtained your Bandyer credentials, you have read the previous "getting started" guides.

SDK configuration

The first thing we need to do in order to use the BandyerSDK is configuring and initializing it. In the code samples below, we are going to initialize the BandyerSDK in our sample AppDelegate. We do it there for convenience but you are not required to do so, you can initialize the BandyerSDK in any point of your code, just make sure to do it only once.

You must create a configuration object the SDK will read to configure itself during initialization. Once this object is created you should start setting the environment in which the SDK will run. In the following examples we tell the SDK to connect to the sandbox environment.

//Import the sdk umbrella header
#import <Bandyer/Bandyer.h>

@implementation AppDelegate

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    //The sdk needs a configuration object where it is specified which environment the sdk should work in
    BDKConfig *config = [BDKConfig new];
    
    //Here we are telling the SDK we want to work in a sandbox environment.
    //Beware the default environment is production, we strongly recommend to test your app in a sandbox environment. 
    config.environment = BDKEnvironment.sandbox;
    
    //Here we are disabling CallKit support for the moment.
    config.callKitEnabled = NO;

    //Now we are ready to initialize the SDK providing the app id token identifying your app in Bandyer platform.
    //You must provide the APP_ID you got from our sales departement

    [BandyerSDK.instance initializeWithApplicationId:@"PUT YOUR APP ID HERE" config:config];

    return YES;
}

@end
import UIKit
import Bandyer

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        
        //The sdk needs a configuration object where it is specified which environment the sdk should work in
        let config = BDKConfig()

        //Here we are telling the SDK we want to work in a sandbox environment.
        //Beware the default environment is production, we strongly recommend to test your app in a sandbox environment.
        config.environment = .sandbox

        //Here we are disabling CallKit support
        config.isCallKitEnabled = false
        
        //Now we are ready to initialize the SDK providing the app id token identifying your app in Bandyer platform.
    	 //You must provide the APP_ID you got from our sales departement
        BandyerSDK.instance().initialize(withApplicationId: "PUT YOUR APP ID HERE", config: config)
        
        return true
    }

}

As you might have noticed, once we set all the flags and configuration needed on the configuration object, we told the SDK to initialize itself providing it an "App Id" and the configuration object created previously. This step, sets up the SDK internally, but you won't start receiving incoming calls nor you can make outgoing calls yet. We must start the call client before we can do anything.

Starting the call client

Once the SDK has been initialized, you must start the call client in order to be able to receive incoming calls, or make outgoing calls. The call client is the object responsible for connecting to the Bandyer platform, and for making and receiving calls. To start the call client you must call the "start" method on it providing the "user alias" of the user that is connecting to the Bandyer platform. Beware the "user alias" it's an identifier identifying a particular user on the Bandyer platform; the user alias must exist on the Bandyer platform otherwise the call client won't be able to connect and authenticate with our servers. So do not try to start the client with a dummy value.

Let's pretend we are writing an app that has some kind of authentication mechanism. After we have authenticated our user (either she/he has provided hers/his authentication credential on a login screen or we resumed her/his user session) we show her/him our wonderful app main screen. There we are going to start the call client, listening for its events.

@implementation MainViewController

- (void)viewDidLoad
{
    [super viewDidLoad];

    //We are registering as a call client observer in order to be notified when the client changes its state.
    //We are also providing the main queue telling the SDK onto which queue should notify the observer provided,
    //otherwise the SDK will notify the observer onto its background internal queue.
    [BandyerSDK.instance.callClient addObserver:self queue:dispatch_get_main_queue()];

    //Then we start the call client providing the "user alias" of the user selected.
    [BandyerSDK.instance.callClient start:@"PUT THE USER ALIAS HERE"];
}

@end
class MainViewController: UIViewController {

	override func viewDidLoad() {
        super.viewDidLoad()

        //We are registering as a call client observer in order to be notified when the client changes its state.
        //We are also providing the main queue telling the SDK onto which queue should notify the observer provided,
        //otherwise the SDK will notify the observer onto its background internal queue.
        BandyerSDK.instance().callClient.add(observer: self, queue: .main)

        //Then we start the call client providing the "user alias" of the user selected.        
        BandyerSDK.instance().callClient.start("PUT THE USER ALIAS HERE")
    }
}

As you might have noticed we done two things: we started the call client calling the "start" method on it, but first we registered as a client observer. Any action requested to the call client will be executed asynchronously on a private background queue, so in order to be notified when the client changes it state or when an event is received the first thing you must do is subscribe as a client observer.

Responding to call client events

The call client will notify its observers anytime it changes state or when an incoming call has been received. Let's see if we can connect to Bandyer successfully. We are going to conform the view controller we created to the BCXCallClientObserver protocol. When the client starts successfully the callClientDidStart: method will be invoked. If an error occurs the callClient:didFailWithError: method will be invoked instead.

- (void)callClientDidStart:(id <BCXCallClient>)client
{
   NSLog(@"Bandyer call client has started");
}

- (void)callClient:(id <BCXCallClient>)client didFailWithError:(NSError *)error
{
   NSLog(@"Bandyer call client has failed because of error %@", error);   
}
extension MainViewController : BCXCallClientObserver{
    public func callClientDidStart(_ client: BCXCallClient) {
    	print("Bandyer call client has started")
    }

    public func callClient(_ client: BCXCallClient, didFailWithError error: Error) {
    	print("Bandyer call client has failed because of error \(error)")
    }
}

Where to go from here

Now that you have a basic implementation that can connect to the Bandyer platform you are ready to start making outgoing calls or receive incoming calls. We also recommend you to take a look at the call client lifecycle guide that will explain you how to respond to the call client state change events.

What's next

Clone this wiki locally