feat: portage complet en Rust (axum + sysinfo + tera)

Remplacement du backend Python/Flask par un binaire Rust natif.
Stack : axum (web), sysinfo (metriques), lettre (SMTP), tera (templates), argon2 (auth).
Binaire Windows 6.3 Mo sans dependance runtime.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Dom
2026-04-13 15:55:36 +02:00
parent 61d17968a0
commit 545ae921e5
12 changed files with 4029 additions and 60 deletions

View File

@@ -1,5 +1,5 @@
{% extends "base.html" %}
{% block title %}Supervision - Configuration{% endblock %}
{% block title %}Supervision - Configuration{% endblock title %}
{% block content %}
<h4 class="mb-3"><i class="bi bi-gear"></i> Configuration</h4>
@@ -10,7 +10,7 @@
<div class="card">
<div class="card-header"><h6 class="mb-0"><i class="bi bi-sliders"></i> Seuils d'alerte (%)</h6></div>
<div class="card-body">
<form method="POST" action="{{ url_for('update_thresholds') }}">
<form method="POST" action="/settings/thresholds">
<div class="mb-3">
<label for="cpu_percent" class="form-label">CPU (%)</label>
<input type="number" class="form-control" id="cpu_percent" name="cpu_percent"
@@ -39,7 +39,7 @@
<div class="card">
<div class="card-header"><h6 class="mb-0"><i class="bi bi-clock"></i> Frequence et alertes</h6></div>
<div class="card-body">
<form method="POST" action="{{ url_for('update_monitoring') }}">
<form method="POST" action="/settings/monitoring">
<div class="mb-3">
<label for="check_interval_minutes" class="form-label">Intervalle de verification (minutes)</label>
<input type="number" class="form-control" id="check_interval_minutes"
@@ -64,7 +64,7 @@
<div class="card mt-4">
<div class="card-header"><h6 class="mb-0"><i class="bi bi-diagram-3"></i> Port de l'application</h6></div>
<div class="card-body">
<form method="POST" action="{{ url_for('update_port') }}">
<form method="POST" action="/settings/port">
<div class="mb-3">
<label for="port" class="form-label">Port (redemarrage requis)</label>
<input type="number" class="form-control" id="port" name="port"
@@ -85,7 +85,7 @@
<div class="card">
<div class="card-header"><h6 class="mb-0"><i class="bi bi-envelope"></i> Configuration SMTP</h6></div>
<div class="card-body">
<form method="POST" action="{{ url_for('update_smtp') }}">
<form method="POST" action="/settings/smtp">
<div class="row">
<div class="col-md-6 mb-3">
<label for="smtp_server" class="form-label">Serveur SMTP</label>
@@ -128,7 +128,7 @@
<div class="col-md-6 mb-3">
<label for="smtp_to" class="form-label">Destinataires (separes par des virgules)</label>
<input type="text" class="form-control" id="smtp_to" name="smtp_to"
value="{{ smtp.to_emails | join(', ') }}"
value="{{ smtp.to_emails | join(sep=", ") }}"
placeholder="admin@example.com, tech@example.com">
</div>
</div>
@@ -139,7 +139,7 @@
</div>
</form>
<hr>
<form method="POST" action="{{ url_for('test_smtp') }}" class="d-inline">
<form method="POST" action="/settings/smtp/test" class="d-inline">
<button type="submit" class="btn btn-outline-info">
<i class="bi bi-send"></i> Envoyer un email de test
</button>
@@ -157,7 +157,7 @@
<h6 class="mb-0"><i class="bi bi-list-task"></i> Processus surveilles</h6>
</div>
<div class="card-body">
<form method="POST" action="{{ url_for('update_processes') }}" id="process-form">
<form method="POST" action="/settings/processes" id="process-form">
<table class="table" id="proc-table">
<thead>
<tr>
@@ -231,7 +231,7 @@
<h6 class="mb-0"><i class="bi bi-shield-lock"></i> Mot de passe administrateur</h6>
</div>
<div class="card-body">
<form method="POST" action="{{ url_for('update_password') }}">
<form method="POST" action="/settings/password">
<div class="mb-3">
<label for="current_password" class="form-label">Mot de passe actuel</label>
<input type="password" class="form-control" id="current_password"
@@ -257,7 +257,7 @@
</div>
</div>
{% endblock %}
{% endblock content %}
{% block scripts %}
<script>
@@ -285,4 +285,4 @@ document.addEventListener('click', function(e) {
}
});
</script>
{% endblock %}
{% endblock scripts %}