NetNewsWire/Frameworks/Account/Feedly/Operations/FeedlyLogoutOperation.swift

52 lines
1.2 KiB
Swift
Raw Normal View History

2019-11-15 09:09:14 +01:00
//
// FeedlyLogoutOperation.swift
// Account
//
// Created by Kiel Gillard on 15/11/19.
// Copyright © 2019 Ranchero Software, LLC. All rights reserved.
//
import Foundation
import os.log
protocol FeedlyLogoutService {
func logout(completion: @escaping (Result<Void, Error>) -> ())
2019-11-15 09:09:14 +01:00
}
final class FeedlyLogoutOperation: FeedlyOperation {
2019-11-15 09:09:14 +01:00
let service: FeedlyLogoutService
let account: Account
let log: OSLog
init(account: Account, service: FeedlyLogoutService, log: OSLog) {
self.service = service
self.account = account
self.log = log
}
override func run() {
2019-11-15 09:09:14 +01:00
os_log("Requesting logout of %{public}@ account.", "\(account.type)")
service.logout(completion: didCompleteLogout(_:))
2019-11-15 09:09:14 +01:00
}
func didCompleteLogout(_ result: Result<Void, Error>) {
assert(Thread.isMainThread)
switch result {
case .success:
os_log("Logged out of %{public}@ account.", "\(account.type)")
do {
try account.removeCredentials(type: .oauthAccessToken)
try account.removeCredentials(type: .oauthRefreshToken)
} catch {
// oh well, we tried our best.
}
didFinish()
case .failure(let error):
os_log("Logout failed because %{public}@.", error as NSError)
didFinish(with: error)
2019-11-15 09:09:14 +01:00
}
}
}