Skip to content

CUCM Usage Guide

Rohit Sharma edited this page Aug 13, 2022 · 7 revisions

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

Usage

  1. Check if you're already logged into CUCM

        var isUCLoggedIn = webex.isUCLoggedIn()
        if(isUCLoggedIn) {
            // Successfully logged in to the CUCM service
        }
  2. Check if you're connected to CUCM server

        let status = webex.getUCServerConnectionStatus()
        if status == .Connected {
            // You're successfully connected to a CUCM server
        }
  3. 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 showUCSSOLoginView(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 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")
            }
        }
  4. 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")
  5. Once you're successfully logged in, 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
            }
        }
  6. 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
            }
        }  
  7. 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
            }
        }  

CUCM CALL NOTIFICATIONS:

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