Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/rauc/rauc-hawkbit

RAUC hawkBit Client
https://github.com/rauc/rauc-hawkbit

iot rauc software-provisioning updating

Last synced: 2 months ago
JSON representation

RAUC hawkBit Client

Awesome Lists containing this project

README

        

RAUC hawkBit Client
===================

|license| |build-status| |coverage-status| |docs-status|

The RAUC hawkBit client is a simple python-based library and **demo
application** that runs on your target and operates as an interface between the
`RAUC `_ D-Bus API
and the `hawkBit `_ DDI API.

**Important:**
This project is not intended for production use.
Consider using `rauc-hawkbit-updater `_ instead.

Quickstart
----------

Despite the rauc-hawkbit client is primarily meant to be used as a library,
it also provides a simple example application that allows you to instantly
start with a small configuration file.

To quickly build and start a hawkBit server, follow
`this `_
instruction.

Then setup your configuration file:

.. code-block:: ini

[client]
hawkbit_server = 127.0.0.1:8080
ssl = false
tenant_id = DEFAULT
target_name = test-target
auth_token = bhVahL1Il1shie2aj2poojeChee6ahShu
mac_address = 12:34:56:78:9A:BC
bundle_download_location = /tmp/bundle.raucb

Finally start the client application:

.. code-block:: sh

./rauc-hawkbit-client -c config.cfg

Documentation
-------------
`Read the Docs `_

Contributing
------------
`Development Docs `_

Background
----------
Work on the RAUC hawkBit client started at `Pengutronix
`_ in the middle of 2016 as part of a customer's project
and for demonstration purposes. In May 2017 the decision was made to restructure
and clean up the code and publish it as Open Source software.

Example Usage
-------------

The ``RaucDBUSDDIClient`` class from the ``rauc_hawkbit`` module allows you to
simply setup an interface between RAUC and hawkBit.

.. code-block:: python

from rauc_hawkbit.rauc_dbus_ddi_client import RaucDBUSDDIClient

...

async with aiohttp.ClientSession() as session:
client = RaucDBUSDDIClient(session, HOST, SSL, TENANT_ID, TARGET_NAME,
AUTH_TOKEN, ATTRIBUTES, BUNDLE_DL_LOCATION,
result_callback, step_callback)
await client.start_polling()

If you only want use the hawkBit interface from your python project, you can
use the DDIClient class.

.. code-block:: python

from rauc_hawkbit.ddi.client import DDIClient

...

ddi = DDIClient(session, host, ssl, auth_token, tenant_id, target_name)
base = await self.ddi()

if '_links' in base:
if 'configData' in base['_links']:
await self.identify(base)

Debugging
---------

When setting the log level to 'debug' the RAUC hawkBit client will print API
URLs and JSON payload sent and received. This can be done either by setting
``log_level`` from the config file

.. code-block:: ini

[client]
...
log_level = debug

or by providing the ``-d`` (``--debug``) switch when calling the client.

.. code-block:: sh

./rauc-hawkbit-client -d

Copyright
---------

| Copyright (C) 2016-2020 Pengutronix, Enrico Joerns
| Copyright (C) 2016-2020 Pengutronix, Bastian Stender
|
| This library is free software; you can redistribute it and/or
| modify it under the terms of the GNU Lesser General Public
| License as published by the Free Software Foundation; either
| version 2.1 of the License, or (at your option) any later version.
|
| This library is distributed in the hope that it will be useful,
| but WITHOUT ANY WARRANTY; without even the implied warranty of
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
| Lesser General Public License for more details.
|
| You should have received a copy of the GNU Lesser General Public
| License along with this library; if not, write to the Free Software
| Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA

.. |license| image:: https://img.shields.io/badge/license-LGPLv2.1-blue.svg
:alt: LGPLv2.1
:target: https://raw.githubusercontent.com/rauc/rauc-hawkbit/master/COPYING

.. |build-status| image:: https://img.shields.io/travis/com/rauc/rauc-hawkbit/master.svg?style=flat
:alt: build status
:target: https://travis-ci.com/rauc/rauc-hawkbit

.. |coverage-status| image:: https://codecov.io/gh/rauc/rauc-hawkbit/branch/master/graph/badge.svg
:alt: coverage status
:target: https://codecov.io/gh/rauc/rauc-hawkbit

.. |docs-status| image:: https://readthedocs.org/projects/rauc-hawkbit/badge/?version=latest
:alt: documentation status
:target: https://rauc-hawkbit.readthedocs.io/en/latest/?badge=latest