Sendbird Chat SDK for iOS
The Sendbird Chat SDK for iOS allows you to add real-time chat into your client app with minimal effort. Sendbird offers a feature rich, scalable, and proven chat solution depended on by companies like Reddit, Hinge, PubG and Paytm.
The Chat SDK provides the full functionality to provide a rich chat experience, implementing it begins by adding a user login, listing the available channels, selecting or creating an open channel or group channel, and receive messages and other events through channel event delegates and the ability to send a message. Once this basic functionality is in place, congrats, you now have a chat app!
Once this is in place, take a look at all the other features that Sendbird supports and add what works best for your users.
Find out more about Sendbird Chat for iOS in the documentation. If you have any comments, questions or feature requests, let us know in the Sendbird community.
The minimum requirements for Chat SDK for iOS are:
macOS
Xcode
At least one device running iOS 9.0 and later
Swift 5.0 or later
orObjective-C
Note: Sendbird server supports Transport Layer Security (TLS) from version 1.0 up to 1.3. For example, in the server regions where TLS 1.3 isn’t available, lower versions, sequentially from 1.2 to 1.0, will be supported for secure data transmission.
The quickest way to get started is by using one of the sample apps from the samples repo, create an application in the Sendbird dashboard and copy the App ID
to the sample app and you’re ready to go.
Before installing Sendbird Chat SDK, you need to create a Sendbird application on the Sendbird Dashboard. You will need the App ID
of your Sendbird application when initializing the Chat SDK.
Note: Each Sendbird application can be integrated with a single client app. Within the same application, users can communicate with each other across all platforms, whether they are on mobile devices or on the web.
Installing the Chat SDK is simple if you’re familiar with using external libraries or SDK’s in your projects. Sendbird Chat SDK can be installed through either Swift Packages, CocoaPods, or Carthage.
Note: If you don't want to use package managers, check out the manual installation guide.
You can use an Xcode native package manager Swift Packages for installation.
-
Open Xcode, go to your project's General settings tab, and select your project under Project in the left column.
-
Go to the Swift packages tab and click the + button.
- When a pop-up shows, enter our github repository address in the search bar. The address is
https://github.com/sendbird/sendbird-chat-sdk-ios
.
- Set Rules and click Next.
- Check
SendbirdChatSDK
in the Package product column and click Finish. This will establish a Swift Package Dependency menu in Xcode.
- Open a terminal window, move to your project directory, and then create a Podfile by running the following command.
$ pod init
- A Podfile will be created in your project folder. Open the Podfile and modify the file like the following.
# platform :ios, '9.0'
target 'YOUR_PROJECT_NAME' do
# Comment the next line if you don't want to use dynamic frameworks
use_frameworks!
# Pods for `YOUR_PROJECT_NAME`
pod SendbirdChatSDK
end
- Then install the
SendbirdChatSDK
framework by running the following command in the same terminal window.
$ pod install
- In the folder, you will see a new project file in the
.xcworkspace
format. Now you can build your project with theSendbirdChatSDK
framework in the file.
- Open a terminal window and add the following line to create a Cartfile in your project folder.
$ touch Cartfile
- Move to your project directory, open the Cartfile, and add the following line to your Cartfile.
github "sendbird/sendbird-chat-sdk-ios"
- Run the carthage update command to download Sendbird Chat SDK for iOS.
$ carthage update --use-xcframeworks
- Once the update is complete, go to your Xcode project's General settings tab. Then, open the <YOUR_XCODE_PROJECT_DIRECTORY>/Carthage/Build/iOS in the Finder window and drag and drop the SendbirdChatSDK.xcframework folder to the Frameworks, Libraries, and Embedded section in Xcode.
With one simple import statement, you can use all classes and methods in both Swift and Objective-C.
import SendbirdChatSDK
Now that the Chat SDK has been imported, we're ready to start sending a message.
Note: The methods in the following steps are all asynchronous, excluding the SendbirdChat.initialize(:)
. This means that when using asynchronous methods, client apps must receive success callbacks from Sendbird server through completion delegates in order to proceed to the next step. A good way to do this is the nesting of methods.
In order to use the features of the Chat SDK, you should initiate the SendbirdChatSDK
instance through user authentication with Sendbird server. This instance communicates and interacts with the server based on an authenticated user account, and then the user’s client app can use the Chat SDK's features.
Here are the steps to sending your first message using Chat SDK:
Now, initialize the Chat SDK in the app to allow the Chat SDK to respond to changes in the connection status in iOS client apps. Initialization requires the App ID
, which can be found in the Sendbird Dashboard.
Before calling the initialize(params:migrationStartHandler:completionHandler:)
method, create a InitParams
object with your Sendbird application ID. In the params, you can also determine whether to enable local caching or not.
let initParams = InitParams(
applicationId: APP_ID,
isLocalCachingEnabled: true,
logLevel: .info
)
SendbirdChat.initialize(params: initParams) {
// Migration starts.
}, completionHandler: { error in
// Migration is completed.
}
The completionHandler
gets the initialization status through different event handlers. The migrationStartHandler
is called when there's an upgrade in the local database. Meanwhile, the completionHandler
informs the client app whether the initialization is completed.
If the initialization fails when you set the isLocalCachingEnabled
to true, the SDK will operate normally and change the value of the isLocalCachingEnabled
to false. If you still wish to use the local caching, clear the database using the clearCachedData(completionHandler:)
and try the initialization again with the isLocalCachingEnabled
set to true.
Note: The
initialize(params:migrationStartHandler:completionHandler:)
method of aSendbirdChatSDK
instance must be called across a client app at least once. We recommend that you initialize Sendbird Chat SDK through theapplication:didFinishLaunchingWithOptions:
method of theAppDelegate
instance.
After initialization by use of the init()
method, your client app must always be connected to Sendbird server before calling any methods. If you attempt to call a method without connecting, an ERR_CONNECTION_REQUIRED (800101)
error would return.
Connect a user to Sendbird server either through a unique user ID or in combination with an access or session token. Sendbird prefers the latter method, as it ensures privacy with the user. The former is useful during the developmental phase or if your service doesn't require additional security.
Connect a user to Sendbird server using their unique user ID. By default, Sendbird server can authenticate a user by a unique user ID. Upon request for a connection, the server queries the database to check for a match. Any untaken user ID is automatically registered as a new user to the Sendbird system, while an existing ID is allowed to log indirectly. The ID must be unique within a Sendbird application, such as a hashed email address or phone number in your service.
This allows you to get up and running without having to go deep into the details of the token registration process, however make sure to enable enforcing tokens before launching as it is a security risk to launch without.
SendbirdChat.connect(userId: USER_ID) { user, error in
guard let user = user, error == nil else {
return // Handle error.
}
// The user is connected to the Sendbird server.
}
Sendbird prefers that you pass the APP ID through the use of a token, as it ensures privacy and security for the users. Create a user along with their access token, or issue an session token to pass during connection. A comparison between an access token and session token can be found here. Once a token is issued, a user is required to provide the issued token in the SendbirdChat.connect()
method which is used for logging in.
- Using the Chat Platform API, create a Sendbird user account with the information submitted when a user signs up your service.
- Save the user ID along with the issued token to your persistent storage which is securely managed.
- When the user attempts to log in to the Sendbird application, load the user ID and token from the storage, and then pass them to the
SendbirdChat.connect()
method. - Periodically replacing the user's token is recommended to protect the account.
SendbirdChat.connect(userId: USER_ID, authToken: AUTH_TOKEN) { user, error in
guard let user = user, error == nil else {
return // Handle error.
}
// The user is connected to the Sendbird server.
}
Create an open channel using the following codes. Open channels are where all users in your Sendbird application can easily participate without an invitation.
let params = OpenChannelCreateParams()
params.name = CHANNEL_NAME
OpenChannel.createChannel(params: params) { openChannel, error in
guard let openChannel = openChannel, error == nil else {
return // Handle error.
}
// An open channel is successfully created.
// Through the openChannel parameter of the callback method,
// you can get the open channel's data from the Sendbird server.
}
Note: You can also create a group channel to send a message. To learn more, see Create a channel in the Group channel page.
Enter the open channel to send and receive messages.
openChannel.enter { error in
guard error == nil else {
return
}
// The current user successfully enters the open channel,
// and can chat with other users in the channel by using APIs.
}
Finally, send a message to the channel you entered. To learn more about the message type you can send, see Messages.
openChannel.sendUserMessage(MESSAGE) { userMessage, error in
guard let userMessage = userMessage, error == nil else {
return // Handle error.
}
// The message is successfully sent to the channel.
// The current user can receive messages from other users through
// the channel(_:didReceiveMessage:) method of an event delegate.
}
Add the OpenChannelDelegate.channel(_:didReceive:)
event delegate using the SendbirdChat.addChannelDelegate(_:identifier:)
method so that you can receive the message you just sent to the channel. You can also see the message on our dashboard.
class ViewController: UIViewController, OpenChannelDelegate {
override func viewDidLoad() {
super.viewDidLoad()
SendbirdChat.addChannelDelegate(self, identifier: CLASS_IDENTIFIER) // Replace CLASS_IDENTIFIER with a unique identifier for this delegate.
}
func channel(_ channel: BaseChannel, didReceive message: BaseMessage) {
// A message is received in the channel.
}
}
At Sendbird, we are a diverse group of humble, friendly, and hardworking individuals united by a shared purpose to build the next generation of mobile & social technologies, across chat, voice, and video, that are changing the way we work and live. We're always looking for great people to join our team. Check out our careers page for more information.