- User-Modell (username, password_hash, role admin/user, is_active) - Standard-Admin-Benutzer wird beim ersten Start automatisch angelegt - JWT-Tokens (HS256) für Benutzer-Sessions, konfigurierbare Ablaufzeit - API-Key bleibt für service-to-service-Calls (backward-compatible) - POST /api/v1/auth/login → JWT-Token - GET /api/v1/auth/me → aktueller Benutzer - CRUD /api/v1/users/ → Benutzerverwaltung (nur Admin) - TUI zeigt Login-Screen beim Start; nach Erfolg → MainScreen - Passwort-Hashing mit bcrypt (python-jose für JWT)
36 lines
1021 B
Python
36 lines
1021 B
Python
from datetime import datetime
|
||
|
||
from fastapi import FastAPI
|
||
from fastapi.middleware.cors import CORSMiddleware
|
||
|
||
from api.routes import auth, channels, contacts, conversations, messages, users
|
||
|
||
app = FastAPI(
|
||
title="MCM – MultiCustomerMessenger API",
|
||
description="Unified messaging gateway for Telegram, WhatsApp and SMS",
|
||
version="1.0.0",
|
||
docs_url="/docs",
|
||
redoc_url="/redoc",
|
||
)
|
||
|
||
app.add_middleware(
|
||
CORSMiddleware,
|
||
allow_origins=["*"],
|
||
allow_credentials=True,
|
||
allow_methods=["*"],
|
||
allow_headers=["*"],
|
||
)
|
||
|
||
# Routen
|
||
app.include_router(auth.router, prefix="/api/v1")
|
||
app.include_router(users.router, prefix="/api/v1")
|
||
app.include_router(messages.router, prefix="/api/v1")
|
||
app.include_router(conversations.router, prefix="/api/v1")
|
||
app.include_router(contacts.router, prefix="/api/v1")
|
||
app.include_router(channels.router, prefix="/api/v1")
|
||
|
||
|
||
@app.get("/health", tags=["system"])
|
||
def health():
|
||
return {"status": "ok", "service": "MCM", "timestamp": datetime.utcnow().isoformat()}
|