Files
ipwatch/backend/app/migrations/add_tracked_field.py
2026-02-07 16:57:37 +01:00

71 lines
2.5 KiB
Python

"""
Script de migration pour ajouter le champ 'tracked' à la table IP
Exécuter avec: python -m backend.app.migrations.add_tracked_field
"""
from sqlalchemy import text, create_engine
import sys
import os
def migrate():
"""Ajoute la colonne 'tracked' et son index à la table IP"""
try:
# Charger le chemin de la base de données depuis config.yaml ou utiliser le défaut
db_path = os.getenv('DB_PATH', './data/db.sqlite')
db_url = f"sqlite:///{db_path}"
# Créer l'engine
engine = create_engine(db_url, echo=False)
with engine.connect() as conn:
# Vérifier si la colonne existe déjà
result = conn.execute(text("PRAGMA table_info(ip)"))
columns = [row[1] for row in result]
if 'tracked' in columns:
print("✓ La colonne 'tracked' existe déjà dans la table IP")
return
# Ajouter la colonne tracked
print("→ Ajout de la colonne 'tracked' à la table IP...")
conn.execute(text("ALTER TABLE ip ADD COLUMN tracked BOOLEAN DEFAULT 0"))
# Créer l'index
print("→ Création de l'index sur 'tracked'...")
conn.execute(text("CREATE INDEX IF NOT EXISTS idx_ip_tracked ON ip(tracked)"))
conn.commit()
print("✓ Migration terminée avec succès!")
print(" - Colonne 'tracked' ajoutée")
print(" - Index 'idx_ip_tracked' créé")
except Exception as e:
print(f"✗ Erreur lors de la migration: {str(e)}", file=sys.stderr)
sys.exit(1)
def rollback():
"""Supprime la colonne 'tracked' (rollback de la migration)"""
try:
# Charger le chemin de la base de données depuis config.yaml ou utiliser le défaut
db_path = os.getenv('DB_PATH', './data/db.sqlite')
db_url = f"sqlite:///{db_path}"
engine = create_engine(db_url, echo=False)
with engine.connect() as conn:
# SQLite ne supporte pas DROP COLUMN directement
# Il faut recréer la table sans la colonne
print("⚠ Rollback non implémenté pour SQLite")
print(" Pour annuler, restaurez une sauvegarde de la base de données")
except Exception as e:
print(f"✗ Erreur lors du rollback: {str(e)}", file=sys.stderr)
sys.exit(1)
if __name__ == "__main__":
if len(sys.argv) > 1 and sys.argv[1] == "rollback":
rollback()
else:
migrate()