Compare commits

..

1 Commits

Author SHA1 Message Date
VC
03ec18ce10 test: ci pipeline
All checks were successful
release / build (push) Successful in 35s
2025-02-28 16:59:57 +01:00
13 changed files with 16 additions and 283 deletions

View File

@@ -2,9 +2,7 @@
name: release name: release
on: on:
push: - push
tags:
- '*'
jobs: jobs:
build: build:
@@ -16,11 +14,8 @@ jobs:
uses: shalzz/zola-deploy-action@v0.20.0 uses: shalzz/zola-deploy-action@v0.20.0
env: env:
BUILD_ONLY: true BUILD_ONLY: true
- name: Create archive - run: tar -czvf bac-public-$(date -I).tar.gz public/
run: tar -czf public.tar.gz public/ - name: Do release
- name: Create release uses: actions/upload-artifact@v4
uses: https://gitea.com/actions/gitea-release-action@v1
with: with:
files: |- path: bac-public-$(date -I).tar.gz
public.tar.gz
api_key: '${{secrets.RELEASE_TOKEN}}'

View File

@@ -173,7 +173,7 @@ Conclusion de la conclusion: ça peut être interéssant de désactiver compl
Pour cela, on pourra ajouter les lignes suivantes dans le `/etc/rc.local`: Pour cela, on pourra ajouter les lignes suivantes dans le `/etc/rc.local`:
```bash ```shell
sysctl net.ipv4.conf.all.forwarding=0 sysctl net.ipv4.conf.all.forwarding=0
sysctl net.ipv6.conf.all.forwarding=0 sysctl net.ipv6.conf.all.forwarding=0
``` ```

View File

@@ -44,7 +44,7 @@ En toute logique, cest un cas assez standard et plutôt simple à mettre en
Donc côté «client», on peut donc commencer par un `main.cf` de ce type: Donc côté «client», on peut donc commencer par un `main.cf` de ce type:
```conf ```postfix
# des trucs génériques dont on se fout un peu # des trucs génériques dont on se fout un peu
smtpd_banner = $myhostname ESMTP $mail_name (Debian/GNU) smtpd_banner = $myhostname ESMTP $mail_name (Debian/GNU)
biff = no biff = no
@@ -77,7 +77,7 @@ smtpd_relay_restrictions = permit_mynetworks,defer_unauth_destination,reject
Et donc effectivement, toute la magie tient dans les variables `smtp_sasl_*` et notamment le fichier `/etc/postfix/sasl_passwd`, qui contient lutilisateur/mot de passe pour le serveur SMTP: Et donc effectivement, toute la magie tient dans les variables `smtp_sasl_*` et notamment le fichier `/etc/postfix/sasl_passwd`, qui contient lutilisateur/mot de passe pour le serveur SMTP:
```conf ```postfix
[smtp.buttse.cx]:587 utilisateur:mot_de_passe [smtp.buttse.cx]:587 utilisateur:mot_de_passe
``` ```
@@ -95,7 +95,7 @@ Du coup, il va falloir ruser pour convaincre *Postfix* de faire comme dhabitu
Sous Debian/Ubuntu, tu peux donc installer le paquet `stunnel4` et faire une petite configuration de ce type, dans `/etc/stunnel/smtp-wrapper.conf`: Sous Debian/Ubuntu, tu peux donc installer le paquet `stunnel4` et faire une petite configuration de ce type, dans `/etc/stunnel/smtp-wrapper.conf`:
```conf ```stunnel
[smtp-tls-wrapper] [smtp-tls-wrapper]
accept = 10465 accept = 10465
client = yes client = yes
@@ -104,13 +104,13 @@ connect = smtp.tem.buttse.cx:465
Et du coup, lorsque lon démarre le service `stunnel4`, on voit effectivement quil écoute sur le port 10465. Il suffit alors de reconfigurer notre petit *Postfix* comme suit pour sadapter: Et du coup, lorsque lon démarre le service `stunnel4`, on voit effectivement quil écoute sur le port 10465. Il suffit alors de reconfigurer notre petit *Postfix* comme suit pour sadapter:
```conf ```postfix
relayhost = [localhost]:10465 relayhost = [localhost]:10465
``` ```
Et évidemment, changer également le login/pass/host dans `/etc/postfix/sasl_passwd`: Et évidemment, changer également le login/pass/host dans `/etc/postfix/sasl_passwd`:
```conf ```sasl_passwd
[localhost]:10465 login:pass [localhost]:10465 login:pass
``` ```
@@ -122,13 +122,13 @@ Quand il sagit de *cron*, le service a tendance à envoyer les messages à l
Pour cela, on peut forcer *Postfix* à faire une réécriture de tous les messages de destination pour les envoyer ailleurs. Ce nest pas bien compliqué, il suffit dajouter la ligne suivante dans le `main.cf`: Pour cela, on peut forcer *Postfix* à faire une réécriture de tous les messages de destination pour les envoyer ailleurs. Ce nest pas bien compliqué, il suffit dajouter la ligne suivante dans le `main.cf`:
```conf ```postfix
recipient_canonical_maps = regexp:/etc/postfix/recipient_canonical recipient_canonical_maps = regexp:/etc/postfix/recipient_canonical
``` ```
Et le fichier `/etc/postfix/recipient_canonical` se présentera comme suit: Et le fichier `/etc/postfix/recipient_canonical` se présentera comme suit:
```conf ```postfix
/.+/ admin@buttse.cx /.+/ admin@buttse.cx
``` ```
@@ -146,7 +146,7 @@ Heureusement, encore une fois *Postfix* à la rescousse! On peut aussi forcer
Pour cela, il va falloir ajouter quelques lignes dans notre `main.cf`: Pour cela, il va falloir ajouter quelques lignes dans notre `main.cf`:
```conf ```postfix
sender_canonical_classes = envelope_sender, header_sender sender_canonical_classes = envelope_sender, header_sender
sender_canonical_maps = regexp:/etc/postfix/sender_canonical_maps sender_canonical_maps = regexp:/etc/postfix/sender_canonical_maps
smtp_header_checks = regexp:/etc/postfix/header_check smtp_header_checks = regexp:/etc/postfix/header_check
@@ -154,7 +154,7 @@ smtp_header_checks = regexp:/etc/postfix/header_check
Et on produit donc les deux *maps* permettant de changer les deux entêtes à la fois dans `/etc/postfix/sender_canonical_maps` et `/etc/postfix/header_check` (cest exactement le même fichier): Et on produit donc les deux *maps* permettant de changer les deux entêtes à la fois dans `/etc/postfix/sender_canonical_maps` et `/etc/postfix/header_check` (cest exactement le même fichier):
```conf ```postfix
/.+/ youplaboom@mondomainesour.ce /.+/ youplaboom@mondomainesour.ce
``` ```

