Chat

The TSL iOS SDK provides methods for fetching details of a specific current event, enabling you to get chat features.

Chat Initialization

init(jwtToken:isGuest:showKey:completion:)

Initializes a new instance of the Chat class and confirm the delegate to recieve chat events.

  • Parameters:
    • jwtToken: Generated JWT token
      • Example: eyJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJzZGtfMmVhMjFkZTE5Y2M4YmM1ZTg2NDBjN2IyMjdmZWYyZjMiLCJleHAiOjE3MTAwMjM0NDEsImp0aSI6InRXc3NBd1Nvb2VoaHp5UTA5NUV1eXk9PSJ9.XtPM3iibdTt-fp8fhm2Gh2T7X0XXuUuIPY17bW648Gk
    • isGuest: A boolean indicating whether the user is a guest user (true) or a federated user (false).
    • showKey: show_key for which you want to subscribe to the channel.
    • completion: (optional)
      • status: A boolean value indicating whether token created successfully or not.
      • error: An optional error that occurred during the token creation process, if any.
let chatInstance = Talkshoplive.Chat(jwtToken: "YourJWTToken", isGuest:true/false, showKey: "YourShowKey")
chatInstance.delegate = someContentViewModel

Send Message

sendMessage(message:)

Use initialized instance of the Chat class and sends a message using that instance.

  • Parameters:

    • message: The text message to be sent.
    • type: Default will be "comment", Other types are giphy and question.
    • aspectRatio: When type is "giphy", aspectRatio is mandatory.
  • Completion:

    • status: A boolean value indicating whether the message was sent successfully or not.
    • error: An optional error that occurred during the sending process, if any.
  • Send Message

