aegis-stack 0.2.0rc2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- aegis/__init__.py +5 -0
- aegis/__main__.py +51 -0
- aegis/cli/__init__.py +6 -0
- aegis/cli/callbacks.py +114 -0
- aegis/cli/interactive.py +611 -0
- aegis/cli/utils.py +70 -0
- aegis/cli/validators.py +34 -0
- aegis/commands/__init__.py +6 -0
- aegis/commands/add.py +353 -0
- aegis/commands/add_service.py +332 -0
- aegis/commands/components.py +35 -0
- aegis/commands/init.py +370 -0
- aegis/commands/remove.py +227 -0
- aegis/commands/services.py +52 -0
- aegis/commands/update.py +252 -0
- aegis/commands/version.py +12 -0
- aegis/config/__init__.py +1 -0
- aegis/config/shared_files.py +136 -0
- aegis/core/CLAUDE.md +377 -0
- aegis/core/__init__.py +6 -0
- aegis/core/component_files.py +228 -0
- aegis/core/component_utils.py +220 -0
- aegis/core/components.py +127 -0
- aegis/core/copier_manager.py +315 -0
- aegis/core/copier_updater.py +475 -0
- aegis/core/dependency_resolver.py +119 -0
- aegis/core/manual_updater.py +554 -0
- aegis/core/post_gen_tasks.py +547 -0
- aegis/core/service_resolver.py +261 -0
- aegis/core/services.py +157 -0
- aegis/core/template_generator.py +266 -0
- aegis/core/version_compatibility.py +259 -0
- aegis/templates/CLAUDE.md +591 -0
- aegis/templates/cookiecutter-aegis-project/cookiecutter.json +39 -0
- aegis/templates/cookiecutter-aegis-project/hooks/post_gen_project.py +214 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/.dockerignore +71 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/.env.example.j2 +130 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/.gitignore +131 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/Dockerfile +53 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/Makefile +236 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/README.md.j2 +196 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/alembic/alembic.ini.j2 +111 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/alembic/env.py.j2 +91 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/alembic/script.py.mako +25 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/alembic/versions/001_initial_auth.py.j2 +51 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/__init__.py +5 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/__init__.py +6 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/ai.py.j2 +700 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/ai_rendering.py +361 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/auth.py.j2 +253 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/health.py.j2 +419 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/load_test.py.j2 +656 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/main.py.j2 +65 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/marko_terminal_renderer.py +489 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/tasks.py.j2 +328 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/cli/{% if cookiecutter.include_scheduler == /"yes/" %}tasks.py{% endif %}" +340 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/__init__.py +0 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/__init__.py +0 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/ai/__init__.py +8 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/ai/router.py +329 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/auth/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/auth/router.py +64 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/deps.py +58 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/health.py +163 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/models.py.j2 +280 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/routing.py.j2 +32 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/scheduler.py.j2 +121 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/api/worker.py.j2 +478 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/hooks.py +144 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/main.py +31 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/middleware/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/middleware/cors.py +20 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/shutdown/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/shutdown/cleanup.py +14 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/startup/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/startup/component_health.py.j2 +418 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/backend/startup/database_init.py.j2 +83 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/__init__.py +5 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/controls/__init__.py +27 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/controls/table.py +78 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/controls/text.py +142 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/__init__.py.j2 +47 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/ai_card.py +287 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/auth_card.py +198 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/base_card.py +256 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/card_factory.py +227 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/card_utils.py +333 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/database_card.py +420 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/fastapi_card.py +328 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/flet_card.py +267 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/redis_card.py +322 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/scheduler_card.py +352 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/services_card.py +233 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/dashboard/cards/worker_card.py +684 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/main.py.j2 +653 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/frontend/theme.py +48 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/scheduler/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/scheduler/main.py.j2 +156 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/CLAUDE.md.j2 +213 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/__init__.py +6 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/constants.py.j2 +30 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/pools.py +97 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/queues/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/queues/load_test.py +55 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/queues/media.py +49 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/queues/system.py +44 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/registry.py +139 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/tasks/__init__.py +120 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/tasks/load_tasks.py +507 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/tasks/simple_system_tasks.py +33 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/components/worker/tasks/system_tasks.py +281 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/core/config.py.j2 +178 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/core/constants.py +58 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/core/db.py.j2 +176 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/core/log.py +92 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/core/security.py +62 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/entrypoints/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/entrypoints/webserver.py +40 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/entrypoints/{% if cookiecutter.include_scheduler == /"yes/" %}scheduler.py{% endif %}" +21 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/integrations/__init__.py +0 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/integrations/main.py +62 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/models/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/models/user.py +44 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/py.typed +0 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/ai/__init__.py +8 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/ai/config.py +130 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/ai/conversation.py +213 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/ai/health.py +96 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/ai/models.py +229 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/ai/providers.py +370 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/ai/service.py +388 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/auth/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/auth/auth_service.py +41 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/auth/health.py +164 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/auth/user_service.py +83 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/backend/middleware_inspector.py.j2 +223 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/backend/models.py.j2 +70 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/backend/route_inspector.py.j2 +155 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/load_test.py +679 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/load_test_models.py +266 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/scheduler/__init__.py.j2 +21 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/scheduler/models.py.j2 +119 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/scheduler/scheduled_task_manager.py.j2 +273 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/scheduler/task_monitor.py.j2 +189 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/shared/__init__.py +15 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/shared/models.py +26 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/system/__init__.py +52 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/system/alerts.py +94 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/system/backup.py.j2 +119 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/system/health.py.j2 +1333 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/system/models.py +243 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/app/services/system/ui.py +52 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/assets/aegis-manifesto-dark.png +0 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/assets/aegis-manifesto-square-backup.png +0 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/assets/aegis-manifesto.png +0 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/.dockerignore +71 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/.env.example.j2 +64 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/.gitignore +131 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/Dockerfile +53 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/Makefile +211 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/README.md.j2 +172 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/docker-compose.yml.j2 +78 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/mkdocs.yml.j2 +62 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/pyproject.toml.j2 +120 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/clean-validation/uv.lock +1673 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/docker-compose.yml.j2 +200 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/docs/api.md +191 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/docs/components/scheduler.md +0 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/docs/components/scheduler.md.j2 +621 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/docs/development.md +215 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/docs/health.md +240 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/docs/javascripts/mermaid-config.js +62 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/docs/stylesheets/mermaid.css +95 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/mkdocs.yml.j2 +62 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/pyproject.toml.j2 +131 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/scripts/entrypoint.sh +87 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/scripts/entrypoint.sh.j2 +93 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/scripts/gen_docs.py +16 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/api/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/api/test_auth_endpoints.py.j2 +307 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/api/test_health_endpoints.py.j2 +262 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/api/test_scheduler_endpoints.py.j2 +214 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/api/test_worker_endpoints.py.j2 +165 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/cli/test_ai_rendering.py +427 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/cli/test_conversation_memory.py +465 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/components/test_scheduler.py +43 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/conftest.py.j2 +195 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/ai/__init__.py +1 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/ai/conftest.py +78 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/ai/test_health.py +157 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/ai/test_models.py +164 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/ai/test_service.py +198 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_auth_integration.py.j2 +528 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_component_integration.py.j2 +387 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_conversation_persistence.py +342 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_health_logic.py.j2 +663 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_load_test_models.py +619 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_load_test_service.py +603 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_middleware_inspector.py.j2 +248 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_scheduled_task_manager.py.j2 +292 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_system_service.py +98 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/services/test_worker_health_registration.py.j2 +257 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/tests/test_core.py +49 -0
- aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/uv.lock +1673 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/.copier-answers.yml.jinja +21 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/.dockerignore +71 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/.env.example.jinja +130 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/.gitignore +131 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/Dockerfile +53 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/Makefile.jinja +236 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/README.md.jinja +196 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/alembic/alembic.ini.jinja +111 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/alembic/env.py.jinja +91 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/alembic/script.py.mako +25 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/alembic/versions/001_initial_auth.py.jinja +51 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/__init__.py.jinja +5 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/__init__.py.jinja +6 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/ai.py.jinja +700 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/ai_rendering.py +360 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/auth.py.jinja +253 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/health.py.jinja +419 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/load_test.py.jinja +656 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/main.py.jinja +65 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/marko_terminal_renderer.py +489 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/cli/tasks.py.jinja +328 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/__init__.py +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/__init__.py +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/ai/__init__.py +8 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/ai/router.py +329 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/auth/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/auth/router.py +64 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/deps.py +58 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/health.py.jinja +163 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/models.py.jinja +280 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/routing.py.jinja +32 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/scheduler.py.jinja +121 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/api/worker.py.jinja +478 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/hooks.py +144 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/main.py +31 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/middleware/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/middleware/cors.py +20 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/shutdown/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/shutdown/cleanup.py +14 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/startup/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/startup/component_health.py.jinja +418 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/backend/startup/database_init.py.jinja +83 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/__init__.py +5 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/controls/__init__.py +27 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/controls/table.py +78 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/controls/text.py +142 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/__init__.py.jinja +47 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/ai_card.py +287 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/auth_card.py +198 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/base_card.py +256 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/card_factory.py +227 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/card_utils.py +333 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/database_card.py +420 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/fastapi_card.py +328 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/flet_card.py +267 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/redis_card.py +322 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/scheduler_card.py +352 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/services_card.py +233 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/dashboard/cards/worker_card.py +684 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/main.py.jinja +653 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/frontend/theme.py +48 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/scheduler/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/scheduler/main.py.jinja +156 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/CLAUDE.md.jinja +213 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/__init__.py +6 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/constants.py.jinja +30 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/pools.py +97 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/queues/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/queues/load_test.py +55 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/queues/media.py +49 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/queues/system.py +44 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/registry.py +139 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/tasks/__init__.py +120 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/tasks/load_tasks.py +507 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/tasks/simple_system_tasks.py +33 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/components/worker/tasks/system_tasks.py +281 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/core/config.py.jinja +178 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/core/constants.py +58 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/core/db.py.jinja +176 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/core/log.py +92 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/core/security.py +62 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/entrypoints/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/entrypoints/scheduler.py.jinja +21 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/entrypoints/webserver.py +39 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/integrations/__init__.py +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/integrations/main.py +61 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/models/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/models/user.py +44 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/py.typed +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/ai/__init__.py +8 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/ai/config.py +130 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/ai/conversation.py +213 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/ai/health.py +96 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/ai/models.py +229 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/ai/providers.py.jinja +370 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/ai/service.py +387 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/auth/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/auth/auth_service.py +40 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/auth/health.py +162 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/auth/user_service.py +82 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/backend/middleware_inspector.py.jinja +223 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/backend/models.py.jinja +70 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/backend/route_inspector.py.jinja +155 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/load_test.py +678 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/load_test_models.py +265 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/scheduler/__init__.py.jinja +21 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/scheduler/models.py.jinja +119 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/scheduler/scheduled_task_manager.py.jinja +273 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/scheduler/task_monitor.py.jinja +189 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/shared/__init__.py +15 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/shared/models.py +26 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/system/__init__.py +52 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/system/alerts.py +94 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/system/backup.py.jinja +119 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/system/health.py.jinja +1333 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/system/models.py +243 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/app/services/system/ui.py +52 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57223!aegis-manifesto.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57224!aegis-manifesto-dark.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57225!aegis-manifesto-square-backup.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57533!aegis-manifesto.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57534!aegis-manifesto-dark.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57538!aegis-manifesto-square-backup.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57897!aegis-manifesto.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57898!aegis-manifesto-dark.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!57904!aegis-manifesto-square-backup.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!58315!aegis-manifesto.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!58316!aegis-manifesto-dark.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!58324!aegis-manifesto-square-backup.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!58837!aegis-manifesto.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!58838!aegis-manifesto-dark.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/.!58849!aegis-manifesto-square-backup.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/aegis-manifesto-dark.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/aegis-manifesto-square-backup.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/assets/aegis-manifesto.png +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/clean-validation/.env.example.jinja +64 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/clean-validation/README.md.jinja +172 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/clean-validation/docker-compose.yml.jinja +78 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/clean-validation/mkdocs.yml.jinja +62 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/clean-validation/pyproject.toml.jinja +120 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/docker-compose.yml.jinja +200 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/docs/api.md.jinja +191 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/docs/components/scheduler.md +0 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/docs/components/scheduler.md.jinja +621 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/docs/development.md.jinja +215 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/docs/health.md.jinja +240 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/docs/javascripts/mermaid-config.js +62 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/docs/stylesheets/mermaid.css +95 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/mkdocs.yml.jinja +62 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/pyproject.toml.jinja +131 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/scripts/entrypoint.sh +87 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/scripts/entrypoint.sh.jinja +93 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/scripts/gen_docs.py +16 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/api/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/api/test_auth_endpoints.py.jinja +307 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/api/test_health_endpoints.py.jinja +262 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/api/test_scheduler_endpoints.py.jinja +214 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/api/test_worker_endpoints.py.jinja +165 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/cli/test_ai_rendering.py +427 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/cli/test_conversation_memory.py +465 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/components/test_scheduler.py +43 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/conftest.py.jinja +195 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/ai/__init__.py +1 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/ai/conftest.py +78 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/ai/test_health.py +157 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/ai/test_models.py +164 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/ai/test_service.py +198 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_auth_integration.py.jinja +528 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_component_integration.py.jinja +387 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_conversation_persistence.py +342 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_health_logic.py.jinja +663 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_load_test_models.py +619 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_load_test_service.py +603 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_middleware_inspector.py.jinja +248 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_scheduled_task_manager.py.jinja +292 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_system_service.py +98 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/services/test_worker_health_registration.py.jinja +257 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/tests/test_core.py +49 -0
- aegis/templates/copier-aegis-project/{{ project_slug }}/uv.lock +1673 -0
- aegis_stack-0.2.0rc2.dist-info/METADATA +165 -0
- aegis_stack-0.2.0rc2.dist-info/RECORD +392 -0
- aegis_stack-0.2.0rc2.dist-info/WHEEL +4 -0
- aegis_stack-0.2.0rc2.dist-info/entry_points.txt +3 -0
- aegis_stack-0.2.0rc2.dist-info/licenses/LICENSE +21 -0
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
# {{ cookiecutter.project_name }} - Aegis Stack Project
|
|
2
|
+
# Developer-friendly commands for Docker workflow
|
|
3
|
+
|
|
4
|
+
#=============================================================================
|
|
5
|
+
# CORE DOCKER COMMANDS
|
|
6
|
+
#=============================================================================
|
|
7
|
+
|
|
8
|
+
build: ## Build all Docker images (safe, sequential)
|
|
9
|
+
@echo "🔨 Building Docker images..."
|
|
10
|
+
@docker compose --profile dev build
|
|
11
|
+
|
|
12
|
+
serve: ## Run all services (assumes images are built)
|
|
13
|
+
@echo "🚀 Starting services... (Press Ctrl+C to stop)"
|
|
14
|
+
@docker compose --profile dev up --remove-orphans
|
|
15
|
+
|
|
16
|
+
serve-bg: ## Run all services in background
|
|
17
|
+
@echo "🚀 Starting services in background..."
|
|
18
|
+
@docker compose --profile dev up -d --remove-orphans
|
|
19
|
+
|
|
20
|
+
stop: ## Gracefully stop all services
|
|
21
|
+
@echo "⏹️ Stopping services..."
|
|
22
|
+
@docker compose --profile dev down --remove-orphans
|
|
23
|
+
|
|
24
|
+
clean: ## Nuclear cleanup - remove containers, networks, and images
|
|
25
|
+
@echo "🧹 Nuclear cleanup - removing everything..."
|
|
26
|
+
@docker compose down --remove-orphans --volumes --rmi all 2>/dev/null || true
|
|
27
|
+
@docker system prune -f
|
|
28
|
+
|
|
29
|
+
#=============================================================================
|
|
30
|
+
# DEVELOPER WORKFLOW COMMANDS (the ones you'll actually use)
|
|
31
|
+
#=============================================================================
|
|
32
|
+
|
|
33
|
+
rebuild: build serve ## Build images and start services
|
|
34
|
+
|
|
35
|
+
refresh: clean build serve ## Nuclear reset - clean everything and rebuild
|
|
36
|
+
|
|
37
|
+
restart: stop serve ## Quick restart (no rebuild)
|
|
38
|
+
|
|
39
|
+
#=============================================================================
|
|
40
|
+
# DEBUGGING AND LOGS
|
|
41
|
+
#=============================================================================
|
|
42
|
+
|
|
43
|
+
logs: ## Follow logs from all services
|
|
44
|
+
@echo "📋 Following all service logs..."
|
|
45
|
+
@docker compose logs -f
|
|
46
|
+
|
|
47
|
+
logs-web: ## Follow webserver logs only
|
|
48
|
+
@echo "📋 Following webserver logs..."
|
|
49
|
+
@docker compose logs -f webserver
|
|
50
|
+
|
|
51
|
+
logs-worker: ## Follow worker logs only
|
|
52
|
+
@echo "📋 Following worker logs..."
|
|
53
|
+
@docker compose logs -f worker-system worker-load-test
|
|
54
|
+
|
|
55
|
+
logs-redis: ## Follow Redis logs only
|
|
56
|
+
@echo "📋 Following Redis logs..."
|
|
57
|
+
@docker compose logs -f redis{% if cookiecutter.include_scheduler == "yes" %}
|
|
58
|
+
|
|
59
|
+
logs-scheduler: ## Follow scheduler logs only
|
|
60
|
+
@echo "📋 Following scheduler logs..."
|
|
61
|
+
@docker compose logs -f scheduler{% endif %}
|
|
62
|
+
|
|
63
|
+
shell: ## Open shell in webserver container
|
|
64
|
+
@echo "🐚 Opening shell in webserver container..."
|
|
65
|
+
@docker compose exec webserver /bin/bash
|
|
66
|
+
|
|
67
|
+
shell-worker: ## Open shell in worker container
|
|
68
|
+
@echo "🐚 Opening shell in worker container..."
|
|
69
|
+
@docker compose exec worker-system /bin/bash
|
|
70
|
+
|
|
71
|
+
ps: ## Show running containers
|
|
72
|
+
@echo "📊 Docker containers status:"
|
|
73
|
+
@docker compose ps
|
|
74
|
+
|
|
75
|
+
#=============================================================================
|
|
76
|
+
# REDIS DEBUGGING
|
|
77
|
+
#=============================================================================
|
|
78
|
+
|
|
79
|
+
redis-cli: ## Connect to Redis CLI
|
|
80
|
+
@echo "🔧 Connecting to Redis CLI..."
|
|
81
|
+
@docker compose exec redis redis-cli
|
|
82
|
+
|
|
83
|
+
redis-stats: ## Show Redis memory and stats
|
|
84
|
+
@echo "📊 Redis statistics:"
|
|
85
|
+
@docker compose exec redis redis-cli info memory
|
|
86
|
+
|
|
87
|
+
redis-keys: ## Show all Redis keys
|
|
88
|
+
@echo "🔑 Redis keys:"
|
|
89
|
+
@docker compose exec redis redis-cli keys "*"
|
|
90
|
+
|
|
91
|
+
redis-reset: ## Clear all Redis data
|
|
92
|
+
@echo "🔄 Clearing all Redis data..."
|
|
93
|
+
@docker compose exec redis redis-cli flushall
|
|
94
|
+
|
|
95
|
+
#=============================================================================
|
|
96
|
+
# HEALTH AND TESTING
|
|
97
|
+
#=============================================================================
|
|
98
|
+
|
|
99
|
+
health: ## Check system health status
|
|
100
|
+
@echo "🩺 Checking system health..."
|
|
101
|
+
@uv run {{ cookiecutter.project_slug }} health status
|
|
102
|
+
|
|
103
|
+
health-detailed: ## Detailed system health information
|
|
104
|
+
@echo "🩺 Detailed system health..."
|
|
105
|
+
@uv run {{ cookiecutter.project_slug }} health status --detailed
|
|
106
|
+
|
|
107
|
+
health-json: ## System health as JSON
|
|
108
|
+
@uv run {{ cookiecutter.project_slug }} health status --json
|
|
109
|
+
|
|
110
|
+
health-probe: ## Health probe (exits 1 if unhealthy)
|
|
111
|
+
@uv run {{ cookiecutter.project_slug }} health probe
|
|
112
|
+
|
|
113
|
+
test: ## Run tests locally
|
|
114
|
+
@echo "🧪 Running tests..."
|
|
115
|
+
@uv run pytest
|
|
116
|
+
|
|
117
|
+
test-verbose: ## Run tests with verbose output
|
|
118
|
+
@echo "🧪 Running tests (verbose)..."
|
|
119
|
+
@uv run pytest -v
|
|
120
|
+
|
|
121
|
+
#=============================================================================
|
|
122
|
+
# CODE QUALITY (local development tools)
|
|
123
|
+
#=============================================================================
|
|
124
|
+
|
|
125
|
+
lint: ## Check code style with ruff
|
|
126
|
+
@echo "🔍 Running linting..."
|
|
127
|
+
@uv run ruff check .
|
|
128
|
+
|
|
129
|
+
fix: ## Auto-fix linting and formatting issues
|
|
130
|
+
@echo "🔧 Auto-fixing code issues..."
|
|
131
|
+
@uv run ruff check . --fix
|
|
132
|
+
@uv run ruff format .
|
|
133
|
+
|
|
134
|
+
format: ## Format code with ruff
|
|
135
|
+
@echo "💄 Formatting code..."
|
|
136
|
+
@uv run ruff format .
|
|
137
|
+
|
|
138
|
+
typecheck: ## Run type checking with ty
|
|
139
|
+
@echo "🔍 Running type checking..."
|
|
140
|
+
@uv run ty check
|
|
141
|
+
|
|
142
|
+
check: lint typecheck test ## Run all code quality checks
|
|
143
|
+
@echo "✅ All checks completed successfully!"
|
|
144
|
+
|
|
145
|
+
#=============================================================================
|
|
146
|
+
# PROJECT MANAGEMENT
|
|
147
|
+
#=============================================================================
|
|
148
|
+
|
|
149
|
+
install: ## Install/sync dependencies with uv
|
|
150
|
+
@echo "📦 Installing dependencies..."
|
|
151
|
+
@uv sync --all-extras
|
|
152
|
+
|
|
153
|
+
deps-update: ## Update dependencies
|
|
154
|
+
@echo "📦 Updating dependencies..."
|
|
155
|
+
@uv sync --upgrade
|
|
156
|
+
|
|
157
|
+
clean-cache: ## Clean Python cache files
|
|
158
|
+
@echo "🧹 Cleaning Python cache files..."
|
|
159
|
+
@find . -type d -name "__pycache__" -exec rm -rf {} +
|
|
160
|
+
@find . -type f -name "*.pyc" -delete
|
|
161
|
+
|
|
162
|
+
#=============================================================================
|
|
163
|
+
# DOCUMENTATION
|
|
164
|
+
#=============================================================================
|
|
165
|
+
|
|
166
|
+
docs-serve: ## Serve documentation locally (http://localhost:8001)
|
|
167
|
+
@echo "📚 Serving documentation on http://localhost:8001"
|
|
168
|
+
@uv run mkdocs serve --dev-addr 0.0.0.0:8001
|
|
169
|
+
|
|
170
|
+
docs-build: ## Build static documentation
|
|
171
|
+
@echo "📚 Building documentation..."
|
|
172
|
+
@uv run mkdocs build
|
|
173
|
+
|
|
174
|
+
{% if cookiecutter.include_database == "yes" %}#=============================================================================
|
|
175
|
+
# DATABASE MIGRATIONS
|
|
176
|
+
#=============================================================================
|
|
177
|
+
|
|
178
|
+
migrate: ## Apply database migrations
|
|
179
|
+
@echo "🗃️ Applying database migrations..."
|
|
180
|
+
@docker compose exec webserver uv run alembic -c alembic/alembic.ini upgrade head
|
|
181
|
+
|
|
182
|
+
migrate-check: ## Check migration status
|
|
183
|
+
@echo "🔍 Checking migration status..."
|
|
184
|
+
@docker compose exec webserver uv run alembic -c alembic/alembic.ini current
|
|
185
|
+
|
|
186
|
+
migrate-history: ## Show migration history
|
|
187
|
+
@echo "📜 Migration history:"
|
|
188
|
+
@docker compose exec webserver uv run alembic -c alembic/alembic.ini history --verbose
|
|
189
|
+
|
|
190
|
+
migrate-reset: ## Reset database (WARNING: destructive)
|
|
191
|
+
@echo "⚠️ This will destroy all data in the database!"
|
|
192
|
+
@read -p "Are you sure? Type 'yes' to continue: " confirm && [ "$$confirm" = "yes" ] || exit 1
|
|
193
|
+
@docker compose exec webserver uv run alembic -c alembic/alembic.ini downgrade base
|
|
194
|
+
@docker compose exec webserver uv run alembic -c alembic/alembic.ini upgrade head
|
|
195
|
+
@echo "✅ Database reset complete"
|
|
196
|
+
|
|
197
|
+
{% endif %}
|
|
198
|
+
|
|
199
|
+
#=============================================================================
|
|
200
|
+
# WORKER DEBUGGING (arq)
|
|
201
|
+
#=============================================================================
|
|
202
|
+
|
|
203
|
+
worker-test: ## Test workers in burst mode (process and exit)
|
|
204
|
+
@echo "🧪 Testing system worker in burst mode..."
|
|
205
|
+
@uv run python -m arq app.components.worker.queues.system.WorkerSettings --burst
|
|
206
|
+
|
|
207
|
+
#=============================================================================
|
|
208
|
+
# HELP AND INFO
|
|
209
|
+
#=============================================================================
|
|
210
|
+
|
|
211
|
+
status: ## Show current system status
|
|
212
|
+
@echo "📊 Current system status:"
|
|
213
|
+
@echo
|
|
214
|
+
@echo "🐳 Docker containers:"
|
|
215
|
+
@docker compose ps || echo "No containers running"
|
|
216
|
+
@echo
|
|
217
|
+
@echo "📦 Dependencies:"
|
|
218
|
+
@uv pip list | head -20 || echo "Dependencies not installed"
|
|
219
|
+
|
|
220
|
+
help: ## Show this help message
|
|
221
|
+
@echo "{{ cookiecutter.project_name }} development commands:"
|
|
222
|
+
@echo
|
|
223
|
+
@echo "🚀 WORKFLOW COMMANDS (start here):"
|
|
224
|
+
@echo " make refresh - Nuclear reset (clean + build + serve)"
|
|
225
|
+
@echo " make rebuild - Build and serve"
|
|
226
|
+
@echo " make restart - Quick restart"
|
|
227
|
+
@echo
|
|
228
|
+
@echo "🔧 CORE COMMANDS:"
|
|
229
|
+
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-20s\033[0m %s\n", $$1, $$2}'
|
|
230
|
+
@echo
|
|
231
|
+
@echo "💡 TIP: Use 'make refresh' when everything is broken!"
|
|
232
|
+
|
|
233
|
+
.PHONY: build serve stop clean rebuild refresh restart logs logs-web logs-worker logs-redis{% if cookiecutter.include_scheduler == "yes" %} logs-scheduler{% endif %} shell shell-worker ps redis-cli redis-stats redis-keys redis-reset health health-detailed health-json health-probe test test-verbose lint fix format typecheck check install deps-update clean-cache docs-serve docs-build{% if cookiecutter.include_database == "yes" %} migrate migrate-check migrate-history migrate-reset{% endif %} worker-test status help
|
|
234
|
+
|
|
235
|
+
# Default target - show help
|
|
236
|
+
.DEFAULT_GOAL := help
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
# {{ cookiecutter.project_name }} 🛡️
|
|
2
|
+
|
|
3
|
+
{{ cookiecutter.project_description }}
|
|
4
|
+
|
|
5
|
+
## Components
|
|
6
|
+
|
|
7
|
+
This Aegis Stack project includes the following components:
|
|
8
|
+
|
|
9
|
+
- **✅ Backend**: FastAPI-based async web server
|
|
10
|
+
- **✅ Frontend**: Flet-based Python UI framework
|
|
11
|
+
{%- if cookiecutter.include_scheduler == "yes" %}
|
|
12
|
+
- **✅ Scheduler**: APScheduler-based async task scheduling
|
|
13
|
+
{%- endif %}
|
|
14
|
+
{%- if cookiecutter.include_database == "yes" %}
|
|
15
|
+
- **✅ Database**: SQLite database with SQLModel ORM
|
|
16
|
+
{%- endif %}
|
|
17
|
+
{%- if cookiecutter.include_cache == "yes" %}
|
|
18
|
+
- **✅ Cache**: Redis-based async caching
|
|
19
|
+
{%- endif %}
|
|
20
|
+
|
|
21
|
+
## Getting Started
|
|
22
|
+
|
|
23
|
+
### Prerequisites
|
|
24
|
+
|
|
25
|
+
- Python {{ cookiecutter.python_version }}+
|
|
26
|
+
- [uv](https://docs.astral.sh/uv/) (recommended) or pip
|
|
27
|
+
|
|
28
|
+
### Installation
|
|
29
|
+
|
|
30
|
+
1. **Install dependencies:**
|
|
31
|
+
```bash
|
|
32
|
+
uv sync # Core dependencies only
|
|
33
|
+
# Or for development: uv sync --all-extras (includes testing, linting, docs)
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
2. **Activate virtual environment:**
|
|
37
|
+
```bash
|
|
38
|
+
source .venv/bin/activate
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
3. **Set up environment:**
|
|
42
|
+
```bash
|
|
43
|
+
cp .env.example .env
|
|
44
|
+
# Edit .env with your configuration
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
{%- if cookiecutter.include_database == "yes" %}
|
|
48
|
+
|
|
49
|
+
4. **Set up database:**
|
|
50
|
+
```bash
|
|
51
|
+
# Create data directory for SQLite database
|
|
52
|
+
mkdir -p data
|
|
53
|
+
|
|
54
|
+
# Database will be created automatically on first run
|
|
55
|
+
# Default location: data/app.db
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
5. **Run the application:**
|
|
59
|
+
{%- else %}
|
|
60
|
+
|
|
61
|
+
4. **Run the application:**
|
|
62
|
+
{%- endif %}
|
|
63
|
+
```bash
|
|
64
|
+
make server
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
The application will be available at `http://127.0.0.1:8000`.
|
|
68
|
+
|
|
69
|
+
## Development
|
|
70
|
+
|
|
71
|
+
### Running Tests
|
|
72
|
+
```bash
|
|
73
|
+
make test
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### Code Quality
|
|
77
|
+
```bash
|
|
78
|
+
make check # Run linting, type checking, and tests
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
### CLI Commands
|
|
82
|
+
|
|
83
|
+
Your project gets its own CLI command **automatically installed** when first used - no setup required! 🎉
|
|
84
|
+
|
|
85
|
+
```bash
|
|
86
|
+
# Health monitoring (auto-installs CLI if needed)
|
|
87
|
+
make health # Basic health check
|
|
88
|
+
make health-detailed # Detailed component status
|
|
89
|
+
make health-json # JSON output for scripts
|
|
90
|
+
make health-quick # Quick healthy/unhealthy check
|
|
91
|
+
|
|
92
|
+
# Direct CLI usage (after first make command)
|
|
93
|
+
{{ cookiecutter.project_slug }} health check # Basic health check
|
|
94
|
+
{{ cookiecutter.project_slug }} health check --detailed # Detailed component status
|
|
95
|
+
{{ cookiecutter.project_slug }} health check --json # JSON output for scripts
|
|
96
|
+
{{ cookiecutter.project_slug }} health quick # Quick healthy/unhealthy check
|
|
97
|
+
|
|
98
|
+
# Explore all commands
|
|
99
|
+
{{ cookiecutter.project_slug }} --help # See all available commands
|
|
100
|
+
{{ cookiecutter.project_slug }} health --help # See health subcommand options
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
**Environment Issues?** If CLI commands don't work:
|
|
104
|
+
```bash
|
|
105
|
+
# Ensure you're in the project's virtual environment
|
|
106
|
+
unset VIRTUAL_ENV # Clear Docker contamination
|
|
107
|
+
source .venv/bin/activate # Activate local venv
|
|
108
|
+
make health # This will auto-install CLI
|
|
109
|
+
# Or manually: make install-cli
|
|
110
|
+
```
|
|
111
|
+
|
|
112
|
+
### Documentation
|
|
113
|
+
```bash
|
|
114
|
+
make docs-serve # Serve docs at http://localhost:8001/{{ cookiecutter.project_slug }}/
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
## Docker
|
|
118
|
+
|
|
119
|
+
### Development
|
|
120
|
+
```bash
|
|
121
|
+
docker compose --profile dev up
|
|
122
|
+
```
|
|
123
|
+
|
|
124
|
+
### Production
|
|
125
|
+
```bash
|
|
126
|
+
docker compose --profile prod up
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
{%- if cookiecutter.include_database == "yes" %}
|
|
130
|
+
|
|
131
|
+
## Configuration
|
|
132
|
+
|
|
133
|
+
### Database Settings
|
|
134
|
+
|
|
135
|
+
The database component uses SQLite with the following default configuration:
|
|
136
|
+
|
|
137
|
+
```bash
|
|
138
|
+
# Environment variables (add to .env file)
|
|
139
|
+
DATABASE_URL=sqlite:///data/app.db # Database file location
|
|
140
|
+
DATABASE_ENGINE_ECHO=false # Enable SQL query logging
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
### Database Usage
|
|
144
|
+
|
|
145
|
+
```python
|
|
146
|
+
from app.core.db import db_session
|
|
147
|
+
from sqlmodel import SQLModel, Field, select
|
|
148
|
+
|
|
149
|
+
# Define a model
|
|
150
|
+
class User(SQLModel, table=True):
|
|
151
|
+
id: int | None = Field(default=None, primary_key=True)
|
|
152
|
+
name: str
|
|
153
|
+
email: str
|
|
154
|
+
|
|
155
|
+
# Use the database
|
|
156
|
+
with db_session() as session:
|
|
157
|
+
user = User(name="John Doe", email="john@example.com")
|
|
158
|
+
session.add(user)
|
|
159
|
+
# Auto-committed by context manager
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
{%- endif %}
|
|
163
|
+
|
|
164
|
+
## Project Structure
|
|
165
|
+
|
|
166
|
+
```
|
|
167
|
+
{{ cookiecutter.project_slug }}/
|
|
168
|
+
├── app/ # Application code
|
|
169
|
+
│ ├── components/ # Component implementations
|
|
170
|
+
│ │ ├── backend/ # FastAPI backend
|
|
171
|
+
│ │ └── frontend/ # Flet frontend
|
|
172
|
+
{%- if cookiecutter.include_scheduler == "yes" %}
|
|
173
|
+
│ │ └── scheduler/ # APScheduler background tasks
|
|
174
|
+
{%- endif %}
|
|
175
|
+
│ ├── cli/ # CLI commands and health monitoring
|
|
176
|
+
│ ├── core/ # Core utilities
|
|
177
|
+
│ │ ├── config.py # Environment-dependent configuration
|
|
178
|
+
│ │ ├── constants.py # Immutable constants (12-Factor App)
|
|
179
|
+
{%- if cookiecutter.include_database == "yes" %}
|
|
180
|
+
│ │ ├── db.py # Database connection and session management
|
|
181
|
+
{%- endif %}
|
|
182
|
+
│ │ └── log.py # Structured logging
|
|
183
|
+
│ ├── entrypoints/ # Execution entry points
|
|
184
|
+
│ ├── integrations/ # App composition layer
|
|
185
|
+
{%- if cookiecutter._has_additional_components == "yes" %}
|
|
186
|
+
│ └── services/ # Business logic services
|
|
187
|
+
{%- endif %}
|
|
188
|
+
├── tests/ # Test suite
|
|
189
|
+
├── docs/ # Documentation
|
|
190
|
+
├── docker-compose.yml # Docker services
|
|
191
|
+
└── pyproject.toml # Project configuration
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
---
|
|
195
|
+
|
|
196
|
+
Generated with [Aegis Stack](https://github.com/lbedner/aegis-stack) 🛡️
|
aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/alembic/alembic.ini.j2
ADDED
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
# A generic, single database configuration.
|
|
2
|
+
|
|
3
|
+
[alembic]
|
|
4
|
+
# path to migration scripts
|
|
5
|
+
script_location = alembic
|
|
6
|
+
|
|
7
|
+
# template used to generate migration file names; The default value is %%(rev)s_%%(slug)s
|
|
8
|
+
# Uncomment the line below if you want the files to be prepended with date and time
|
|
9
|
+
# file_template = %%(year)d_%%(month).2d_%%(day).2d_%%(hour).2d%%(minute).2d-%%(rev)s_%%(slug)s
|
|
10
|
+
|
|
11
|
+
# sys.path path, will be prepended to sys.path if present.
|
|
12
|
+
# defaults to the current working directory.
|
|
13
|
+
prepend_sys_path = .
|
|
14
|
+
|
|
15
|
+
# timezone to use when rendering the date within the migration file
|
|
16
|
+
# as well as the filename.
|
|
17
|
+
# If specified, requires the python-dateutil library that can be
|
|
18
|
+
# installed by adding `alembic[tz]` to the pip requirements
|
|
19
|
+
# string value is passed to dateutil.tz.gettz()
|
|
20
|
+
# leave blank for localtime
|
|
21
|
+
# timezone =
|
|
22
|
+
|
|
23
|
+
# max length of characters to apply to the
|
|
24
|
+
# "slug" field
|
|
25
|
+
# truncate_slug_length = 40
|
|
26
|
+
|
|
27
|
+
# set to 'true' to run the environment during
|
|
28
|
+
# the 'revision' command, regardless of autogenerate
|
|
29
|
+
# revision_environment = false
|
|
30
|
+
|
|
31
|
+
# set to 'true' to allow .pyc and .pyo files without
|
|
32
|
+
# a source .py file to be detected as revisions in the
|
|
33
|
+
# versions/ directory
|
|
34
|
+
# sourceless = false
|
|
35
|
+
|
|
36
|
+
# version number format. This value is passed to the
|
|
37
|
+
# strftime() function and is used to generate revision timestamps.
|
|
38
|
+
# version_num_format = %%(year)d%%(month).2d%%(day).2d_%%(hour).2d%%(minute).2d
|
|
39
|
+
|
|
40
|
+
# version path separator; As mentioned above, this is the character used to split
|
|
41
|
+
# version_locations. The default within new alembic.ini files is "os", which uses
|
|
42
|
+
# os.pathsep. If this key is omitted entirely, it falls back to the legacy
|
|
43
|
+
# behavior of splitting on spaces and/or commas.
|
|
44
|
+
# version_path_separator = :
|
|
45
|
+
# version_path_separator = ;
|
|
46
|
+
# version_path_separator = space
|
|
47
|
+
version_path_separator = os
|
|
48
|
+
|
|
49
|
+
# set to 'true' to search source files recursively
|
|
50
|
+
# in each "version_locations" directory
|
|
51
|
+
# new in Alembic version 1.10
|
|
52
|
+
# recursive_version_locations = false
|
|
53
|
+
|
|
54
|
+
# the output encoding used when revision files
|
|
55
|
+
# are written from script.py.mako
|
|
56
|
+
# output_encoding = utf-8
|
|
57
|
+
|
|
58
|
+
sqlalchemy.url = driver://user:pass@localhost/dbname
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
[post_write_hooks]
|
|
62
|
+
# post_write_hooks defines scripts or Python functions that are run
|
|
63
|
+
# on newly generated revision scripts. See the documentation for further
|
|
64
|
+
# detail and examples
|
|
65
|
+
|
|
66
|
+
# format using "black" - use the console_scripts runner, against the "black" entrypoint
|
|
67
|
+
# hooks = black
|
|
68
|
+
# black.type = console_scripts
|
|
69
|
+
# black.entrypoint = black
|
|
70
|
+
# black.options = -l 79 REVISION_SCRIPT_FILENAME
|
|
71
|
+
|
|
72
|
+
# format using "ruff" - use the console_scripts runner, against the "ruff" entrypoint
|
|
73
|
+
# hooks = ruff
|
|
74
|
+
# ruff.type = console_scripts
|
|
75
|
+
# ruff.entrypoint = ruff
|
|
76
|
+
# ruff.options = format REVISION_SCRIPT_FILENAME
|
|
77
|
+
|
|
78
|
+
# Logging configuration
|
|
79
|
+
[loggers]
|
|
80
|
+
keys = root,sqlalchemy,alembic
|
|
81
|
+
|
|
82
|
+
[handlers]
|
|
83
|
+
keys = console
|
|
84
|
+
|
|
85
|
+
[formatters]
|
|
86
|
+
keys = generic
|
|
87
|
+
|
|
88
|
+
[logger_root]
|
|
89
|
+
level = WARN
|
|
90
|
+
handlers = console
|
|
91
|
+
qualname =
|
|
92
|
+
|
|
93
|
+
[logger_sqlalchemy]
|
|
94
|
+
level = WARN
|
|
95
|
+
handlers =
|
|
96
|
+
qualname = sqlalchemy.engine
|
|
97
|
+
|
|
98
|
+
[logger_alembic]
|
|
99
|
+
level = INFO
|
|
100
|
+
handlers =
|
|
101
|
+
qualname = alembic
|
|
102
|
+
|
|
103
|
+
[handler_console]
|
|
104
|
+
class = StreamHandler
|
|
105
|
+
args = (sys.stderr,)
|
|
106
|
+
level = NOTSET
|
|
107
|
+
formatter = generic
|
|
108
|
+
|
|
109
|
+
[formatter_generic]
|
|
110
|
+
format = %(levelname)-5.5s [%(name)s] %(message)s
|
|
111
|
+
datefmt = %H:%M:%S
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"""
|
|
2
|
+
Alembic environment configuration for SQLModel integration.
|
|
3
|
+
|
|
4
|
+
This module configures Alembic to work with SQLModel and ensures
|
|
5
|
+
proper metadata detection for autogenerate functionality.
|
|
6
|
+
"""
|
|
7
|
+
|
|
8
|
+
# ruff: noqa: I001
|
|
9
|
+
from logging.config import fileConfig
|
|
10
|
+
import sys
|
|
11
|
+
from pathlib import Path
|
|
12
|
+
|
|
13
|
+
from sqlalchemy import engine_from_config, pool
|
|
14
|
+
|
|
15
|
+
from alembic import context
|
|
16
|
+
|
|
17
|
+
# Add project root to path for imports
|
|
18
|
+
project_root = Path(__file__).parent.parent
|
|
19
|
+
sys.path.insert(0, str(project_root))
|
|
20
|
+
|
|
21
|
+
# Import SQLModel and models to register metadata
|
|
22
|
+
from sqlmodel import SQLModel # noqa: E402
|
|
23
|
+
from app.core.config import settings # noqa: E402
|
|
24
|
+
{% if cookiecutter.include_auth == "yes" %}
|
|
25
|
+
from app.models.user import User # noqa: E402,F401
|
|
26
|
+
{% endif %}
|
|
27
|
+
|
|
28
|
+
# this is the Alembic Config object, which provides
|
|
29
|
+
# access to the values within the .ini file in use.
|
|
30
|
+
config = context.config
|
|
31
|
+
|
|
32
|
+
# Interpret the config file for Python logging.
|
|
33
|
+
# This line sets up loggers basically.
|
|
34
|
+
if config.config_file_name is not None:
|
|
35
|
+
fileConfig(config.config_file_name)
|
|
36
|
+
|
|
37
|
+
# Set the SQLAlchemy URL from our settings
|
|
38
|
+
config.set_main_option("sqlalchemy.url", settings.DATABASE_URL)
|
|
39
|
+
|
|
40
|
+
# Set target metadata to SQLModel.metadata
|
|
41
|
+
target_metadata = SQLModel.metadata
|
|
42
|
+
|
|
43
|
+
def run_migrations_offline() -> None:
|
|
44
|
+
"""Run migrations in 'offline' mode.
|
|
45
|
+
|
|
46
|
+
This configures the context with just a URL
|
|
47
|
+
and not an Engine, though an Engine is acceptable
|
|
48
|
+
here as well. By skipping the Engine creation
|
|
49
|
+
we don't even need a DBAPI to be available.
|
|
50
|
+
|
|
51
|
+
Calls to context.execute() here emit the given string to the
|
|
52
|
+
script output.
|
|
53
|
+
"""
|
|
54
|
+
url = config.get_main_option("sqlalchemy.url")
|
|
55
|
+
context.configure(
|
|
56
|
+
url=url,
|
|
57
|
+
target_metadata=target_metadata,
|
|
58
|
+
literal_binds=True,
|
|
59
|
+
dialect_opts={"paramstyle": "named"},
|
|
60
|
+
)
|
|
61
|
+
|
|
62
|
+
with context.begin_transaction():
|
|
63
|
+
context.run_migrations()
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
def run_migrations_online() -> None:
|
|
67
|
+
"""Run migrations in 'online' mode.
|
|
68
|
+
|
|
69
|
+
In this scenario we need to create an Engine
|
|
70
|
+
and associate a connection with the context.
|
|
71
|
+
"""
|
|
72
|
+
connectable = engine_from_config(
|
|
73
|
+
config.get_section(config.config_ini_section, {}),
|
|
74
|
+
prefix="sqlalchemy.",
|
|
75
|
+
poolclass=pool.NullPool,
|
|
76
|
+
)
|
|
77
|
+
|
|
78
|
+
with connectable.connect() as connection:
|
|
79
|
+
context.configure(
|
|
80
|
+
connection=connection,
|
|
81
|
+
target_metadata=target_metadata
|
|
82
|
+
)
|
|
83
|
+
|
|
84
|
+
with context.begin_transaction():
|
|
85
|
+
context.run_migrations()
|
|
86
|
+
|
|
87
|
+
|
|
88
|
+
if context.is_offline_mode():
|
|
89
|
+
run_migrations_offline()
|
|
90
|
+
else:
|
|
91
|
+
run_migrations_online()
|
aegis/templates/cookiecutter-aegis-project/{{cookiecutter.project_slug}}/alembic/script.py.mako
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"""${message}
|
|
2
|
+
|
|
3
|
+
Revision ID: ${up_revision}
|
|
4
|
+
Revises: ${down_revision | comma,n}
|
|
5
|
+
Create Date: ${create_date}
|
|
6
|
+
|
|
7
|
+
"""
|
|
8
|
+
from alembic import op
|
|
9
|
+
import sqlalchemy as sa
|
|
10
|
+
import sqlmodel
|
|
11
|
+
${imports if imports else ""}
|
|
12
|
+
|
|
13
|
+
# revision identifiers, used by Alembic.
|
|
14
|
+
revision = ${repr(up_revision)}
|
|
15
|
+
down_revision = ${repr(down_revision)}
|
|
16
|
+
branch_labels = ${repr(branch_labels)}
|
|
17
|
+
depends_on = ${repr(depends_on)}
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
def upgrade() -> None:
|
|
21
|
+
${upgrades if upgrades else "pass"}
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
def downgrade() -> None:
|
|
25
|
+
${downgrades if downgrades else "pass"}
|