Initial commit: Robot ökoszisztéma v2.0 - Stabilizált jármű és szerviz robotok

This commit is contained in:
Kincses
2026-03-04 02:03:03 +01:00
commit 250f4f4b8f
7942 changed files with 449625 additions and 0 deletions

View File

@@ -0,0 +1,89 @@
import asyncio
import os
from sqlalchemy.ext.asyncio import create_async_engine
from sqlalchemy import text
from dotenv import load_dotenv
load_dotenv(os.path.join(os.path.dirname(__file__), '../../.env'))
DATABASE_URL = os.getenv("DATABASE_URL")
# Kezdő adatkészlet
INITIAL_DATA = {
"BMW": ["3 Series", "5 Series", "X5", "R 1250 GS (Motor)"],
"Toyota": ["Corolla", "Yaris", "RAV4", "Hilux"],
"Volkswagen": ["Golf", "Passat", "Tiguan", "Polo"],
"Honda": ["Civic", "CR-V", "CB500X (Motor)", "Africa Twin (Motor)"],
"Audi": ["A3", "A4", "A6", "Q5"],
"Mercedes-Benz": ["C-Class", "E-Class", "S-Class", "G-Class"],
"Suzuki": ["Swift", "Vitara", "S-Cross", "DL 650 V-Strom (Motor)"]
}
async def seed_vehicles():
# Ha a DATABASE_URL környezeti változóból jön, azt használjuk
engine = create_async_engine(DATABASE_URL)
try:
async with engine.begin() as conn:
print("--- 🛠️ Struktúra ellenőrzése és építése... ---")
# 1. SÉMA ÉS TÁBLÁK LÉTREHOZÁSA (Ez a hiányzó láncszem!)
await conn.execute(text("CREATE SCHEMA IF NOT EXISTS ref;"))
await conn.execute(text("""
CREATE TABLE IF NOT EXISTS ref.vehicle_makes (
id SERIAL PRIMARY KEY,
name VARCHAR(100) UNIQUE NOT NULL
);
"""))
await conn.execute(text("""
CREATE TABLE IF NOT EXISTS ref.vehicle_models (
id SERIAL PRIMARY KEY,
make_id INTEGER REFERENCES ref.vehicle_makes(id) ON DELETE CASCADE,
model_name VARCHAR(100) NOT NULL,
category VARCHAR(50),
technical_data JSONB,
UNIQUE(make_id, model_name)
);
"""))
print("--- ✅ Táblák sikeresen létrehozva/ellenőrizve ---")
# 2. ADATOK FELTÖLTÉSE
print(f"--- 📥 Adatok betöltése... ---")
for make, models in INITIAL_DATA.items():
await conn.execute(
text("INSERT INTO ref.vehicle_makes (name) VALUES (:name) ON CONFLICT (name) DO NOTHING"),
{"name": make}
)
result = await conn.execute(
text("SELECT id FROM ref.vehicle_makes WHERE name = :name"),
{"name": make}
)
make_id = result.scalar()
for model in models:
category = "Motor" if "(Motor)" in model else "Autó"
clean_model = model.replace(" (Motor)", "")
await conn.execute(
text("""
INSERT INTO ref.vehicle_models (make_id, model_name, category)
VALUES (:make_id, :name, :cat)
ON CONFLICT DO NOTHING
"""),
{"make_id": make_id, "name": clean_model, "cat": category}
)
print(f" -> Mentve: {make} {clean_model}")
print("\n--- 🏁 SIKER! Minden adat a helyén van. ---")
except Exception as e:
print(f"\n❌ KRITIKUS HIBA: {e}")
finally:
await engine.dispose()
if __name__ == "__main__":
asyncio.run(seed_vehicles())