From 80e9585d08d4bf6c23c509c55971ee44170dd976 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Karol=20K=C4=85kol?= Date: Mon, 25 Mar 2024 15:10:01 +0100 Subject: [PATCH] add initialized to decode nullable metadata in TrackData.swift --- Sources/MembraneRTC/Types/TrackData.swift | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/Sources/MembraneRTC/Types/TrackData.swift b/Sources/MembraneRTC/Types/TrackData.swift index b871c864..eba19b1b 100644 --- a/Sources/MembraneRTC/Types/TrackData.swift +++ b/Sources/MembraneRTC/Types/TrackData.swift @@ -1,12 +1,18 @@ -public struct TrackData: Codable{ +public struct TrackData: Codable { public let metadata: Metadata public let simulcastConfig: SimulcastConfig? - - public init (metadata : Metadata, simulcastConfig : SimulcastConfig? = nil) { + + public init(metadata: Metadata, simulcastConfig: SimulcastConfig? = nil) { self.metadata = metadata self.simulcastConfig = simulcastConfig } - + + public init(from decoder: Decoder) throws { + let container = try decoder.container(keyedBy: CodingKeys.self) + self.metadata = try container.decodeIfPresent(Metadata.self, forKey: .metadata) ?? Metadata() + self.simulcastConfig = try container.decodeIfPresent(SimulcastConfig.self, forKey: .simulcastConfig) + } + func copyWith(metadata: Metadata? = nil, simulcastConfig: SimulcastConfig? = nil) -> TrackData { return TrackData( metadata: metadata ?? self.metadata,