Created comprehensive VPN setup tooling for Peaceful Spirit L2TP/IPsec connection and enhanced agent documentation framework. VPN Configuration (PST-NW-VPN): - Setup-PST-L2TP-VPN.ps1: Automated L2TP/IPsec setup with split-tunnel and DNS - Connect-PST-VPN.ps1: Connection helper with PPP adapter detection, DNS (192.168.0.2), and route config (192.168.0.0/24) - Connect-PST-VPN-Standalone.ps1: Self-contained connection script for remote deployment - Fix-PST-VPN-Auth.ps1: Authentication troubleshooting for CHAP/MSChapv2 - Diagnose-VPN-Interface.ps1: Comprehensive VPN interface and routing diagnostic - Quick-Test-VPN.ps1: Fast connectivity verification (DNS/router/routes) - Add-PST-VPN-Route-Manual.ps1: Manual route configuration helper - vpn-connect.bat, vpn-disconnect.bat: Simple batch file shortcuts - OpenVPN config files (Windows-compatible, abandoned for L2TP) Key VPN Implementation Details: - L2TP creates PPP adapter with connection name as interface description - UniFi auto-configures DNS (192.168.0.2) but requires manual route to 192.168.0.0/24 - Split-tunnel enabled (only remote traffic through VPN) - All-user connection for pre-login auto-connect via scheduled task - Authentication: CHAP + MSChapv2 for UniFi compatibility Agent Documentation: - AGENT_QUICK_REFERENCE.md: Quick reference for all specialized agents - documentation-squire.md: Documentation and task management specialist agent - Updated all agent markdown files with standardized formatting Project Organization: - Moved conversation logs to dedicated directories (guru-connect-conversation-logs, guru-rmm-conversation-logs) - Cleaned up old session JSONL files from projects/msp-tools/ - Added guru-connect infrastructure (agent, dashboard, proto, scripts, .gitea workflows) - Added guru-rmm server components and deployment configs Technical Notes: - VPN IP pool: 192.168.4.x (client gets 192.168.4.6) - Remote network: 192.168.0.0/24 (router at 192.168.0.10) - PSK: rrClvnmUeXEFo90Ol+z7tfsAZHeSK6w7 - Credentials: pst-admin / 24Hearts$ Files: 15 VPN scripts, 2 agent docs, conversation log reorganization, guru-connect/guru-rmm infrastructure additions Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
66 lines
2.5 KiB
Rust
66 lines
2.5 KiB
Rust
//! REST API routes
|
|
//!
|
|
//! Provides endpoints for:
|
|
//! - Agent management (registration, listing, deletion)
|
|
//! - Client and site management
|
|
//! - Metrics retrieval
|
|
//! - Command execution
|
|
//! - User authentication
|
|
|
|
pub mod agents;
|
|
pub mod auth;
|
|
pub mod clients;
|
|
pub mod commands;
|
|
pub mod metrics;
|
|
pub mod sites;
|
|
|
|
use axum::{
|
|
routing::{delete, get, post, put},
|
|
Router,
|
|
};
|
|
|
|
use crate::AppState;
|
|
|
|
/// Build all API routes
|
|
pub fn routes() -> Router<AppState> {
|
|
Router::new()
|
|
// Authentication
|
|
.route("/auth/login", post(auth::login))
|
|
.route("/auth/register", post(auth::register))
|
|
.route("/auth/me", get(auth::me))
|
|
// Clients
|
|
.route("/clients", get(clients::list_clients))
|
|
.route("/clients", post(clients::create_client))
|
|
.route("/clients/:id", get(clients::get_client))
|
|
.route("/clients/:id", put(clients::update_client))
|
|
.route("/clients/:id", delete(clients::delete_client))
|
|
.route("/clients/:id/sites", get(sites::list_sites_by_client))
|
|
// Sites
|
|
.route("/sites", get(sites::list_sites))
|
|
.route("/sites", post(sites::create_site))
|
|
.route("/sites/:id", get(sites::get_site))
|
|
.route("/sites/:id", put(sites::update_site))
|
|
.route("/sites/:id", delete(sites::delete_site))
|
|
.route("/sites/:id/regenerate-key", post(sites::regenerate_api_key))
|
|
// Agents
|
|
.route("/agents", get(agents::list_agents_with_details))
|
|
.route("/agents", post(agents::register_agent))
|
|
.route("/agents/stats", get(agents::get_stats))
|
|
.route("/agents/unassigned", get(agents::list_unassigned_agents))
|
|
.route("/agents/:id", get(agents::get_agent))
|
|
.route("/agents/:id", delete(agents::delete_agent))
|
|
.route("/agents/:id/move", post(agents::move_agent))
|
|
.route("/agents/:id/state", get(agents::get_agent_state))
|
|
// Metrics
|
|
.route("/agents/:id/metrics", get(metrics::get_agent_metrics))
|
|
.route("/metrics/summary", get(metrics::get_summary))
|
|
// Commands
|
|
.route("/agents/:id/command", post(commands::send_command))
|
|
.route("/commands", get(commands::list_commands))
|
|
.route("/commands/:id", get(commands::get_command))
|
|
// Legacy Agent (PowerShell for 2008 R2)
|
|
.route("/agent/register-legacy", post(agents::register_legacy))
|
|
.route("/agent/heartbeat", post(agents::heartbeat))
|
|
.route("/agent/command-result", post(agents::command_result))
|
|
}
|