initial: alpaclaudia paper-trading bot + dashboard

Python bot (bot/alpaclaudia): alpaca-py client, wheel strategy (CSP + covered
calls) plus equity trailing stops, risk gates (cash buffer, cost-basis guard,
per-symbol concentration cap), SQLite state log, Typer CLI (tick/loop/status/
report/dump-state), Discord daily report, pytest suite.

Next.js 14 dashboard (dashboard/): read-only — reads the bot's SQLite directly
and pulls live account/positions/orders from Alpaca. KPIs, equity chart,
positions, bot-intents audit table, and orders table. Dark UI with Tailwind.

systemd/: user-unit templates for the polling loop and the post-close report
timer.

docs/STRATEGY.md: wheel mechanics, risk invariants, later candidates.

Defaults to BOT_MODE=dry — nothing is submitted to Alpaca until explicitly
enabled in .env. ALPACA_ENV=paper by default; flipping to live requires an
explicit second guard.
This commit is contained in:
2026-04-16 21:38:25 +02:00
commit 39875112a0
46 changed files with 5195 additions and 0 deletions
+35
View File
@@ -0,0 +1,35 @@
[project]
name = "alpaclaudia"
version = "0.1.0"
description = "Alpaca Paper-Trading Bot — Wheel strategy + equity trailing stops."
requires-python = ">=3.11"
dependencies = [
"alpaca-py>=0.43.0",
"python-dotenv>=1.0.1",
"httpx>=0.27.0",
"pydantic>=2.7.0",
"typer>=0.12.0",
"rich>=13.7.0",
"pandas>=2.2.0",
"pytz>=2024.1",
]
[project.optional-dependencies]
dev = [
"pytest>=8.0",
"ruff>=0.5",
]
[project.scripts]
alpaclaudia = "alpaclaudia.__main__:app"
[build-system]
requires = ["hatchling"]
build-backend = "hatchling.build"
[tool.hatch.build.targets.wheel]
packages = ["alpaclaudia"]
[tool.ruff]
line-length = 100
target-version = "py311"