From 0b22f9aa2ef11ae37c32e72b74158a334c6e9177 Mon Sep 17 00:00:00 2001 From: Yann Locatelli Date: Wed, 17 Jan 2024 17:56:59 +0100 Subject: [PATCH] :zap: (LekaUpdater): Set version and apply update in cascade --- .../Version/UpdateProcessV100.swift | 18 ++++++++++----- .../Version/UpdateProcessV130.swift | 22 ++++++++++--------- 2 files changed, 24 insertions(+), 16 deletions(-) diff --git a/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV100.swift b/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV100.swift index 2846b1b6dd..be5099f6cc 100644 --- a/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV100.swift +++ b/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV100.swift @@ -261,8 +261,7 @@ private class StateApplyingUpdate: GKState, StateEventProcessor { } override func didEnter(from _: GKState?) { - DispatchQueue.main.asyncAfter(deadline: .now() + 1, execute: self.setMajorMinorRevision) - DispatchQueue.main.asyncAfter(deadline: .now() + 2, execute: self.applyUpdate) + self.setMajor() } override func willExit(to _: GKState) { @@ -282,30 +281,37 @@ private class StateApplyingUpdate: GKState, StateEventProcessor { private var cancellables: Set = [] - private func setMajorMinorRevision() { + private func setMajor() { let majorData = Data([globalFirmwareManager.major]) let majorCharacteristic = CharacteristicModelWriteOnly( characteristicUUID: BLESpecs.FirmwareUpdate.Characteristics.versionMajor, - serviceUUID: BLESpecs.FirmwareUpdate.service + serviceUUID: BLESpecs.FirmwareUpdate.service, + onWrite: self.setMinor ) Robot.shared.connectedPeripheral?.send(majorData, forCharacteristic: majorCharacteristic) + } + private func setMinor() { let minorData = Data([globalFirmwareManager.minor]) let minorCharacteristic = CharacteristicModelWriteOnly( characteristicUUID: BLESpecs.FirmwareUpdate.Characteristics.versionMinor, - serviceUUID: BLESpecs.FirmwareUpdate.service + serviceUUID: BLESpecs.FirmwareUpdate.service, + onWrite: self.setRevision ) Robot.shared.connectedPeripheral?.send(minorData, forCharacteristic: minorCharacteristic) + } + private func setRevision() { let revisionData = globalFirmwareManager.revision.data let revisionCharacteristic = CharacteristicModelWriteOnly( characteristicUUID: BLESpecs.FirmwareUpdate.Characteristics.versionRevision, - serviceUUID: BLESpecs.FirmwareUpdate.service + serviceUUID: BLESpecs.FirmwareUpdate.service, + onWrite: self.applyUpdate ) Robot.shared.connectedPeripheral?.send(revisionData, forCharacteristic: revisionCharacteristic) diff --git a/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV130.swift b/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV130.swift index e90b08e507..5e9d4deeef 100644 --- a/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV130.swift +++ b/Apps/LekaUpdater/Sources/Libs/UpdateProcess/Version/UpdateProcessV130.swift @@ -335,8 +335,7 @@ private class StateApplyingUpdate: GKState, StateEventProcessor { } override func didEnter(from _: GKState?) { - DispatchQueue.main.asyncAfter(deadline: .now() + 1, execute: self.setMajorMinorRevision) - DispatchQueue.main.asyncAfter(deadline: .now() + 5, execute: self.applyUpdate) + self.setMajor() } override func willExit(to _: GKState) { @@ -356,34 +355,37 @@ private class StateApplyingUpdate: GKState, StateEventProcessor { private var cancellables: Set = [] - private func setMajorMinorRevision() { + private func setMajor() { let majorData = Data([globalFirmwareManager.major]) let majorCharacteristic = CharacteristicModelWriteOnly( characteristicUUID: BLESpecs.FirmwareUpdate.Characteristics.versionMajor, - serviceUUID: BLESpecs.FirmwareUpdate.service + serviceUUID: BLESpecs.FirmwareUpdate.service, + onWrite: self.setMinor ) Robot.shared.connectedPeripheral?.send(majorData, forCharacteristic: majorCharacteristic) + } - sleep(1) - + private func setMinor() { let minorData = Data([globalFirmwareManager.minor]) let minorCharacteristic = CharacteristicModelWriteOnly( characteristicUUID: BLESpecs.FirmwareUpdate.Characteristics.versionMinor, - serviceUUID: BLESpecs.FirmwareUpdate.service + serviceUUID: BLESpecs.FirmwareUpdate.service, + onWrite: self.setRevision ) Robot.shared.connectedPeripheral?.send(minorData, forCharacteristic: minorCharacteristic) + } - sleep(1) - + private func setRevision() { let revisionData = globalFirmwareManager.revision.data let revisionCharacteristic = CharacteristicModelWriteOnly( characteristicUUID: BLESpecs.FirmwareUpdate.Characteristics.versionRevision, - serviceUUID: BLESpecs.FirmwareUpdate.service + serviceUUID: BLESpecs.FirmwareUpdate.service, + onWrite: self.applyUpdate ) Robot.shared.connectedPeripheral?.send(revisionData, forCharacteristic: revisionCharacteristic)