From 9863fc66deec3a66aedcaadf5ae6db76594056aa Mon Sep 17 00:00:00 2001 From: Yu Sung Date: Wed, 13 Sep 2023 12:14:03 +0900 Subject: [PATCH] =?UTF-8?q?=EC=9E=AC=EC=83=9D=20=EC=88=98=20=EC=97=85?= =?UTF-8?q?=EB=8D=B0=EC=9D=B4=ED=8A=B8=20=EB=A1=9C=EC=A7=81=20=EC=B6=94?= =?UTF-8?q?=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../AddAllPlaybackTrackingRequest.swift | 2 +- SodaLive/Sources/Main/Home/HomeView.swift | 1 + .../Sources/Main/Home/HomeViewModel.swift | 37 +++++++++++++++++++ 3 files changed, 39 insertions(+), 1 deletion(-) diff --git a/SodaLive/Sources/Content/AddAllPlaybackTrackingRequest.swift b/SodaLive/Sources/Content/AddAllPlaybackTrackingRequest.swift index 8ea769d..bd244ab 100644 --- a/SodaLive/Sources/Content/AddAllPlaybackTrackingRequest.swift +++ b/SodaLive/Sources/Content/AddAllPlaybackTrackingRequest.swift @@ -13,7 +13,7 @@ struct AddAllPlaybackTrackingRequest: Encodable { } struct PlaybackTrackingData: Encodable { - let audioContentId: Int + let contentId: Int let playDateTime: String let isPreview: Bool } diff --git a/SodaLive/Sources/Main/Home/HomeView.swift b/SodaLive/Sources/Main/Home/HomeView.swift index b1c7767..187b4bc 100644 --- a/SodaLive/Sources/Main/Home/HomeView.swift +++ b/SodaLive/Sources/Main/Home/HomeView.swift @@ -114,6 +114,7 @@ struct HomeView: View { pushTokenUpdate() viewModel.getMemberInfo() viewModel.getEventPopup() + viewModel.addAllPlaybackTracking() } if appState.isShowPlayer { diff --git a/SodaLive/Sources/Main/Home/HomeViewModel.swift b/SodaLive/Sources/Main/Home/HomeViewModel.swift index 7d5c444..7acef32 100644 --- a/SodaLive/Sources/Main/Home/HomeViewModel.swift +++ b/SodaLive/Sources/Main/Home/HomeViewModel.swift @@ -14,6 +14,8 @@ final class HomeViewModel: ObservableObject { private let userRepository = UserRepository() private let eventRepository = EventRepository() + private let contentRepository = ContentRepository() + private let playbackTrackingRepository = PlaybackTrackingRepository() enum CurrentTab: String { case content, live, explorer, message, mypage @@ -92,4 +94,39 @@ final class HomeViewModel: ObservableObject { } .store(in: &subscription) } + + func addAllPlaybackTracking() { + let playbackTrackingList = playbackTrackingRepository.getAllPlaybackTracking() + let trackingDataList = playbackTrackingList + .filter { + return $0.endPosition != nil + } + .filter { ($0.endPosition! - $0.startPosition) >= 10 } + .map { + PlaybackTrackingData(contentId: $0.audioContentId, playDateTime: $0.playDateTime, isPreview: $0.isPreview) + } + + contentRepository.addAllPlaybackTracking(request: AddAllPlaybackTrackingRequest(trackingDataList: trackingDataList)) + .sink { result in + switch result { + case .finished: + DEBUG_LOG("finish") + case .failure(let error): + ERROR_LOG(error.localizedDescription) + } + } receiveValue: { [unowned self] response in + let responseData = response.data + + do { + let jsonDecoder = JSONDecoder() + let decoded = try jsonDecoder.decode(ApiResponseWithoutData.self, from: responseData) + + if decoded.success { + self.playbackTrackingRepository.removeAllPlaybackTracking() + } + } catch { + } + } + .store(in: &subscription) + } }