If you are not using >=4.0.0 of our Chat SDK (or later), please follow the appropriate migration guides to get to v4+ before following this guide.
We are happy you decided to migrate your Programmable Chat iOS SDK to Conversations. It is a great decision and this guide will simplify the process a lot. The bulk of the work is primarily renaming, which will be covered here. You should also review this companion guide that covers the high-level changes and new APIs in Conversations.
_10# Replace_10_10pod "TwilioChatClient"_10_10# with_10_10pod "TwilioConversationsClient"
_10import TwilioChatClient_10_10// becomes_10_10import TwilioConversationsClient
TCHTwilioChatClient
becomes
TCHTwilioConversationsClient
TCHChannel
becomes
TCHConversation
TCHMember
becomes
TCHParticipant
TCHClientSynchronizationStatusChannelsListCompleted
becomes
TCHClientSynchronizationStatusConversationsListCompleted
Intermediate accessor objects were removed so your code will look cleaner.
_10TwilioChatClient.chatClient(withToken:properties:delegate:completion:)_10_10// becomes_10_10TwilioConversationsClient.conversationsClient(withToken:properties:delegate:completion:)
_10TwilioChatClient.users.subscribedUser(withIdentity:completion:)_10_10// becomes_10_10TwilioConversationsClient.subscribedUser(withIdentity:completion:)
_10Channel.member(withIdentity:)_10_10// becomes_10_10Conversation.participant(withIdentity:)
_15TwilioChatClient.channels.subscribedChannels()_15// becomes_15TwilioConversationsClient.myConversations()_15_15//-------------------------------------------------------------_15_15TwilioChatClient.channels.createChannel(options:completion:)_15// becomes_15TwilioConversationsClient.createConversation(options:completion:)_15_15//-------------------------------------------------------------_15_15TwilioChatClient.channels.channel(withSidOrUniqueName:completion:)_15// becomes_15TwilioConversationsClient.conversation(withSidOrUniqueName:completion:)
_15Channel.members.members(completion:)_15// becomes_15Conversation.participants()_15_15//-------------------------------------------------------------_15_15Channel.members.add(byIdentity:completion:)_15// becomes_15Conversation.addParticipant(byIdentity:attributes:completion:)_15_15//-------------------------------------------------------------_15_15Channel.members.remove(_:completion:)_15// becomes_15Conversation.removeParticipant(_:completion:)
_69Channel.messages. sendMessage(with:completion:)_69// becomes_69Conversation.sendMessage(with:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.removeMessage(_:completion:)_69// becomes_69Conversation.removeMessage(_:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.getLastMessages(withCount:completion:)_69// becomes_69Conversation.getLastMessages(withCount:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.getMessagesBefore(_:withCount:completion:)_69// becomes_69Conversation.getMessagesBefore(_:withCount:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.getMessagesAfter(_:withCount:completion:)_69// becomes_69Conversation.getMessagesAfter(_:withCount:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.message(withIndex:completion:)_69// becomes_69Conversation.message(withIndex:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.message(forConsumptionIndex:completion:)_69// becomes_69Conversation.message(forReadIndex:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.lastConsumedMessageIndex_69// becomes_69Channel.lastReadMessageIndex_69_69//-------------------------------------------------------------_69_69Channel.messages.setLastConsumedMessageIndex(_:completion:)_69// becomes_69Conversation.setLastReadMessageIndex(_:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.advanceLastConsumedMessageIndex(_:completion:)_69// becomes_69Conversation.advanceLastReadMessageIndex(_:completion:)_69_69//-------------------------------------------------------------_69_69Channel.messages.setAllMessagesConsumedWithCompletion(_:)_69// becomes_69Conversation.setAllMessagesReadWithCompletion(_:)_69_69//-------------------------------------------------------------_69_69Channel.messages.setNoMessagesConsumedWithCompletion(_:)_69// becomes_69Conversation.setAllMessagesUnreadWithCompletion(_:)
Channels subscribedChannelsSortedBy
Channels userChannelDescriptorsWithCompletion
Channels publicChannelDescriptorsWithCompletion
Members inviteByIdentity:completion:
_10// added_10Conversation.addParticipant(byAddress:proxyAddress:attributes:completion:)_10_10// added_10Conversation.removeParticipant(byIdentity:completion:)
Conversations now have state.
TCHConversationUpdateState
.
Conversation.state()
TCHChannelUpdateLastConsumedMessageIndex
becomes
TCHConversationUpdateLastReadMessageIndex
TCHParticipantUpdateLastConsumedMessageIndex
becomes
TCHParticipantUpdateLastReadMessageIndex
TCHParticipantUpdateLastConsumedTimestamp
becomes
TCHParticipantUpdateLastReadTimestamp
Channel.getUnconsumedMessagesCountWithCompletion
becomes
Conversation.getUnreadMessagesCountWithCompletion
Member.lastConsumedMessageIndex
becomes
Participant.lastReadMessageIndex
Member.lastConsumptionTimestamp
becomes
Participant.lastReadTimestamp
Member.lastConsumptionTimestampAsDate
becomes
Participant.lastReadTimestampAsDate
There are no more streams used to download media. Instead, you'll retrieve a temporary data URL to download it.
_10getMediaContentTemporaryUrl(completion:)
conversationWithSidOrUniqueName
returns an error if the conversation is public.
TCHChannelType
is removed.
subscribedChannelsSortedBy
method, sort the list returned from
myConversations
.
TCHChannelDescriptor
,
TCHUserDescriptor
were removed. Use
TCHConversation
and
TCHUser
objects instead.
addParticipantByIdentity
and
addParticipantByAddress
instead.
TCHConversationStatus
could be now either
joined
or
notParticipating
.