This commit is contained in:
2026-03-30 17:49:18 +02:00
parent 50a48c5292
commit 474a10aa43
3 changed files with 129 additions and 0 deletions

102
fastapi/Readme Normal file
View File

@@ -0,0 +1,102 @@
# README
## Description
Ce serveur **FastAPI** est destiné à être déployé sur le **deuxième Raspberry Pi** de larchitecture.
Son rôle principal est de **gérer et traiter toutes les requêtes envoyées par le Raspberry Pi 1**, afin de centraliser la logique de traitement et dassurer une communication fluide entre les deux الأجهزة.
---
## Architecture
* **Raspberry Pi 1**
* Envoie les requêtes (HTTP/API)
* Sert de client / déclencheur
* **Raspberry Pi 2 (ce serveur)**
* Héberge le serveur FastAPI
* Reçoit, traite et répond aux requêtes
* Exécute la logique métier
---
## Installation
Pour garantir une installation propre et optimale, il est recommandé dutiliser le script fourni.
### 1. Cloner le projet
```bash
git clone <repo_url>
cd <repo>
```
### 2. Lancer linstallation automatique
Le script `main.sh` permet de :
* créer un environnement virtuel Python (`venv`)
* installer toutes les dépendances nécessaires
* configurer lenvironnement correctement
```bash
chmod +x main.sh
./main.sh
```
---
## Environnement virtuel
Le projet utilise **Python venv** pour isoler les dépendances.
Si besoin, activation manuelle :
```bash
source venv/bin/activate
```
---
## Dépendances
Les dépendances sont listées dans le fichier :
```
requirements.txt
```
Elles sont automatiquement installées via le script `main.sh`.
---
## Lancement du serveur
Une fois linstallation terminée, le serveur peut être lancé avec :
```bash
uvicorn main:app --host 0.0.0.0 --port 8000
```
---
## Objectif
Ce serveur a pour objectif de :
* centraliser le traitement des requêtes
* améliorer les performances globales du système
* permettre une architecture distribuée entre plusieurs Raspberry Pi
---
## Notes
* Assurez-vous que les deux Raspberry Pi sont sur le même réseau.
* Vérifiez les ports et adresses IP pour permettre la communication entre les deux machines.
* Adapter la configuration si nécessaire selon votre environnement.
---

25
fastapi/main.py Normal file
View File

@@ -0,0 +1,25 @@
from fastapi import FastAPI
from pydantic import BaseModel
import os
import sys
app = FastAPI(title="Loustiques API - Pi 2")
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
composants = os.path.join(BASE_DIR, "composants", "byPanda")
sys.path.insert(0, composants)
from lumieres import SystemeLumieres
class CommandeLumiere(BaseModel):
action: str
@app.post("/Lumière")
async def action_pi2(commande: CommandeLumiere):
if commande.action == "allumer_lumiere":
return {"success": True, "message": "Lumière allumée par le Pi 2"}
return {"success": False, "message": "Action inconnue"}

2
fastapi/requirement.txt Normal file
View File

@@ -0,0 +1,2 @@
fastapi
uvicorn