mirror of
https://github.com/Dimillian/IceCubesApp.git
synced 2024-12-22 15:16:36 +00:00
Handle dynamic streaming URL
This commit is contained in:
parent
816eae2d40
commit
4de46610e0
5 changed files with 19 additions and 9 deletions
|
@ -158,7 +158,11 @@ struct IceCubesApp: App {
|
|||
currentAccount.setClient(client: client)
|
||||
currentInstance.setClient(client: client)
|
||||
userPreferences.setClient(client: client)
|
||||
watcher.setClient(client: client)
|
||||
Task {
|
||||
await currentInstance.fetchCurrentInstance()
|
||||
watcher.setClient(client: client, instanceStreamingURL: currentInstance.instance?.urls?.streamingApi)
|
||||
watcher.watch(streams: [.user, .direct])
|
||||
}
|
||||
}
|
||||
|
||||
private func handleScenePhase(scenePhase: ScenePhase) {
|
||||
|
|
|
@ -17,6 +17,9 @@ class ShareViewController: UIViewController {
|
|||
let instance = CurrentInstance.shared
|
||||
account.setClient(client: client)
|
||||
instance.setClient(client: client)
|
||||
Task {
|
||||
await instance.fetchCurrentInstance()
|
||||
}
|
||||
let colorScheme = traitCollection.userInterfaceStyle
|
||||
let theme = Theme.shared
|
||||
theme.setColor(withName: colorScheme == .dark ? .iceCubeDark : .iceCubeLight)
|
||||
|
|
|
@ -22,15 +22,10 @@ public class CurrentInstance: ObservableObject {
|
|||
|
||||
public func setClient(client: Client) {
|
||||
self.client = client
|
||||
Task {
|
||||
await fetchCurrentInstance()
|
||||
}
|
||||
}
|
||||
|
||||
public func fetchCurrentInstance() async {
|
||||
guard let client = client else { return }
|
||||
Task {
|
||||
instance = try? await client.get(endpoint: Instances.instance)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -7,6 +7,7 @@ public class StreamWatcher: ObservableObject {
|
|||
private var client: Client?
|
||||
private var task: URLSessionWebSocketTask?
|
||||
private var watchedStreams: [Stream] = []
|
||||
private var instanceStreamingURL: URL?
|
||||
|
||||
private let decoder = JSONDecoder()
|
||||
private let encoder = JSONEncoder()
|
||||
|
@ -25,16 +26,18 @@ public class StreamWatcher: ObservableObject {
|
|||
decoder.keyDecodingStrategy = .convertFromSnakeCase
|
||||
}
|
||||
|
||||
public func setClient(client: Client) {
|
||||
public func setClient(client: Client, instanceStreamingURL: URL?) {
|
||||
if self.client != nil {
|
||||
stopWatching()
|
||||
}
|
||||
self.client = client
|
||||
self.instanceStreamingURL = instanceStreamingURL
|
||||
connect()
|
||||
}
|
||||
|
||||
private func connect() {
|
||||
task = client?.makeWebSocketTask(endpoint: Streaming.streaming)
|
||||
guard let client else { return }
|
||||
task = client.makeWebSocketTask(endpoint: Streaming.streaming, instanceStreamingURL: instanceStreamingURL)
|
||||
task?.resume()
|
||||
receiveMessage()
|
||||
}
|
||||
|
|
|
@ -29,6 +29,10 @@ public struct Instance: Codable {
|
|||
public let text: String
|
||||
}
|
||||
|
||||
public struct URLs: Codable {
|
||||
public let streamingApi: URL?
|
||||
}
|
||||
|
||||
public let title: String
|
||||
public let shortDescription: String
|
||||
public let email: String
|
||||
|
@ -39,4 +43,5 @@ public struct Instance: Codable {
|
|||
public let thumbnail: URL?
|
||||
public let configuration: Configuration?
|
||||
public let rules: [Rule]?
|
||||
public let urls: URLs?
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue