Daniel Krähenbühl
c03d2a97ab
feat: insurance section — overview, documents, analysis, KVG premium comparison
...
- Insurance overview page (/insurance): current policies table with type,
provider, premium, franchise, coverage, and document links
- Documents page: upload and manage insurance documents
- Analysis page: coverage gap analysis per insurance type
- Priminfo integration (/insurance/priminfo): KVG premium comparison by
insurer, model (TAR/HMO/etc.), franchise level, and accident coverage
via embedded Priminfo iframe (no public API available)
- Backend: Insurance, PraemienEntry, PraemienPolice models with migrations
- Sidebar: insurance nav group with flyout and dropdown
- i18n: all keys in DE/EN/FR/IT
2026-05-25 22:46:31 +02:00
Daniel Krähenbühl
1a7ef09805
feat: Armarium v1.1.0 — dashboard, auth, 2FA, SMTP, settings, deploy
...
Dashboard:
- ApexCharts bar chart (income vs fixed costs vs expenses) and donut chart
- KPI cards: income, fixed costs, savings rate with configurable goal
- Greeting with time-of-day and locale-aware date/time display
Authentication & security:
- Email-based login (no username), case-insensitive lookup
- JWT access/refresh tokens with rotation and blacklist
- TOTP 2FA with QR code, backup codes (copy + PDF export)
- 2FA recovery via email code
- Cloudflare Turnstile CAPTCHA on login and register
Email flows:
- Email verification on registration (24h token)
- Password reset flow (15min token, anti-enumeration)
- Brevo SMTP integration with HTML + plaintext email templates
- Notification emails: 2FA recovery, password changed, email changed
Settings page:
- 2FA management (enable/disable, QR, backup codes)
- Active sessions list with per-device revoke
- Data export: ZIP with 6 PDFs via fpdf2
- Notification preferences (3 toggles)
- Danger zone: account deletion with mandatory export + confirmation phrase
UI & layout:
- Sidebar with collapsible/flyout mode, Angular signal-based dropdowns
- Dark mode (class-based), language switcher (DE/FR/IT/EN)
- Mobile-responsive layout with touch-friendly targets
- Roboto font via @fontsource (GDPR-compliant, no Google CDN)
- Pure Tailwind CSS v3
Infrastructure:
- Forgejo Actions CI/CD pipeline (auto-deploy on push to main)
- Gunicorn + Nginx + PostgreSQL production setup
- Rate limiting, HSTS, secure cookies, CSRF protection
2026-05-25 22:46:30 +02:00
Daniel Krähenbühl
807ebc41a5
release: Armarium v1.0.0
...
Full-stack personal finance application (Django + Angular 21).
Backend: Django REST Framework, JWT auth, PostgreSQL, iCal feed, rate limiting.
Frontend: Angular 21 standalone components, TailwindCSS, i18n (DE/FR/IT/EN),
responsive mobile layout, dark/light mode, ApexCharts dashboard,
Swiss holiday calendar with canton support.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-13 14:08:44 +02:00