123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- /*
- * Copyright (c) 2020 Linumiz
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- /**
- * @brief Hawkbit Firmware Over-the-Air for Zephyr Project.
- * @defgroup hawkbit Hawkbit Firmware Over-the-Air
- * @ingroup lib
- * @{
- */
- #ifndef ZEPHYR_INCLUDE_MGMT_HAWKBIT_H_
- #define ZEPHYR_INCLUDE_MGMT_HAWKBIT_H_
- #define HAWKBIT_JSON_URL "/default/controller/v1"
- /**
- * @brief Response message from Hawkbit.
- *
- * @details These messages are used to inform the server and the
- * user about the process status of the Hawkbit and also
- * used to standardize the errors that may occur.
- *
- */
- enum hawkbit_response {
- HAWKBIT_NETWORKING_ERROR,
- HAWKBIT_UNCONFIRMED_IMAGE,
- HAWKBIT_METADATA_ERROR,
- HAWKBIT_DOWNLOAD_ERROR,
- HAWKBIT_OK,
- HAWKBIT_UPDATE_INSTALLED,
- HAWKBIT_NO_UPDATE,
- HAWKBIT_CANCEL_UPDATE,
- HAWKBIT_PROBE_IN_PROGRESS,
- };
- /**
- * @brief Init the flash partition
- *
- * @return 0 on success, negative on error.
- */
- int hawkbit_init(void);
- /**
- * @brief Runs Hawkbit probe and Hawkbit update automatically
- *
- * @details The hawkbit_autohandler handles the whole process
- * in pre-determined time intervals.
- */
- void hawkbit_autohandler(void);
- /**
- * @brief The Hawkbit probe verify if there is some update to be performed.
- *
- * @return HAWKBIT_UPDATE_INSTALLED has an update available.
- * @return HAWKBIT_NO_UPDATE no update available.
- * @return HAWKBIT_NETWORKING_ERROR fail to connect to the Hawkbit server.
- * @return HAWKBIT_METADATA_ERROR fail to parse or to encode the metadata.
- * @return HAWKBIT_OK if success.
- * @return HAWKBIT_DOWNLOAD_ERROR faile while downloading the update package.
- */
- enum hawkbit_response hawkbit_probe(void);
- /**
- * @}
- */
- #endif /* _HAWKBIT_H_ */
|