Show
TSL SDK provides methods for fetching details of a specific show and its current event, enabling you to get show and current event details in your app. Retrieve Shows information by "". Same key used in the embed and in the url.
For example:
https://talkshop.live/watch/o_HHIe1c8GfZ the "show-key" is o_HHIe1c8GfZ
Show Details
getDetails(showKey:completion:)
Get detailed information about a specific show.
Parameters:
showKey
: The unique identifier of the show.completion
: A closure that will be called once the show details are fetched. It takes a Result enum containing either the ShowData on success or an Error on failure.
let showInstance = Talkshoplive.Show()
showInstance.getDetails(showKey: "show-key") { result in
switch result {
case .success(let show):
print("Show details: \(show)")
case .failure(let error):
// Handle error case
print("Error fetching show details: \(error)")
}
}
Response:
struct Show: Codable {
let id: Int
let show_key: String
let name: String
let description: String
let status: String // see status below
let hls_playback_url: String // live or null
let hls_url: String //vod or null
let trailer_url: String //trailer
let air_date: datetime
let ended_at: datetime
let event_id: int
let duration: int
}
Show Status
getStatus(showKey:completion:)
Get the current event of a show.
Parameters:
showKey
: The unique identifier of the show.completion
: A closure that will be called once the show details are fetched. It takes a Result enum containing either the ShowData on success or an Error on failure.
let showInstance = Talkshoplive.Show()
showInstance.getStatus(showKey: "yourShowId") { result in
switch result {
case .success(let eventData):
print("Show's current event' details: \(eventData)")
case .failure(let error):
// Handle error case
print("Error fetching show's current event details: \(error)")
}
}
Response:
struct EventData: Codable {
public var name: String
public var status: String
public var hls_playback_url: URL
public var duration: Int
}
Show status
-
created
: the show has not started and trailer_url is ready to be consumed
live
: the show is currently live and the stream hls_playback_url is ready to consume.
transcoding
: the show is no longer live and the VOD is not available as it is being transcoded
finished
: the show is no longer live and the VOD hls_url is ready to be consumed.
Show Products
getProducts(showKey:preLive:completion:)
Get Products list from specific show's details.
Parameters:
showKey
: The unique identifier of the show.preLive
(optional): A flag indicating whether the request is related to pre products. Default isfalse
.completion
: A closure that will be called once the products are fetched. It takes aResult
enum containing either the[ProductData]
on success or anError
on failure.
showInstance.getProducts(showKey: "yourShowKey", preLive: "true/false") { result in
switch result {
case .success(let products):
print("Products: \(products)")
//Please use following to find product's variants information
for i in products {
print("Product Details", i)
if let variants = i.variants, variants.count > 0 {
for j in variants {
print("SKU", (i.sku ?? ""))
}
}
}
case .failure(let error):
// Handle error case
print("Error fetching products list: \(error)")
}
}
Updated 13 days ago