Skip to content

CUCM Usage Guide

Akshay Agarwal edited this page Aug 24, 2022 · 7 revisions

Using the Cisco Webex iOS SDK v3.0, you can place, receive, transfer and merge CUCM calls.

To get started developer need to first login to CUCM and then wait for Phone Services to get connected, once both steps are successful, you are good to start enjoying features of CUCM.

Usage

  1. Start the UC Services

        webex.startUCServices()
  2. Check if you're already logged into CUCM

        var isUCLoggedIn = webex.isUCLoggedIn()
        if(isUCLoggedIn) {
            // Successfully logged in to the CUCM service
        }
  3. If you're not logged in, you can start the login process by providing the UC domain / serverUrl from the user and invoking the below method. Note: Provide only either a domain or a server, but not both.

        webex.ucLoginDelegate = self // always ensure ucLoginDelegate is set before invoking below method
        webex.setUCDomainServerUrl(ucDomain: "cucm.example.com", serverUrl: "cucmserver.example.com")
  4. Webex SDK exposes a delegate protocol called WebexUCLoginDelegate. This is useful for hooking into the async CUCM operations like login status change, server connection status change, etc. Your class should conform to this protocol and set it appropriately like so:

        class YourViewController: UIViewController {
            override func viewDidAppear(_ animated: Bool) {
                // You need to register your class as a delegate
                webex.ucLoginDelegate = self
            }
        }
    
        extension HomeViewController: WebexUCLoginDelegate {
            func onUCLoggedIn() {
                // cucm login attempt was successful
            }
    
            func onUCLoginFailed() {
                // cucm login attempt failed
            }
            
            func onUCServerConnectionStateChanged(status: UCLoginServerConnectionStatus, failureReason: PhoneServiceRegistrationFailureReason) {
                if status == .Connected {
                    // cucm server connection success
                }
            }
            
            func loadUCSSOView(to url: String) {
                // If your cucm server supports SSO based sign in, you'll need to open a webview using `webex.getUCSSOLoginView` helper like below
                webex.getUCSSOLoginView(parentViewController: self, ssoUrl: url) { success in
                    if let success = success, success {
                        // you're logged in                
                    }
                }
            }
            
           func onUCSSOLoginFailed(failureReason: UCSSOFailureReason) {
                // If the SSO login failed due to reason like session expiry, you'll need to re login using `webex.retryUCSSOLogin` helper like below 
                webex.retryUCSSOLogin()
           }
    
            func showUCNonSSOLoginView() {
                // If your cucm server requires a non-sso(username/password) flow, this delegate method will be invoked
                // You should collect the username / password from user and call the below method 
                webex.setCUCMCredential(username: "[email protected]", password: "SuperSecret")
            }
        }
  5. Check if you're connected to CUCM server

        let status = webex.getUCServerConnectionStatus()
        if status == .Connected {
            // You're successfully connected to a CUCM server
        }
  6. Once you're successfully connected, You can start making calls as usual using either a PSTN number or a sip uri using the regular webex.phone.dial() api e.g:

        let mediaOption = MediaOption.audioOnly()
        webex.phone.dial("+1800123456", option: mediaOption) { result in
            switch result {
                case .success(let call):
                    // Call started successfully
                case .failure(let error):
                    // Call failed
            }
        }
  7. Once you have an instance of a cucm call, you can transfer it to another call

        guard call.isCUCMCall else { 
            print("Call transfer works only with CUCM calls")
            return
        }
    
        // Put an active call on hold
        call.holdCall(putOnHold: true)
        
        // start a new call that can be transferred later to the previous call
        call.startAssociatedCall( dialNumber: "+1800123123", associationType: .transfer, isAudioCall: true) {[weak self] result in
            switch result {
            case .success(let newCall):
                // successfully started an associated call that can be transferred
                call.transferCall(toCallId: newCall.callId)
            case .failure(let error):
                // an error occurred
            }
        }  
  8. Once you have an instance of a cucm call, you can merge it with a new call

        guard call.isCUCMCall else { 
            print("Call merge works only with CUCM calls")
            return
        }
    
        // Put an active call on hold
        call.holdCall(putOnHold: true)
        
        // start a new call that can be transferred later to the previous call
        call.startAssociatedCall(dialNumber: "+1800123123", associationType: .merge, isAudioCall: true) {[weak self] result in
            switch result {
            case .success(let newCall):
                // successfully started an associated call that can be transferred
                call.mergeCall(targetCallId: newCall.callId)
            case .failure(let error):
                // an error occurred
            }
        }  

Flow Chart for CUCM Login:

CUCM CALL NOTIFICATIONS:

For CUCM incoming call notifications, please visit App Registration For Mobile SDK v3