self.chatInstance.sendMessage(message: newMessage, completion: {status, error in
    if status {
        print("Message Sent!", status)
    } else {
        //If Token is revoked, it will return "PERMISSION_DENIED"
        //If Token is expired, it will return "CHAT_TOKEN_EXPIRED"
        print("Message Sending Failed: \(error.localizedDescription)")
    }
}
  • Send Giphy
self.chatInstance.sendMessage(message: "GiphyId", type: .giphy, aspectRatio: "GiphyWidth/GiphyHeight",completion: {status, error in
    if status {
        print("Giphy Sent!", status)
    } else {
        //If aspectRatio will be missing, it will return "MESSAGE_SENDING_GIPHY_DATA_NOT_FOUND"
        //If Token is revoked, it will return "PERMISSION_DENIED"
        print("Giphy Sending Failed: \(error.localizedDescription)")
    }
}
  • Recieve New message event listener
class ContentViewModel: ObservableObject, ChatDelegate {
    func onNewMessage(_ message: MessageData) {
        // Handle the received message
        print("Recieved New Message", message)
        
        //If it's threaded message, it will have original message details
        if let originalMessage = message.payload?.original?.message {
            print("Original message's sender details", originalMessage.sender)
            print("Original message details", originalMessage.text)
        }
        
        //When MessageType is "giphy"
        if message.payload?.type == .giphy {
            print("Giphy ID", message.payload?.text)
            //Use giphyId with respective giphy URL to load the gif.
        }
    }
}

Remove Message

deleteMessage(timeToken:)

  • Parameters:

    • timeToken : The time token when message was published.
  • Completion:

    • status: A boolean value indicating whether the message was deleted successfully or not.
    • error: An optional error that occurred during the deletion process, if any.
  • Delete Message

self.chatInstance.deleteMessage(timeToken: timetoken, completion: { status, error in
        if status {
            print("Message Deleted!")
        } else {
            //If Token is revoked, it will return "PERMISSION_DENIED"
            //If Token is expired, it will return "CHAT_TOKEN_EXPIRED"
            print("Message Deletion Failed : “\(error.localizedDescription))
        }
}
  • Recieve Delete message event listener
class ContentViewModel: ObservableObject, ChatDelegate {
    func onDeleteMessage(_ message: Talkshoplive.MessageBase) {
        // Handle the deleted message.
    }
}

Chat History

getChatMessages(page:includeActions:includeMeta:includeUUID:completion:)

Use to retrieve messages for a specific page, including or excluding actions, metadata, and UUID in the response.

  • Parameters:
    • page: Specifies the page from which to retrieve chat history. If not provided (set to nil), the method will fetch chat history without specifying a particular page.
    • includeActions: Defaults to true. Set to false if you wish to exclude actions from the response.
    • includeMeta: Defaults to true. Set to false if you want to omit metadata from the response.
    • includeUUID: Defaults to true. Set to false if you prefer not to include UUID in the response.
    • completion: A closure invoked upon fetching chat history. It receives a Result enum with an array of MessageBase on success or an Error on failure.
self.chatInstance.getChatMessages(page: page, completion: { result in
    switch result {
    case let .success((messageArray, nextPage)):
        // print("Next Page:", nextPage)
        // print("Received chat messages:", messageArray)
        
        // Access the actions if 'includeActions' is set to true
        for message in messageArray {
            //If it's threaded message, it will have original message details
            if let originalMessage = message.payload?.original?.message {
                print("Original message's sender details", originalMessage.sender)
                print("Original message details", originalMessage.text)
            }
            
            if let actions = message.actions, actions.count > 0 {
                for action in actions {
                    print("Message Action:", action)
                }
            }
        }            
    case .failure(let error):
        // Handle error case
        //If Token is revoked, it will return "PERMISSION_DENIED"
        //If Token is expired, it will return "CHAT_TOKEN_EXPIRED"
        print("Error: \(error.localizedDescription)")
    }
})

Clean up

clean()

Use to clear all resources associated with the chat instance, including connections and delegates.

self.chatInstance.clean()

Update User

updateUser(jwtToken:isGuest:completion:)

Use initialized instance of the Chat class and update use with updated jwtToken

  • Parameters:
    • jwtToken: Updated JWT token
    • isGuest: A boolean indicating whether the user will updated to guest user (true) or a federated user (false).
    • completion:
      • status: A boolean value indicating whether the user was updated successfully or not.
      • error: An optional error that occurred during the sending process, if any.
self.chatInstance.updateUser(jwtToken: "Your Updated JWTToken", isGuest:true/false) { status, error in
    if status {
        print("User Updated successfully!")
    } else {
        print("Error occurred: \(error.localizedDescription)")
    }
}

Messages Count

countMessages(completion:)

Use to retrieve the count of messages using a chat instance.

  • completion:
    • count: An integer value representing the total count of messages.
    • error: An optional error that occurred during the counting process, if any.
self.chat?.countMessages({ count, error in
    if let error = error {
        //If Token is revoked, it will return "PERMISSION_DENIED"
        //If Token is expired, it will return "CHAT_TOKEN_EXPIRED"
        print(error.localizedDescription)
        print("Error fetching messages count: \(error.localizedDescription))"
    } else {
        print("Message Count : \(count)")
    }
})

Like Comment

likeComment(timeToken:completion:)

Use to like a message using a chat instance.

  • Parameters:
    • timeToken : The time token when message was published.
  • Completion:
    • status: A boolean value indicating whether the message was liked successfully or not.
    • error: An optional error that occurred during the like comment process, if any.
self.chatInstance.likeComment(timeToken: "timetoken", completion: { status, error in
    if status {
        print("Liked comment Successfully", status)
    } else {
        print("Liked comment Error", error?.localizedDescription ?? "")
    }
})
  • Recieve Like comment event listener
class ContentViewModel: ObservableObject, ChatDelegate {
    func onLikeComment(_ messageAction: Talkshoplive.MessageAction) {
        // Handle the liked message action.
    }
}

Unlike Comment

UnlikeComment(timeToken:actionTimeToken:completion:)

Use to Unlike a message using a chat instance.

  • Parameters:
    • timeToken : The time token when message was published.
    • actionTimeToken : The time token when message was liked.
  • Completion:
    • status: A boolean value indicating whether the message was unliked successfully or not.
    • error: An optional error that occurred during the unlike comment process, if any.
self.chatInstance.UnlikeComment(timeToken: "timetoken", actionTimeToken: "actionTimetoken", completion: { status, error in
    if status {
        print("Unliked comment Successfully", status)
    } else {
        print("Unliked comment Error", error?.localizedDescription ?? "")
    }
})
  • Recieve Unlike comment event listener
class ContentViewModel: ObservableObject, ChatDelegate {
    func onUnlikeComment(_ messageAction: MessageAction) {
        // Handle the Unliked message action.
    }
}

Common Listener - onStatusChange

onStatusChange(error:)

Use to listen event when token is revoked.

func onStatusChange(error: Talkshoplive.APIClientError) {
    
    switch error {
    case .PERMISSION_DENIED:
        //If Token is revoked
        print("Permission Denied")
    case .CHAT_TOKEN_EXPIRED:
        //If Token is expired
        print("Chat token expired")
    case .CHAT_TIMEOUT:
        //Chat timeout
        print("Chat Timeout")
    case .CHAT_CONNECTION_ERROR:
        //connection get dismiss and tried to reconnect and fails
        print("Chat connection error")
    default:
        break
    }
}