View File

@@ -5,7 +5,7 @@ date = 2023-12-08
tags = [ "truenas", "minio", "s3", "sysadmin", "système" ] tags = [ "truenas", "minio", "s3", "sysadmin", "système" ]
+++ +++
> La mauvaise doc, tu la lis… tu comprends rien! La bonne doc, tu la lis… bon tu comprends rien non plus, mais cest une bonne doc! > La mauvaise doc, tu la lis… tu comprends rien! La bonne doc, tu la lis… bon tu comprends rien non plus, mas cest une bonne doc!
<!-- more --> <!-- more -->

View File

@@ -1,131 +0,0 @@
+++
title = "Home Assistant: Projet Consonance"
date = 2025-07-18
[taxonomies]
tags = [ "système", "home assistant", "infrarouge", "logitech harmony", "consonance" ]
+++
> « Hail to the King, baby! »
*Duke Nukem ou quelque chose, je sais pas, jai pas joué au jeu*
<!-- more -->
# Le roi est mort, vive… ah attendez…
Pour ceux qui ne seraient pas au courant, [Logitech](https://www.logitech.com/fr-fr) a annoncé, il y a déjà quelques années, que les télécommandes de la série [Harmony](https://www.myharmony.com/fr-fr/) sarrêtait.
Non seulement, Logitech ne va plus les vendre, mais en plus, **les serveurs seront éteints courant de lannée 2025**. Or, nous sommes courant de lannée 2025 et certains serveurs sont effectivement déjà éteints, notamment celui de [lapplication historique de Logitech](https://members.harmonyremote.com/EasyZapper/) sur lequel sappuyait notamment le projet [Concordance](https://github.com/jaymzh/concordance) qui permettait aux utilisateurs de Linux de mettre à jour leur télécommande.
Lapplication Windows, écrite avec [Microsoft Silverlight](https://fr.wikipedia.org/wiki/Silverlight), non, non, ce nest pas une blague, continue de fonctionner mais avec un nombre de télécommandes bien plus limitées et pour un temps probablement lui aussi très limité.
Larrêt de serveurs ne transforme pas instantannément toutes les télécommandes Harmony en presse-papier. Elles ont été conçues au début des annnées 2000, période à laquelle il nétait pas forcément possible que tout appareil puisse être connecté.
Autrement dit, si tu as une télécommande Harmony, la bonne nouvelle cest quelle fonctionne toujours. La mauvaise, cest que si tu dois y effectuer le moindre changement, ajouter un appareil ou modifier une commande, et bien tu las dans los.
# Les alternatives
Larrêt ayant été annoncé en 2021, tu pourrais penser que des concurrents reprennent le flambeau. Et bien malheureusement, ça ne se passe pas tout-à-fait comme ça… Je te propose de jeter un petit coup dœil à ce qui pourrait remplacer une télécommande Harmony en 2025.
## HDMI CEC
Le concurrent n°1, cest évidemment… la norme HDMI elle-même! Nous sommes en 2025 et la plupart des gens ont des appareils connectés de manière numérique et utilisant une norme permettant le transfert de limage, du son **et des commandes**.
Ça sappelle le [HDMI CEC](https://fr.wikipedia.org/wiki/Consumer_Electronics_Control) et, tant quon ne lui en demande pas trop, ça «marche». Alors soyons très clair, si tas effectivement une télévision, une barre de son, une Nintendo Switch et un boîtier TV quelconque, ça marche.
Par contre, dès que tu commences à intégrer des appareils nayant pas de CEC, ou simplement que ton installation est plus compliquée que cela et bien ça merde dans les grandes largeurs. Le CEC a été conçu pour des cas simples avec des appareils à fonctions bien définies et uniques. Dès que lon rajoute ne serait-ce quun Switch HDMI, ça commence généralement à partir en couille.
Sans compter le fait quil est toujours compliqué de déterminer qui allume qui, qui éteint qui, etc…
Bref, je pense que cest **la raison** qui fait que Logitech a abandonné les télécommandes Harmony: avec le CEC, pour 90% des usages, cest largement suffisant, sa télécommande ne se justifiait plus que pour un marché de niche, voire dultra-niche. Mais il nempêche que pour les gens qui ont besoin de contrôler plus de choses, le CEC est plus un cauchemar quautre chose.
## SofaBaton
Présenté par certains comme **LA** solution à la défection de Logitech, [Sofabaton](https://www.sofabaton.com/), malgré son nom ridicule, est effectivement un sérieux concurrent. Une télécommande qui a lair bien foutue, une liste de compatibilité longue comme… enfin une très longue liste, et un appareil qui lui-même semble plutôt costaud et sympathique à utiliser.
Sofabaton présente aussi lavantage de proposer un hub, façon [Harmony Hub](https://support.myharmony.com/fr-fr/hub) sur certains modèles. Le hub, cest un truc à la con, mais quand on commande des appareils infrarouge, il faut obligatoirement avoir une ligne de vue vers les appareils en question. En fonction de comment est organisé ton salon et tes appareils, ça peut éventuellement être compliqué davoir systématiquement **tout** en ligne de mire pour lancer une commande. Donc on retiendra que le Hub, cest plutôt une bonne idée dans labsolu, surtout quil dispose de sorties infrarouge supplémentaires au cas où.
Par contre, toutes les Sofabaton ne naissent pas égales. Les modèles [U2](https://www.sofabaton.com/products/u2/) ne fonctionnent pas ainsi selon le principe dActivités qui a rendu les Logitech Harmony célèbres: tu appuies sur le bouton DVD, ça allume télé, les enceintes, lampli, le lecteur DVD lui-même et ça met toutes les bonnes entrées sur tout ce petit monde. Sans cela, et bien on a juste regroupé toutes les télécommandes en une, mais on na pas vraiment simplifié la façon de fonctionner de lensemble. Fort heureusement, les X1 et [X1S](https://www.sofabaton.com/products/x1s/) corrige le tir en prévoyant un fonctionnement par activité.
Autre problème: le prix. Quelques fois disponibles pour un peu moins de 200€, bah ça fait quand même 200€. Alors certes, les télécommandes Harmony ont toujours été assez chères aussi. En prenant compte de linflation, je pense quune Harmony One devait facilement coûter 300€. Mais la proposition de valeur nest plus tout-à-fait la même aujourdhui.
Mais en fait, le vrai gros point noir cest la configuration. Elle se fait toujours avec une appli, sur mobile cette fois, et cette appli, elle pourrait bien sarrêter dans quelques années, voire quelques mois. Et jai déjà donné, donc non merci…
## Unfolded Circle Remote Two/3
[Unfolded Circle](https://www.unfoldedcircle.com/), en dehors davoir un nom à coucher dehors, ça a lair dêtre des gens bien. Et leur produit, cest effectivement un avion de chasse: configuration locale à 100%, plusieurs milliers dappareils supportés, Bluetooth, gyroscope, *air-mouse*, chargement par induction, etc…
Cest un truc de gros furieux avec en plus un dock, des relais infrarouges, etc… Et en plus, une API ouverte et plein dautres trucs. On peut a priori y faire tout et surtout nimporte quoi avec à peu près nimporte quel appareil.
Le problème… cest le prix. À 399€, la télécommande seule, 499€ avec le dock, cest quand même putain de pas donné! La Rolls Royce des télécommandes, à nen pas douter, mais clairement une solution bien au-delà de mes moyens pour un truc de ce type.
# Bricole picole a.k.a. Projet Consonance
![img](/2025/07/harmony_unfolded.jpg)
Lautre alternative. Et bien, cest Home Assistant.
En fait, Home Assistant a déjà presque tout ce quil faut pour remplacer une télécommande Harmony: des scripts, des entités virtuelles et des intégrations de folie. On peut déjà y coller une TV connectée si on le souhaite, un Kodi, un Nvidia Shield, etc…
Donc en théorie, on peut déjà contrôler pas mal de trucs si on fait exception de tout ce qui est infrarouge.
## Blaste cet infrarouge!
Mais il se trouve quon peut aussi y coller un *IR Blaster*. Cest un petit appareil dont la seule utilité est de balancer des éléments infrarouge quon lui aura précédemment appris. Il en existe de nombreux: connecté à une application ou pas, en Zigbee, en Z-Wave, sur pile, sur batterie, etc… Cest presque sûr quon peut trouver de quoi faire son bonheur. Personnellement, jai opté pour le [Broadlink RM4 Pro](https://ebroadlink.com/products/universal-remote-rm4-pro).
Il vient avec une application qui permet de faire le premier paramétrage et après… on peut len détacher complètement et sen servir directement dans Home Assitant. Il est en Wi-Fi et prend deux commandes très simple: `learn_command` pour apprendre une commande existante et `send_command` pour envoyer une commande existante.
Alors effectivement, quand on le déconnecte de son appli, il faut se taper lapprentissage de toutes les commandes via les télécommandes dorigine ou via la Logitech Harmony encore opérationnelle. Mais lintérêt derrière, cest que cest un simple fichier JSON avec des informations assez simple: quel appareil, quelle commande, quel signal.
Donc changer dappareil pour envoyer des commandes, rien de plus simple en réalité.
Une fois le RM4 Pro intégré dans Home Assistant, via lintégration Broadlink, lapprentissage se fait en passant par le menu `Outils de développement`, dans `Actions`.
Voici un exemple:
![img](/2025/07/dev_learn_command_ha.png)
Cest un peu pénible à faire, mais jen ai eu pour à peu près une heure pour rentrer 5 télécommandes. Le plus relou restant les commandes qui nexistent pas sur la télécommande dorigine. Par exemple, ma télévision LG OLED peut aller directement sur la bonne entrée (`HDMI1`, `HDMI2`, etc…) mais ce nest pas une touche en accès direct. Il a donc fallu que je repasse par ma Logitech Harmony pour apprendre tout ça au Broadlink.
## Scripts
Maintenant quon a appris toutes les commandes, il reste à voir commander les ordonnancer proprement pour chaque activité. Et là, un second problème pointe son nez: quand on fait de linfrarouge, on ne peut pas vraiment savoir si lappareil a reçu la commande correctement ou non: on blaste les commandes suffisamment fort en espérant que ça passe.
![img](/2025/07/blasting.jpg)
Et le second souci à coupler à ce premier: la plupart des appareils infrarouge ont un seul et unique bouton pour allumer et éteindre. Cest un `power_toggle`. Il est assez rare davoir une commande dallumage et une commande dextinction. Cela veut dire que lon doit mémoriser quelque part létat de lappareil histoire de ne pas tout éteindre/tout allumer aléatoirement tout le temps.
> Note: lintégration Broadlink comprend une notion de [communateur (switch)](https://www.home-assistant.io/integrations/broadlink/#setting-up-custom-irrf-switches) qui permet de créer des interrupteurs virtuels. Si on possède effectivement une commande dallumage et une commande dextinction, ça marche plutôt bien. Malheureusement, cest rarement le cas.
Pour ce faire, jai créé des entités virtuelles représentant les différents appareils que je souhaite contrôler. Ce sont des simples interrupteurs (*on/off*) mais on pourrait imaginer de stocker plus dinformations que cela (par exemple la dernière entrée dun appareil).
Donc dans `Paramètres` > `Appareils et services` > `Entrées`, jai créé les 6 appareil contrôlés en infrarouge. Pour des raisons pratiques, je vais considérer que Kodi est contrôlé via son API (ce sera bien plus simple). Je leur ai tous donné une zolie icône et mis dans une catégorie `Consonance`, puisque ce sera le nom de ce projet. Concrètement, ça donne ça:
![img](/2025/07/home_assistant_config_helpers.png)
Partant de là, cest relativement simple: un script pour chaque activité et un script dextinction. Pour linstant, je ne souhaite pas compliquer les choses en permettant de passer dune activité à une autre, comme mon Harmony savait le faire. Cela pourra venir plus tard, ce nest pas particulièrement complexe à faire, ça demande juste un peu plus de temps pour pas grand-chose.
Dans le script dactivité:
* on envoie la commande `power_toggle` tous les appareils qui vont bien (TV, enceintes, etc…)
* on allume toutes les entrées logiques correspondantes pour garder la mémoire de ce qui est allumé
* on attend (5 secondes en général)
* on envoie toutes les commandes dentrée qui vont bien sur les appareils allumés
Et boum! On a une activité qui roule. Plus lactivité implique dappareils, plus les temps dattente vont varier, mais ce nest pas beaucoup plus lourd que ça à gérer.
Pour lextinction générale pareil, assez simple, pour chaque entrée logique:
* on vérifie si elle est allumé
* on envoie la commande `power_toggle`
* on éteint lentrée logique
Avec le langage de script dHome Assistant, il est difficile de faire des boucles, mais on peut faire des groupes ou traiter tous les appareils indépendamment. On pourrait donc très bien imaginer mettre les appareils dans un groupe ou une catégorie en fonction de lactivité et simplement sappuyer là-dessus pour gérer la partie interrupteur virtuelle.
Si lon veut éviter le gros gloubiboulga en basculant dune activité à lautre, on peut forcer le passage par le script dextinction. Pour cela, il suffit de rajouter une autre entrée logique permettant de dire quun activité est en cours (ou prendre une entrée logique existant dont on sait quelle est toujours allumée) et dajouter une condition au début de lexécution de chaque script dactivité pour arrêter sa propre exécution si lentrée logique en question est *on*. Ça rajoute encore une petite couche de logique un peu reloue à gérer, mais cest le prix à payer.
Si lon souhaitait éviter ce comportement et passer dune activité à une autre en passant par les mêmes scripts, il faudrait revenir à ce que lon disait plus haut: grouper les interrupteurs virtuels pour garder un état cohérent.
Sachant que, de toutes manières, on ne pourra jamais vraiment avoir létat complet du système… tout comme avec les Logitech Harmony!
# Conclusage
Là, on a plutôt fait la partie arrière-boutique. La prochaine fois, on verra comment interagir avec Home Assistant pour tout contrôler. En attendant, je te laisse avec [le repo qui va bien](https://giteu.be/home_assitant/consonance) si tu veux repomper le truc ou tinspirer.

View File

@@ -1,131 +0,0 @@
+++
title = "Home Assistant: Projet Consonance, lavant-boutique"
date = 2025-08-19
[taxonomies]
tags = [ "système", "home assistant", "infrarouge", "logitech harmony", "consonance" ]
+++
![Aquaman Meme, en haut Frontend, en bas Backend](/2025/08/aquaman.jpg)
<!-- more -->
# Dis à Tiny Tim que son papa ne rentrera pas pour Noël
Juste une petite note avant de commencer. Je pensais que le hub serait quelque chose qui marche bien. Et bien, je me trompais. **Ça marche putain de sa grand-mère bien**.
Comme le hub est fixe dans la pièce, il peut vraiment être placé de manière ultra optimale. Et ce que jai réalisé (et que je ne comprends toujours pas vraiment dans les faits), cest que finalement ce placement pouvait être pas mal au pif. Mon lecteur de Laserdisc est à pratiquement un mètre, sur la droite du hub, dans meuble presque fermé et ça marche quand même!
Je trouve ça assez ouf dans le principe. Jai vraiment limpression que ça joue sur des rebonds ou quelque chose de ce goût-là. Et ça rend lensemble hyper fiable et limite très largement le recours aux commandes isolées ou au bouton *Help* comme on pouvait lavoir avec une Harmony. Cest simple, ça ne foire quasiment jamais.
# Dis à Scarlett que cest le cadet de mes soucis
Donc résumé de lépisode précédent: on a un hub, on a des scripts et on a pu tester lensemble. Ça marche plutôt pas mal mais ça ne permet pas davoir des boutons spécifiques à certaines activités ou dinteragir directement au cours dune activité (pour mettre à pause, baisser le son, etc…).
Je vais donc tenter de décrire une ou deux activités types pour montrer à quel point cest important et quest-ce qui a guidé mes réflexions sur lergonomie de la solution retenue (qui est labsence de solution en fait, mais on verra ça plus tard).
## Description des activités
Je vais essayer de ne pas te barber, mais voici quelques constats que jai fait quand jai regardé les activités que javais sur la télécommande Harmony:
* toutes les activités utilisent systématiquement les enceintes: écouter un vynil ne nécessite pas la TV mais utilisent les enceintes, toutes les autres activités (JV, Blu-Ray, etc…) utilisent aussi mécaniquement les enceintes;
* quasiment toutes les activités utilisent la TV, mais une fois que lentrée est réglée, seule lactivité «Regarder la TV» utilisent les touches de la TV (pour changer de chaîne, etc…)
De ces deux points, on peut tirer quelques évidences:
* pouvoir contrôler le son (volume +, volume -, muet) est primordial pour toutes les activités;
* comme on ne peut pas passer dune activité à lautre, le bouton pour éteindre doit aussi être tout le temps visible.
Le reste a demandé un peu plus dinvestigation, notamment pour déterminer un certain nombre de stéréotypes de commandes. Typiquement:
* les lecteurs de média de manière générale (Kodi, lecteur Blu-Ray, lecteur de Laserdiscs) ont souvent un cluster de commandes de lecture qui sont à peu près toutes les mêmes: lecture, pause, avance, arrière, suivant, précédent, etc…
* quasiment toutes les activités nécessitent un cluster de navigation: haut, bas, gauche, droite, confirmer, retour, menu, info, etc…
* lactivité «Regarder la TV» elle-même contient des commandes quasi-uniques: chaîne suivante, chaîne précédente et le pavé numérique.
De ces trois points, on peut de nouveau faire quelques déductions:
* on peut parfaitement se passer dun pavé numérique: une seule activité lutilise vraiment, néanmoins, ça donne pas mal de boutons supplémentaires (et numérotés qui plus est) pour faire dautres choses, on y reviendra;
* le cluster de commandes média sont généralement assez mal foutues sur les vraies télécommandes: mon lecteur de laserdiscs na quune seule commande pour Lecture et Pause alors que mon lecteur Blu-Ray a une touche pour Lecture et une touche pour Pause;
* le cluster de commandes média doit contenir une touche Éjecter qui est rarement présente sur les télécommandes universelles (Logitech Harmony comprise!);
* le cluster de navigation est quasi obligatoire pour la moindre activité, et fort heureusement les touches sont relativement simples à implémenter.
Ça donne quelques perspectives intéressantes sur le design moderne des télécommandes. La mode semble être à la télécommande assez minimaliste, mais il y a toujours un bouton lecture/pause, des boutons pour le volume (sils sont marqués intelligemment, ils peuvent aussi faire suivant/précédent) et un cluster de navigation. Cest vraiment le strict minimum pour les média modernes.
Mais le manque daccès direct à certaines fonctions est quand même, à mon sens, relativement gênant. Même sans lire un CD, quand on écoute de la musique comment savoir si droite correspond à passer 10 secondes ou à passer au morceau suivant?
Encore une fois, lapproche est intéressante mais trop limitée.
# Première tentative
Partant de cela, ma première idée a été de me dire quil suffirait de prendre un petit écran tactile dédié. Ça ressemble à ça et ça coûte entre 15 et 20 balles sur AliExpress:
![ESP32 avec écran tactile](/2025/08/esp32_tactile.webp)
Tous ces petits modules sont construits sur une base ESP32 et ça tombe drôlement bien parce quil existe un module côté Home Assistant qui permet de configurer un ESP32, y compris les boutons, lécran tactile et les éventuels capteurs, tout ça dans un YAML plus ou moins compréhensible. Il sagit d[ESPHome](https://esphome.io/) et il dispose même des composants nécessaires pour construire des interfaces graphiques via [LVGL](https://esphome.io/components/lvgl/index.html).
Et mine de rien, et bah ça marche pas mal. Alors, il y a quelques pièges à éviter bien sûr mais en saccrochant un peu et en utilisant quelques astuces de YAML (notamment en abusant des *anchors* YAML), on peut obtenir une interface utilisateur tout-à-fait agréable à utiliser.
Mon idée de base étant quon ne peut pas passer dune activité à lautre, jai donc fait un système assez simple:
* la page daccueil contient un bouton par activité (10 au total)
* quand on clique sur le bouton en question, ça lance le script correspondant côté Home Assistant et ça affiche la page spécifique à lactivité
* sur cette page, le bouton Éteindre est toujours disponible, lance le script dextinction et revient à la page principale
* toujours sur cette page, les boutons de volume sont disponibles en permanence en haut de lécran (et cest un vilain *anchor* YAML bien crade)
* chaque touche après ça envoie directement une commande Home Assistant avec la bonne commande IR derrière
Cest relativement chiant à construire parce quil y a quand même beaucoup de boutons (8 pour un cluster média, 10 pour un pavé numérique, etc…) et quon ne peut pas vraiment «programmer»: il faut obligatoirement tout assigner à la main. Encore une fois, avec des morceaux d*anchors* YAML, on sen sort, mais cest loin dêtre confort.
Et du coup, ça se présente comme ça:
<video controls>
<source src="/2025/08/esp32_tactile_activity.mp4" type="video/mp4" />
</video>
Et si comme moi, tu tes posé la question: non, je nai pas trouvé démulateur correct pour ce truc. Jaurais bien testé sans acheter de matériel, mais malheureusement, ça na pas été possible.
Tout est évidemment disponible [](https://giteu.be/home_assitant/consonance/src/branch/main/esphome/esp32cc.yaml) si tu veux y jeter un œil. Il y a quelques astuces à connaître, mais au final, quand on a compris comment fonctionne ESPHome, ça va relativement vite à construire.
# Évaluation de lensemble
Cest pas tout de construire un frontend, encore faut-il léprouver.
Et donc, ça marche dans lensemble pas trop mal. Avec un peu dexpérience, on se rend vite compte quil vaut mieux utiliser le widget [button matrix](https://esphome.io/components/lvgl/widgets.html#buttonmatrix) plutôt que des boutons à placer. On finit par comprendre la logique pour placer des boutons les uns par rapport aux autres, etc… Ça ressemble beaucoup à du CSS au final, où lon place les choses les unes par rapport aux autres et on indique des centrages, des tailles, des tailles relatives, etc…
Sincèrement, je trouve que le système, même sil nest pas parfait, permet quand même de faire des choses assez impressionantes. LVGL permet vraiment de construire des interfaces relativement complexes avec des onglets, des pages, des boutons, des visualiseurs, etc… Jimagine quon pourrait très facilement y faire de petites interfaces de contrôle pour le chauffage, pour un EVSE ou plein dautres choses.
Mais est-ce que ça marche correctement pour une télécommande? Et bien, fonctionnellement, cest pas mal: ça donne une interface quon peut personnaliser très facilement et avoir un truc assez minimaliste pour certaines activités et très chargé pour dautres activités. Typiquement, mon activité «Nintendo Switch 2» ne contient que guère que le bandeau de volume que tu as pu voir précédemment. Parce quil ny a pas grand-chose de plus de nécessaire. Mon activtité «Blu-Ray» contient un cluster média et un cluster de navigation.
Et cest là quon voit le premier problème: les boutons ne sont pas toujours placés au même endroit à lécran, en dehors du bandeau du haut, en fonction de lactivité. Jai essayé de garder un peu de cohérence en plaçant par exemple toujours le cluster de navigation en haut de lécran, mais il nempêche: cest pas toujours tout au même endroit.
Cela veut dire quon est souvent obligé de **regarder** lécran pour trouver le bouton quon cherche. Au bout de quelques heures, on na effectivement un peu moins besoin de le faire, mais dans la pratique, je trouve quon regarder très souvent lécran: dabord parce que les boutons ne sont pas tous au même endroit et ensuite parce quon na pas vraiment de retour tactile des boutons, cest juste un écran.
Ce qui mamène au second défaut: **il ny a pas de retour haptique et évidemment pas de sensation tactile**. Quand on démarre ce genre de choses, on se dit que lécran tactile, cest parfait parce que ça permet de construire nimporte quelle interface et de faire un peu nimporte quoi. On nest pas obligé de mettre un bouton «Enregistrer» si on nen a pas besoin. On nest pas obligé dutiliser un bouton aléatoire pour une fonction particulière. **On peut concevoir chaque bouton précisément pour ce quon a besoin.**
Mais cest oublier un peu vite quon na pas lécran sous les yeux en permanence. Quand tu utilises ton téléphone, tu vois à la fois linterface (les boutons, les coches, etc…) et ce que tu es en train de manipuler. Quand tu utilises une télécommande, tu regardes généralement ton moniteur, pas la télécommande.
Ça revient au final au même problème que la WiiU: quand tu joues sur la télé, si tu dois baisser les yeux pour aller chercher une commande sur lécran tactile, cest plus long, tu interromps ton activité, tu es obligé de refocaliser tes yeux sur autre choses, plus proche, puis de revenir à ton activité, et de refocaliser tes yeux.
Donc au final, efficace oui, ergonomique moyen.
# Alternatives
Alors quest-ce quon peut faire dautres? On a vu que finalement un écran, aussi tactile soit-il, nest pas forcément lalpha et loméga. Cest peut-être aussi pour ça que la plupart des télécommandes Logitech Harmony ont un écran tactile mais pour des commandes additionnelles, pour des choses spécifiques, pas pour des fonctions que lon doit accéder souvent.
On pourrait donc imaginer dutiliser un clavier sans fil par exemple: en réécrivant les labels sur les touches et avec un peu dhabitude, on pourrait facilement convertir un petit clavier, avec ou sans pavé numérique, en télécommande. Ça donnerait rapidement quelque chose dutilisable. On pourrait par exemple imaginer de mettre tout le cluster média sur le bas du clavier:
* Espace pour lecture (ou lecture pause)
* Pause sur Alt Gr
* Stop sur Alt
* Super Gauche pour Précédent
* Super Droite pour Suivant
* Ctrl Gauche pour Rembobiner
* Ctrl Droit pour Avancer
Et voilà, boum, les 7 touches essentielles pour contrôler les médias, toutes sur la même ligne et assez facile à «apprendre» avec les mains. Bon après, un clavier, cest très encombrant, donc ça peut être une solution, mais ça reste un peu bizarre.
La seconde solution, ce serait simplement de se servir dun *dashboard* Home Assistant. Lavantage, cest que ça fonctionne déjà sorti de la boîte et quon peut faire quand même beaucoup de choses dans un *dashboard*. Le problème, cest que ça oblige à avoir un navigateur ouvert en permanence. Ça pourrait se faire avec un petit écran tactile pour Raspberry Pi par exemple, mais on reviendrait au même problème que précédemment: cest de nouveau un écran tactile. Et quand au fait dêtre obligé dutiliser son téléphone pour tout faire, cest moyen pour les invités ou pour les enfants. Ou pour quand tas la tête dans le cul.
La troisième solution, ce serait de construire soi-même une télécommande. [Certains lont fait](https://www.thestockpot.net/videos/theeverythingremote) et le résultat est plus ou moins disponible pour être réutilisé par nimporte qui.
De base, ça donne une télécommande assez minimaliste (peut-être trop), mais ça peut donner des idées… Des idées intéressantes…
# Conclusement
Voilà, dans cette partie, nous avons vu comment construire une interface graphique avec ESPHome et LVGL et comment on pouvait sen servir pour faire une télécommande. Je suis conscient que le système est loin dêtre parfait: il envoie des commandes directes à Home Assistant là où il devrait plutôt envoyer des signaux; il est 100% tactile ce qui pose des problèmes dergonomie à lutilisation.
Mais voilà, il faut bien le dire: ça marche. Ça peut remplacer une télécommande Harmony qui nest plus supportée ou qui est tombée en panne. Pour une poignée deuros (20 pour le *blaster IR* et 20 pour lécran tactile), on peut reconstruire un système de commande utilisable par nimporte qui.
Mais jai envie daller plus loin. Alors, je vais aller plus loin.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 68 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 71 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 104 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 62 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 123 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 27 KiB