2021-07-15 03:56:26 +02:00
|
|
|
//
|
|
|
|
// StatusFilterService.swift
|
|
|
|
// Mastodon
|
|
|
|
//
|
|
|
|
// Created by Cirno MainasuK on 2021-7-14.
|
|
|
|
//
|
|
|
|
|
|
|
|
import os.log
|
|
|
|
import Foundation
|
|
|
|
import Combine
|
|
|
|
import CoreData
|
|
|
|
import CoreDataStack
|
|
|
|
import MastodonSDK
|
|
|
|
import MastodonMeta
|
|
|
|
|
|
|
|
final class StatusFilterService {
|
|
|
|
|
|
|
|
var disposeBag = Set<AnyCancellable>()
|
|
|
|
|
|
|
|
// input
|
|
|
|
weak var apiService: APIService?
|
|
|
|
weak var authenticationService: AuthenticationService?
|
|
|
|
let filterUpdatePublisher = PassthroughSubject<Void, Never>()
|
|
|
|
|
|
|
|
// output
|
2022-02-15 12:44:45 +01:00
|
|
|
@Published var activeFilters: [Mastodon.Entity.Filter] = []
|
2021-07-15 03:56:26 +02:00
|
|
|
|
|
|
|
init(
|
|
|
|
apiService: APIService,
|
|
|
|
authenticationService: AuthenticationService
|
|
|
|
) {
|
|
|
|
self.apiService = apiService
|
|
|
|
self.authenticationService = authenticationService
|
|
|
|
|
|
|
|
// fetch account filters every 300s
|
|
|
|
// also trigger fetch when app resume from background
|
|
|
|
let filterUpdateTimerPublisher = Timer.publish(every: 300.0, on: .main, in: .common)
|
|
|
|
.autoconnect()
|
|
|
|
.share()
|
|
|
|
.eraseToAnyPublisher()
|
|
|
|
|
|
|
|
filterUpdateTimerPublisher
|
|
|
|
.map { _ in }
|
|
|
|
.subscribe(filterUpdatePublisher)
|
|
|
|
.store(in: &disposeBag)
|
|
|
|
|
|
|
|
let activeMastodonAuthenticationBox = authenticationService.activeMastodonAuthenticationBox
|
|
|
|
Publishers.CombineLatest(
|
|
|
|
activeMastodonAuthenticationBox,
|
|
|
|
filterUpdatePublisher
|
|
|
|
)
|
|
|
|
.flatMap { box, _ -> AnyPublisher<Result<Mastodon.Response.Content<[Mastodon.Entity.Filter]>, Error>, Never> in
|
|
|
|
guard let box = box else {
|
|
|
|
return Just(Result { throw APIService.APIError.implicit(.authenticationMissing) }).eraseToAnyPublisher()
|
|
|
|
}
|
|
|
|
return apiService.filters(mastodonAuthenticationBox: box)
|
|
|
|
.map { response in
|
|
|
|
let now = Date()
|
|
|
|
let newResponse = response.map { filters in
|
2022-02-15 12:44:45 +01:00
|
|
|
return filters.filter { filter in
|
|
|
|
if let expiresAt = filter.expiresAt {
|
|
|
|
// filter out expired rules
|
|
|
|
return expiresAt > now
|
|
|
|
} else {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
2021-07-15 03:56:26 +02:00
|
|
|
}
|
|
|
|
return Result<Mastodon.Response.Content<[Mastodon.Entity.Filter]>, Error>.success(newResponse)
|
|
|
|
}
|
|
|
|
.catch { error in
|
|
|
|
Just(Result<Mastodon.Response.Content<[Mastodon.Entity.Filter]>, Error>.failure(error))
|
|
|
|
}
|
|
|
|
.eraseToAnyPublisher()
|
|
|
|
}
|
|
|
|
.sink { result in
|
|
|
|
switch result {
|
|
|
|
case .success(let response):
|
|
|
|
os_log(.info, log: .debug, "%{public}s[%{public}ld], %{public}s: fetch account filters success. %ld items", ((#file as NSString).lastPathComponent), #line, #function, response.value.count)
|
2022-02-15 12:44:45 +01:00
|
|
|
self.activeFilters = response.value
|
2021-07-15 03:56:26 +02:00
|
|
|
case .failure(let error):
|
|
|
|
os_log(.info, log: .debug, "%{public}s[%{public}ld], %{public}s: fetch account filters fail: %s", ((#file as NSString).lastPathComponent), #line, #function, error.localizedDescription)
|
|
|
|
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.store(in: &disposeBag)
|
|
|
|
|
|
|
|
// make initial trigger once
|
|
|
|
filterUpdatePublisher.send()
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|