Add gitignor

This commit is contained in:
2026-04-07 22:06:36 +02:00
parent 49802d89d5
commit 5703cf5871
98 changed files with 5329 additions and 72 deletions

70
scripts/list_voices.py Normal file
View File

@@ -0,0 +1,70 @@
#!/usr/bin/env python3
"""
Liste toutes les voix Voxtral disponibles (preset et custom).
Usage :
python scripts/list_voices.py
python scripts/list_voices.py --type preset
python scripts/list_voices.py --type custom
"""
import argparse
import sys
from pathlib import Path
sys.path.insert(0, str(Path(__file__).parent.parent))
from mistralai.client import Mistral
from assistant import config
def main() -> None:
parser = argparse.ArgumentParser(description="Lister les voix Voxtral disponibles")
parser.add_argument(
"--type",
choices=["all", "preset", "custom"],
default="all",
help="Type de voix à lister (défaut: all)",
)
args = parser.parse_args()
client = Mistral(api_key=config.MISTRAL_API_KEY)
page, page_size = 0, 50
all_voices = []
while True:
response = client.audio.voices.list(
type_=args.type,
limit=page_size,
offset=page * page_size,
)
all_voices.extend(response.items)
if len(all_voices) >= response.total or not response.items:
break
page += 1
if not all_voices:
print("Aucune voix trouvée.")
return
# Affichage tabulaire
col_name = max(len(v.name) for v in all_voices)
col_lang = max(len(str(v.languages or [])) for v in all_voices)
col_id = max(len(v.id) for v in all_voices)
header = f"{'NOM':<{col_name}} {'LANGUES':<{col_lang}} {'ID':<{col_id}} TYPE"
print(f"\n{header}")
print("-" * len(header))
for v in sorted(all_voices, key=lambda x: (x.languages or ["zzz"])[0] + x.name):
langs = ", ".join(v.languages) if v.languages else ""
voice_type = "preset" if not v.user_id else "custom"
print(f"{v.name:<{col_name}} {langs:<{col_lang}} {v.id:<{col_id}} {voice_type}")
print(f"\n{len(all_voices)} voix trouvée(s).")
print("\nPour utiliser une voix, ajoute dans .env :")
print(" VOICE_ID=<id>")
if __name__ == "__main__":
main()

57
scripts/register_voice.py Normal file
View File

@@ -0,0 +1,57 @@
#!/usr/bin/env python3
"""
Script pour enregistrer une voix personnalisée via Voxtral TTS (Phase 2).
Usage :
python scripts/register_voice.py --name "Ma voix" --audio path/to/sample.mp3
L'identifiant de la voix créée sera affiché et pourra être ajouté à .env :
VOICE_ID=<id_retourné>
"""
import argparse
import base64
import sys
from pathlib import Path
# Permettre l'import depuis la racine du projet
sys.path.insert(0, str(Path(__file__).parent.parent))
from mistralai.client import Mistral
from assistant import config
def main() -> None:
parser = argparse.ArgumentParser(description="Enregistrer une voix Voxtral")
parser.add_argument("--name", required=True, help="Nom de la voix")
parser.add_argument("--audio", required=True, help="Chemin vers le fichier audio (mp3/wav)")
parser.add_argument("--gender", default=None, help="Genre : male ou female")
parser.add_argument("--language", default="fr", help="Langue principale (ex: fr, en)")
args = parser.parse_args()
audio_path = Path(args.audio)
if not audio_path.exists():
print(f"Erreur : fichier introuvable : {audio_path}")
sys.exit(1)
sample_audio_b64 = base64.b64encode(audio_path.read_bytes()).decode()
client = Mistral(api_key=config.MISTRAL_API_KEY)
print(f"Enregistrement de la voix '{args.name}'...")
voice = client.audio.voices.create(
name=args.name,
sample_audio=sample_audio_b64,
sample_filename=audio_path.name,
languages=[args.language],
**({"gender": args.gender} if args.gender else {}),
)
print(f"\n✅ Voix créée avec succès !")
print(f" ID : {voice.id}")
print(f" Nom : {voice.name}")
print(f"\nAjoute dans ton fichier .env :")
print(f" VOICE_ID={voice.id}")
if __name__ == "__main__":
main()