diff --git a/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV130.swift b/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV130.swift index 5af59edc00..1dc47e2e84 100644 --- a/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV130.swift +++ b/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV130.swift @@ -300,6 +300,7 @@ private class StateVerifyingFile: GKState, StateEventProcessor { private var cancellables: Set = [] private var isFileValid = false + private var lastValue = "0000000000000000000000000000000000000000000000000000000000000000" private var nextStateIsClearingFile = false @@ -312,6 +313,8 @@ private class StateVerifyingFile: GKState, StateEventProcessor { override func didEnter(from previousState: GKState?) { if previousState is StateSettingDestinationPath { nextStateIsClearingFile = true + } else { + nextStateIsClearingFile = false } DispatchQueue.main.asyncAfter(deadline: .now() + 1, execute: startFileVerification) @@ -349,9 +352,10 @@ private class StateVerifyingFile: GKState, StateEventProcessor { .sink { value in guard let value = value else { return } - if value == "0000000000000000000000000000000000000000000000000000000000000000" { + if value == self.lastValue { return } + self.lastValue = value self.isFileValid = value == globalFirmwareManager.sha256 self.process(event: .fileVerificationReceived) @@ -524,6 +528,7 @@ class UpdateProcessV130: UpdateProcessProtocol { private var stateMachine: GKStateMachine? private var stateSendingFile = StateSendingFile() + private var stateVerifyingFile = StateVerifyingFile() private var cancellables: Set = [] @@ -541,7 +546,7 @@ class UpdateProcessV130: UpdateProcessProtocol { StateSettingDestinationPath(), StateClearingFile(), stateSendingFile, - StateVerifyingFile(), + stateVerifyingFile, StateApplyingUpdate(), StateWaitingForRobotToReboot(),