This library is an opinionated VoIP wrapper for iOS applications. It currently uses Linphone as the underlying SIP library.
Install using Cocoa Pods.
Step 1: Create a Config object . This object contains all the possible configuration options, however the auth parameter is the only one that is required, the rest will use sensible defaults.
let config = Config(auth: Auth(name: "username", password: "password", domain: "domain", port: "port"),
callDelegate: callManager)
Step 2: Get an instance of the VoIPLib and initialise it with the config
let voipLib = VoIPLib.shared
voipLib.initialize(config: config)
Step 3: Call register
to register with the authentication information provided in the config
voipLib.register { state in
if state == .registered {
print("Registration was successful.")
}
}
To unregister
use:
voipLib.unregister {
print("Unregistering.")
}
To receive events you must provide an object that implements the CallDelegate protocol. This provides a handful of simple methods that will allow your application to update based on the current state of the call. There is further documentation within the CallDelegate protocol as to what each callback method does.
Once created this object should be provided in the config provided.
The CallDelegate listens for the following events:
- incomingCallReceived
- outgoingCallCreated
- callConnected
- callEnded
- callUpdated
- error
All of these methods will provide a Call object, listening to these methods is the only way to obtain a call object so actions can be performed on it.
Once registered you can make a call as follows:
voipLib.call(to: "0612345678")
If setup successfully this will be followed shortly by a call to the outgoingCallCreated method which will provide a Call object.
When successfully registered, the library will be listening for incoming calls. If one is received the incomingCallReceived callback method will be triggered.
Answering or declining an incoming call are considered actions, you can perform an action on a call as follows:
voipLib.actions(call: call).accept()
or
voipLib.actions(call: call).end()
There are many more actions available for calls, please inspect the Actions class to see what more can be done to active calls.
The library contains an example app that shows more clearly how to use the library but the following is a very basic example for making an outgoing call.
let config = Config(
auth: Auth(name:"my username", password: "my password", domain: "sip.com", port: 5061),
callDelegate: myCallManager,
encryption: true,
stun: "mystunserver.com",
codecs: [Codec.OPUS]
)
let voipLib = VoIPLib.shared
voipLib.initialize(config: config)
voipLib.register { state in
if state == .registered {
voipLib.call(to: "0612345678")
}
}
Incoming calls on mobile devices typically use push notifications to trigger a registration, this is the our recommendation but implementing it is out of scope for this library.
Although other use-cases are supported, we suggest performing a full initialisation before each call, and completely destroying the library after the call has completed.
This library is designed to simplify using VoIP in an iOS application and as such must be somewhat opinionated. This means the library will not support every possible situation.
Any pull requests should keep this in-mind as they will not be approved if they add a significant amount of complexity.
If you have any question please let us know via opensource@wearespindle.com
or by opening an issue.