Files
SideStore/SideStoreApp/Sources/SideStoreAppKit/Operations/UpdatePatronsOperation.swift

94 lines
3.2 KiB
Swift
Raw Normal View History

//
// UpdatePatronsOperation.swift
// AltStore
//
// Created by Riley Testut on 4/11/22.
// Copyright © 2022 Riley Testut. All rights reserved.
//
import CoreData
2023-03-01 00:48:36 -05:00
import Foundation
2023-03-01 00:48:36 -05:00
import SideStoreCore
2023-03-01 00:48:36 -05:00
private extension URL {
#if STAGING
2023-03-01 00:48:36 -05:00
static let patreonInfo = URL(string: "https://f000.backblazeb2.com/file/altstore-staging/altstore/patreon.json")!
#else
2023-03-01 00:48:36 -05:00
static let patreonInfo = URL(string: "https://cdn.altstore.io/file/altstore/altstore/patreon.json")!
#endif
}
2023-03-01 00:48:36 -05:00
extension UpdatePatronsOperation {
private struct Response: Decodable {
var version: Int
var accessToken: String
var refreshID: String
}
}
2023-03-01 00:48:36 -05:00
final class UpdatePatronsOperation: ResultOperation<Void> {
let context: NSManagedObjectContext
2023-03-01 00:48:36 -05:00
init(context: NSManagedObjectContext = DatabaseManager.shared.persistentContainer.newBackgroundContext()) {
self.context = context
}
2023-03-01 00:48:36 -05:00
override func main() {
super.main()
2023-03-01 00:48:36 -05:00
let dataTask = URLSession.shared.dataTask(with: .patreonInfo) { data, response, error in
do {
if let response = response as? HTTPURLResponse {
guard response.statusCode != 404 else {
self.finish(.failure(URLError(.fileDoesNotExist, userInfo: [NSURLErrorKey: URL.patreonInfo])))
return
}
}
2023-03-01 00:48:36 -05:00
guard let data = data else { throw error! }
2023-03-01 00:48:36 -05:00
2023-03-01 14:36:52 -05:00
let response = try SideStoreCore.JSONDecoder().decode(Response.self, from: data)
Keychain.shared.patreonCreatorAccessToken = response.accessToken
2023-03-01 00:48:36 -05:00
let previousRefreshID = UserDefaults.shared.patronsRefreshID
guard response.refreshID != previousRefreshID else {
self.finish(.success(()))
return
}
2023-03-01 00:48:36 -05:00
PatreonAPI.shared.fetchPatrons { result in
self.context.perform {
2023-03-01 00:48:36 -05:00
do {
let patrons = try result.get()
let managedPatrons = patrons.map { ManagedPatron(patron: $0, context: self.context) }
2023-03-01 00:48:36 -05:00
let patronIDs = Set(managedPatrons.map { $0.identifier })
let nonFriendZonePredicate = NSPredicate(format: "NOT (%K IN %@)", #keyPath(ManagedPatron.identifier), patronIDs)
2023-03-01 00:48:36 -05:00
let nonFriendZonePatrons = ManagedPatron.all(satisfying: nonFriendZonePredicate, in: self.context)
2023-03-01 00:48:36 -05:00
for managedPatron in nonFriendZonePatrons {
self.context.delete(managedPatron)
}
2023-03-01 00:48:36 -05:00
try self.context.save()
2023-03-01 00:48:36 -05:00
UserDefaults.shared.patronsRefreshID = response.refreshID
2023-03-01 00:48:36 -05:00
self.finish(.success(()))
2023-03-01 00:48:36 -05:00
print("Updated Friend Zone Patrons!")
2023-03-01 00:48:36 -05:00
} catch {
self.finish(.failure(error))
}
}
}
2023-03-01 00:48:36 -05:00
} catch {
self.finish(.failure(error))
}
}
2023-03-01 00:48:36 -05:00
dataTask.resume()
}
}