ncantu 6bf37be44e Cron restart services (bitcoind, mempool), service-login-verify, website-skeleton, docs
**Motivations:**
- Consigner l'état actuel du dépôt (cron, service-login-verify, website-skeleton, userwallet, docs).
- Centraliser les modifications en attente.

**Root causes:**
- N/A (commit groupé).

**Correctifs:**
- N/A.

**Evolutions:**
- Cron quotidien restart services : script local sans SSH, systemd (bitcoin-signet, bitcoin, APIs, dashboard, userwallet, website-skeleton) + Docker (mempool, bitcoin-signet-instance).
- Feature cron-restart-services-local : documentation et règle scripts locaux / pas d'SSH.
- service-login-verify : module vérification login (buildAllowedPubkeys, verifyLoginProof, nonceCache).
- website-skeleton : app iframe UserWallet, config, systemd unit.
- userwallet : collectSignatures, relay.
- docs : DOMAINS_AND_PORTS, README, WEBSITE_SKELETON ; features userwallet-contrat-login, timeouts-backoff, service-login-verify.

**Pages affectées:**
- data/restart-services-cron.sh, data/restart-services.log, data/sync-utxos.log
- features/cron-restart-services-local.md, features/service-login-verify.md, features/userwallet-contrat-login-reste-a-faire.md, features/userwallet-timeouts-backoff.md
- docs/DOMAINS_AND_PORTS.md, docs/README.md, docs/WEBSITE_SKELETON.md
- configure-nginx-proxy.sh
- service-login-verify/ (src, dist, node_modules)
- userwallet/src/utils/collectSignatures.ts, userwallet/src/utils/relay.ts
- website-skeleton/
2026-01-28 00:48:37 +01:00
..

website-skeleton

Squelette dun site qui intègre UserWallet en iframe : écoute des messages postMessage (auth-request, login-proof, error), vérification des preuves de login via service-login-verify, et affichage du statut (accepté / refusé).

Prérequis

  • service-login-verify : npm run build dans ../service-login-verify avant dinstaller ou builder le skeleton.
  • UserWallet : à servir sur lURL configurée (voir cidessous) pour que liframe fonctionne.

Installation

cd website-skeleton
npm install
npm run build

Développement

npm run dev

Ouvre par défaut sur http://localhost:3024. Liframe pointe vers UserWallet (USERWALLET_ORIGIN).

Configuration

  • Origine UserWallet : src/config.ts définit USERWALLET_ORIGIN. En dev, défaut http://localhost:3018 (si UserWallet tourne en dev sur ce port). En prod, défaut https://userwallet.certificator.4nkweb.com. Pour override : variable denvironnement VITE_USERWALLET_ORIGIN (ex. VITE_USERWALLET_ORIGIN=http://localhost:3018 npm run dev).
  • Validateurs : DEFAULT_VALIDATEURS dans src/config.ts est un placeholder. Remplacezle par les validateurs de laction login de votre contrat (ou chargezles depuis votre API / contrat fourni par channel).

Utilisation

  1. Lancer UserWallet (dev ou déployé) sur lURL configurée.
  2. Lancer le skeleton (npm run dev ou servir dist/).
  3. Ouvrir la page du skeleton : liframe affiche UserWallet.
  4. Demander auth : bouton « Demander auth (auth-request) » → envoi de auth-request à liframe.
  5. Login : depuis liframe, effectuer le flux de login ; à la fin, UserWallet envoie login-proof au parent. Le skeleton vérifie la preuve (verifyLoginProof) et affiche « Login accepté » ou « Login refusé : … ».

Structure

  • index.html : page avec iframe, zone de statut, bouton auth.
  • src/main.ts : chargement de liframe, écoute message, envoi auth-request, appel à verifyLoginProof, mise à jour du statut.
  • src/config.ts : USERWALLET_ORIGIN, DEFAULT_VALIDATEURS.

Déploiement

  • Production : https://skeleton.certificator.4nkweb.com (proxy → 192.168.1.105:3024).
  • Installation : ./install-website-skeleton.sh sur le backend, puis ./update-proxy-nginx.sh pour proxy + certificat. Voir docs/WEBSITE_SKELETON.md.

Références

  • docs/WEBSITE_SKELETON.md (documentation détaillée)
  • features/service-login-verify.md
  • features/userwallet-contrat-login-reste-a-faire.md (§ 3.7)
  • userwallet/ (iframe)
  • service-login-verify/ (vérification)