nabd est un serveur TCP/IP et s'interface ainsi avec les daemons des services. Il écoute sur le port 10543. Chaque paquet est sur une ligne (CRLF), encodée en JSON. Chaque paquet comprend un slot "type".
Indication de l'état du lapin. Ce paquet est envoyé lors de la connexion et lors de tout changement d'état.
Émetteur: nabd
{"type":"state","state":state}
Le slot "state"
peut être :
"asleep"
: le lapin dort ;"idle"
: le lapin est éveillé et affiche les infos ;"interactive"
: le lapin est en mode interactif ;"playing"
: le lapin joue une commande.
Modification de l'animation visuelle du lapin, c'est-à-dire ce qu'il affiche au repos (mode "idle"
).
Émetteurs: services
{"type":"info","request_id":request_id,"info_id":info_id,"animation":animation}
Le slot "request_id"
est optionnel et est retourné dans la réponse.
Le slot "info_id"
, requis, indique l'identification de l'info. C'est cette séquence qui est modifiée. info_id
est une chaîne.
Le slot "animation"
, optionnel, indique l'animation visuelle. S'il est absent, l'info est supprimée. S'il est présent, c'est un objet:
{"tempo":tempo, "colors":colors}
tempo
est en ms.
colors
est une liste pour les couleurs des leds :
{"left":color,"center":color,"right":color}
Tous les slots sont optionnels ({}
= toutes les leds sont éteintes).
color
peut être :
- un nombre de 0 à 15 représentant une valeur dans la palette originale (0 = noir, 15 = orange)
- un texte représentant la couleur au format HTML ('#' suivi de 3 octets en hexa) ou symbolique
Modification de la position des oreilles au repos (mode "idle"
). La position des oreilles en mode interactif peut être modifiée avec un paquet "command"
via une chorégraphie. Le paquet de type "ears"
est conçu pour le service mariage d'oreilles.
Émetteurs: services
{"type":"ears","request_id":request_id,"left":left_ear,"right":right_ear}
Le slot "request_id"
est optionnel et est retourné dans la réponse.
Les slots "left"
et "right"
sont optionnels (un seul est requis), et left_ear
comme right_ear
sont des entiers représentant la position.
Commande à exécuter par le lapin.
Émetteurs: services
{"type":"command","request_id":request_id,"sequence":sequence,"expiration":expiration_date,"cancelable":cancelable}
Le slot "request_id"
est optionnel et est retourné dans la réponse.
Le slot "expiration"
est optionnel et indique la date d'expiration de la commande. La commande est jouée quand le lapin est disponible (pas endormi, pas en train de faire autre chose) et si la date d'expiration n'est pas atteinte.
Le slot "sequence"
est requis et sequence
est une liste d'éléments du type :
{"audio":audio_list,"choreography":choreography}
Les slots "audio"
et "choreography"
sont optionnels.
audio_list
est une liste de sons à jouer.
Chaque son peut être :
- une liste de ressources, séparées par des ";", la première trouvée est celle qui sera jouée.
Chaque ressource est un chemin vers un son tel que
"nabmastodon/communion.wav"
. L'algorithme essaie d'abord dans le sous-répertoire de chaque application correspondant à la langue actuelle du lapin ("sounds/fr_FR"
) puis dans le répertoire"sounds"
, les applications dans l'ordre de"settings.py"
. Si la ressource termine par"*"
ou"*.suffixe"
, le son est choisi au hasard dans les éléments du répertoire correspondant.
choreography
peut être :
- une liste de ressources vers les chorégraphies sur le même mécanisme que les sons, dans les répertoires
choreographies
des différentes applications. "urn:x-chor:streaming"
pour la chorégraphie de streaming avec palette aléatoire."urn:x-chor:streaming:N"
pour la chorégraphie de streaming avec palette N."data:application/x-nabaztag-mtl-choreography;base64,<BASE64>"
pour une chorégraphie fournie en Base64
La chorégraphie est jouée pendant la lecture des différents fichiers audios de la liste et est interrompue à la fin de l'audio. Si aucun son n'est joué, la chorégraphie est jouée jusqu'au bout. Si la même chorégraphie est indiquée pour les différentes séquences, elle n'est pas interrompue.
Le slot "cancelable"
est optionnel. Par défaut, la commande sera annulée par un click sur le bouton. Si cancelable
est false
, la commande n'est pas annulée par le bouton (le service doit gérer le bouton).
Messages à faire diffuser par le lapin.
Émetteurs: services
{"type":"message","request_id":request_id,"signature":signature,"body":body,"cancelable":cancelable}
Le slot "request_id"
est optionnel et est retourné dans la réponse.
Le slot "expiration"
est optionnel et indique la date d'expiration de la commande. La commande est jouée quand le lapin est disponible (pas endormi, pas en train de faire autre chose) et si la date d'expiration n'est pas atteinte.
Le slot "signature"
est optionnel et est du type :
{"audio":audio_list,"choreography":choreography}
Le slot "body"
est requis et est une liste d'éléments du type :
{"audio":audio_list,"choreography":choreography}
Les slots "audio"
et "choreography"
sont optionnels.
audio_list
est une liste de sons à jouer, comme pour les paquets "command"
.
choreography
est une chorégraphie, comme pour les paquets "command"
. Cependant, si la chorégraphie n'est pas précisée, alors c'est la chorégraphie de streaming qui est utilisée.
La signature est jouée en premier, suivi du corps du message, puis la signature est rejouée.
Le slot "cancelable"
est optionnel. Par défaut, la commande sera annulée par un click sur le bouton. Si cancelable
est false
, la commande n'est pas annulée par le bouton (le service doit gérer le bouton).
Annule une commande en cours d'exécution (ou programmée).
Émetteurs: services
{"type":"cancel","request_id":request_id}
Le slot "request_id"
est requis et correspond au slot "request_id"
de la commande passée. Ne fonctionne que pour les commandes et les messages, pas pour les autres paquets.
Réveille le lapin.
Émetteurs: services
{"type":"wakeup","request_id":request_id}
Le slot "request_id"
est optionnel et est retourné dans la réponse.
Endort le lapin. Le lapin s'endort dès que toutes les commandes sont exécutées et qu'il est en mode "idle"
.
Émetteurs: services
{"type":"sleep","request_id":request_id}
Le slot "request_id"
est optionnel et est retourné dans la réponse.
Émetteurs: services
Change le mode pour un service donné.
{"type":"mode","request_id":request_id,"mode":mode,"events":events}
Le slot "mode"
peut être:
"idle"
"interactive"
Le slot "events"
, optionnel, est une liste avec:
"asr"
"button"
"ears"
Pour le mode "idle"
, si "events"
n'est pas précisé, cela est équivalent à la liste vide: le service ne reçoit aucun événement. Si "asr"
, "button"
ou "ears"
sont précisés, le service reçoit les événements correspondants lorsque le lapin est éveillé et n'est pas en mode "interactive"
avec un autre service. Par défaut, le mode est "idle"
, sans événements.
Dans le mode "interactive"
, le service prend la main sur le lapin et reçoit les événéments précisés. Le lapin cesse d'afficher les infos. Un seul service peut être en mode interactif. Si non précisé, le service reçoit tous les événements. Les autres services ne reçoivent pas les événements, le lapin ne joue pas les commmandes et ne s'endort pas. Le mode interactif s'achève lorsque le service envoie un paquet "mode"
avec le mode "idle"
(ou lorsque la connexion est rompue).
Émetteur: nabd
Signifie aux services qu'une commande vocale a été comprise. Le slot "nlu" contient le détail de la commande comprise, à partir du moteur de NLU. En particulier, le slot "intent" contient l'intention détectée.
{'type': 'asr_event', 'nlu': {'intent': intent}}
Émetteur: nabd
Signifie aux services que les oreilles ont été bougées.
En mode "idle"
, nabd calcule la position en lançant une détection et envoie aux services (pour le mariage d'oreilles).
Le paquet a alors cette forme :
{"type":"ears_event","left":ear_left,"right":ear_right}
En mode "interactive"
, nabd envoie le fait que l'oreille a bougé.
Le paquet a alors cette forme :
{"type":"ears_event","ear": ear}
Émetteur: nabd
Signifie aux services que le bouton a été appuyé. Est envoyé aux services qui demandent ce type d'événements (mode "idle"
/"interactive"
).
{"type":"button_event","event":event}
Le slot "event"
peut être:
"down"
"up"
"click"
"double_click"
"click_and_hold"
Émetteur: nabd
Réponse de nabd à un paquet d'un service.
{"type":"response","request_id":request_id,"status":"ok"}
{"type":"response","request_id":request_id,"status":"canceled"}
{"type":"response","request_id":request_id,"status":"expired"}
{"type":"response","request_id":request_id,"status":"error","class":class,"message":message}
Le statut "ok"
signifie que l'info a été ajoutée ou que la commande a été exécutée ou le mode changé. Dans le cas d'une commande, cette réponse est envoyée lorsque la commande est terminée. Idem pour le paquet "sleep"
. Le slot "request_id"
, s'il est présent, reprend l'id fourni dans la requête.
Le statut "canceled"
signifie que l'utilisateur a annulé la commande avec le bouton.
Le statut "expired"
signifie que la commande est expirée.
Le statut "error"
signifie une erreur dans le protocole. class
et message
sont des chaînes.
Utilisés en interne pour la communication entre le site web et nabd.