Uses new Rust 2021
|2.1.3||Jun 8, 2022|
|2.1.1||May 9, 2022|
|2.1.0||Jan 18, 2022|
|2.0.6||Sep 23, 2021|
|2.0.2||Apr 27, 2021|
#49 in Embedded development
41 downloads per month
Used in updatehub-cloud-sdk
|Linux - x86_64|
|Linux - AArch64|
|Linux - ARMv7|
UpdateHub is an enterprise-grade solution which makes simple to remotely update all your embedded devices in the field. It handles all aspects related to sending Firmware Over-the-Air (FOTA) updates with maximum security and efficiency, making your project the center of your attention.
This repository provides the UpdateHub agent for Embedded and Industrial Linux-based devices.
To start using UpdateHub, it is suggested that you follow the Getting started guide in the UpdateHub documentation.
The support provided by the UpdateHub for the device includes:
- Bootloader upgrade support (U-Boot and GRUB)
- Flash support (NAND, NOR)
- UBIFS support
- Update package signature validation for security
- Automated rollback in case of update fail
- Conditional installation (content, version and custom pattern support)
- Callback support for every update step
- HTTP API to control and inquiry the local agent
To learn more about UpdateHub, check out our documentation.
Building and testing
The UpdateHub agent is developed using Rust programing language due its focus in safety and system level integration. In case you wish to build it, you can:
cargo build --release
Some tests are marked as ignored because they require user previleges. There's a Vagrant file that can be used to run them. To run tests on the virtual machine run:
vagrant up vagrant ssh
and inside the SSH session, run:
sudo -i cd /vagrant cargo test cargo test -- --ignored
Licensed under Apache License, Version 2.0 (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0).
UpdateHub is an open source project and we love to receive contributions from our community. If you would like to contribute, please read our contributing guide.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.