Eclipse Kapua

Eclipse Kapua est une plate-forme de cloud IoT modulaire, intégrée et interopérable pour gérer et intégrer les périphériques et leurs données, et fournir une base solide pour les services IoT pour toute application IoT.

Histoire
Eclipse Kapua a débuté sous la forme d'un projet d'incubateur open source sous le groupe de travail Eclipse IoT. En octobre 2016, le code source de la première goutte d'Eclipse Kapua a été fourni par Eurotech, en collaboration avec Red Hat.

Description
Eclipse Kapua ™ est une plateforme modulaire fournissant les services requis pour gérer les passerelles IoT et les périphériques intelligents. Kapua fournit un cadre d'intégration de base et un ensemble initial de services IoT de base, notamment un registre de périphériques, des services de gestion des périphériques, des services de messagerie, la gestion des données et l'activation des applications.

Fonctionnement
Eclipse Kapua fournit les services requis pour gérer les passerelles IoT et les périphériques intelligents, à travers un framework d'intégration de base. Il offre un ensemble initial de services pour le registre des périphériques, la gestion des périphériques, le routage des messages, l'intégration des données et l'activation des applications.

L'objectif du projet Eclipse Kapua est de fournir une plate-forme d'intégration IoT basée sur le cloud avec les fonctionnalités de haut niveau suivantes: aux protocoles IoT établis comme MQTT. D'autres protocoles comme AMQP, HTTP et CoAP seront ajoutés au fil du temps. La couche de connectivité est également responsable de la gestion de l'authentification et de l'autorisation des appareils. applications et les microprogrammes des périphériques et de contrôler le périphérique à distance. La plate-forme IoT expose un contrat ouvert vers le périphérique cible géré sans aucune hypothèse sur la pile logicielle de l'appareil. l'archivage des données pour les tableaux de bord ou les applications de business intelligence, ainsi que l'analyse en temps réel et les règles métier. Une caractéristique importante est la flexibilité et la configurabilité des routes d'intégration de données offrant des options de stockage de données pour collecter les données entrantes et les mettre à la disposition des applications d'entreprise en amont.
 * Gérer la connectivité pour les périphériques IoT et les passerelles IoT à travers un certain nombre de protocoles différents. Le soutien initial sera offert
 * Gérer les périphériques. La gestion des périphériques offre la possibilité d'inspecter la configuration des périphériques, de mettre à jour les
 * Pipelines de données pour les données provenant de dispositifs IoT collectant de grandes quantités de données de télémétrie. Les pipelines de données peuvent offrir
 * Gestion de compte multi-utilisateurs, gestion des utilisateurs, permissions et rôles.
 * Entièrement programmable via l'API RESTful. Une console d'administration Web pour un opérateur de périphérique est souhaitable.
 * Déploiement dans le cloud ou sur site, avec son packaging permettant des options de déploiement flexibles.

Architecture
Le diagramme suivant fournit une architecture fonctionnelle du projet Eclipse Kapua:



Pré-requis

 * Architecture 64 bits
 * JVM version 8
 * Docker version 1.2+
 * Accès internet

Cloner et lancer Kapua
> Cloner le dépôt git de Kapua $ git clone https://github.com/eclipse/kapua

> Créez et exécutez Demo Box de Kapua en utilisant le script de démarrage rapide. $ cd ./kapua/dev-tools/src/main/bin $ ./start-demo.sh

> Les services suivants sont alors disponbles et s'exécutent:



> La console d'administration est accessible à l'ardesse: http://localhost:8080/. > Pour se connecter:
 * Username: kapua-sys
 * Password: kapua-password

APIs RestFul
La documentation de l'API RESTFul est disponible à l'adresse http://localhost:8081/doc/. Le point de montage est quant à lui accessible à l'adresse: http://localhost:8081/v1/ Pour plus d'information: https://github.com/eclipse/kapua

Le Broker
Le conteneur de Broker expose un endpoint Mqtt accessible à l'adresse à tcp://localhost:1883/. Le Broker peut être accessible via Eclipse Kura ou un client Mqtt simple comme, par exemple, Eclipse Paho.

Pour qu'un client établisse une connexion Mqtt avec le Broker, il doit fournir des identifiants valides. Les informations d'identification de l'utilisateur kapua-broker sont les suivantes:
 * Username: kapua-sys
 * Password: kapua-password

> Notes:
 * Ne pas utiliser l'identifiant kapua-sys pour établir des connexions Mqtt.
 * Si vous utilisez Docker sous Windows, le nom d'hôte ne sera probablement pas localhost mais l'adresse IP de votre instance docker.

Liens utiles

 * https://github.com/eclipse/kapua/blob/develop/assembly/README.md
 * https://github.com/eclipse/kapua/blob/develop/dev-tools/src/main/vagrant/README.md#demo-machine-quick-start
 * https://github.com/eclipse/kapua/blob/develop/docs/developer-guide/en/running.md#openshift
 * http://download.eclipse.org/kapua/docs/develop/user-manual/en/
 * http://download.eclipse.org/kapua/docs/develop/developer-guide/en/