Newer
Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import AppCore
import ComposableArchitecture
import Foundation
import XCTestDynamicOverlay
import XXClient
import XXMessengerClient
import XXModels
public struct VerifyContactComponent: ReducerProtocol {
public struct State: Equatable {
public enum Result: Equatable {
case success(Bool)
case failure(String)
}
public init(
contact: XXClient.Contact,
isVerifying: Bool = false,
result: Result? = nil
) {
self.contact = contact
self.isVerifying = isVerifying
self.result = result
}
public var contact: XXClient.Contact
public var isVerifying: Bool
public var result: Result?
}
public enum Action: Equatable {
case verifyTapped
case didVerify(State.Result)
}
public init() {}
@Dependency(\.app.messenger) var messenger: Messenger
@Dependency(\.app.dbManager.getDB) var db: DBManagerGetDB
@Dependency(\.app.mainQueue) var mainQueue: AnySchedulerOf<DispatchQueue>
@Dependency(\.app.bgQueue) var bgQueue: AnySchedulerOf<DispatchQueue>
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
public func reduce(into state: inout State, action: Action) -> EffectTask<Action> {
switch action {
case .verifyTapped:
state.isVerifying = true
state.result = nil
return Effect.result { [state] in
func updateStatus(_ status: XXModels.Contact.AuthStatus) throws {
try db().bulkUpdateContacts.callAsFunction(
.init(id: [try state.contact.getId()]),
.init(authStatus: status)
)
}
do {
try updateStatus(.verificationInProgress)
let result = try messenger.verifyContact(state.contact)
try updateStatus(result ? .verified : .verificationFailed)
return .success(.didVerify(.success(result)))
} catch {
try? updateStatus(.verificationFailed)
return .success(.didVerify(.failure(error.localizedDescription)))
}
}
.subscribe(on: bgQueue)
.receive(on: mainQueue)
.eraseToEffect()
case .didVerify(let result):
state.isVerifying = false
state.result = result
return .none
}
}
}