MCPSERV.CLUB
OpenBudgeteer

OpenBudgeteer

Self-Hosted

Self-hosted budgeting with bucket principles

Active(72)
888stars
0views
Updated Jul 28, 2025
OpenBudgeteer screenshot 1
1 / 5

Overview

Discover what makes OpenBudgeteer powerful

OpenBudgeteer is a self‑hosted financial management platform that implements the Bucket Budgeting Principle. From a developer’s standpoint it is a **full‑stack .NET solution** that couples a Blazor Server front‑end with a robust MVVM‑based back‑end. The application exposes a rich set of domain entities—accounts, categories, buckets, transactions—and offers an extensible API surface that can be consumed by third‑party tools or integrated into existing ERP stacks.

Back‑end

Front‑end

Containerization

Database

Overview

OpenBudgeteer is a self‑hosted financial management platform that implements the Bucket Budgeting Principle. From a developer’s standpoint it is a full‑stack .NET solution that couples a Blazor Server front‑end with a robust MVVM‑based back‑end. The application exposes a rich set of domain entities—accounts, categories, buckets, transactions—and offers an extensible API surface that can be consumed by third‑party tools or integrated into existing ERP stacks.

Technical Stack & Architecture

  • Back‑end: C# 11 on .NET 8, following the Model‑View‑ViewModel (MVVM) pattern. Business logic is encapsulated in services, while persistence uses Entity Framework Core with a MariaDB provider. The choice of EF Core allows LINQ‑based queries and code‑first migrations that are easy to version control.
  • Front‑end: Blazor Server, leveraging SignalR for real‑time UI updates. Components are strongly typed and reuse the same ViewModel classes that the server exposes, ensuring a single source of truth for UI state.
  • Containerization: Docker images are published to GitHub Packages and Docker Hub, with CI pipelines that build both pre‑release and latest tags. The image is lightweight (≈ 400 MB) thanks to the multi‑stage build and Alpine base.
  • Database: MariaDB (or MySQL) is the only supported relational store, with a dedicated OpenBudgeteer schema. The application ships with SQL scripts for initial setup and supports automated migrations on container start.

Core Capabilities & Developer APIs

  • REST‑like API: While the primary interface is Blazor, the application exposes a set of JSON endpoints for CRUD operations on accounts, buckets, and transactions. These endpoints are authenticated via JWT tokens that can be generated by the web UI or programmatically.
  • Webhooks: Developers can register webhook URLs to receive event notifications (e.g., new transaction, bucket rollover). This is useful for synchronizing with external accounting systems.
  • Plugin System: The application exposes a simple plugin contract (IPlugin) that allows additional UI components or background jobs to be injected at runtime. Plugins are discovered via a convention‑based assembly scan and can ship as separate Docker images that mount into the plugin folder.
  • Scripting: An embedded scripting engine (C# Roslyn) lets advanced users write custom validation rules or automated budget adjustments that run on the server side.

Deployment & Infrastructure

  • Self‑hosting: A single Docker Compose file (available in the docs) orchestrates the web service and MariaDB. The container exposes port 80 by default, but can be mapped to any host port or behind a reverse proxy.
  • Scalability: Because Blazor Server relies on SignalR, scaling horizontally requires a shared backplane (e.g., Redis). The application is already configured to accept an optional RedisConnectionString environment variable for this purpose.
  • Persistence: All user data resides in MariaDB; backups can be performed with standard mysqldump or Docker volumes. The application also supports read‑replica configurations for reporting workloads.

Integration & Extensibility

  • OAuth/OpenID Connect: Optional integration with external identity providers (e.g., Keycloak, Azure AD) is supported via ASP.NET Core authentication middleware.
  • Custom Themes: CSS variables and Razor component overrides allow UI theming without touching the core codebase.
  • CLI Tools: A lightweight command‑line interface (CLI) can be used to seed data, run migrations, or trigger background jobs from CI pipelines.

Developer Experience

  • Documentation: The project hosts comprehensive, autogenerated docs on GitHub Pages. API reference pages are generated from XML comments.
  • Community: The project is listed in awesome‑selfhosted and has an active GitHub issue tracker. Pull requests are reviewed promptly, and the maintainers encourage contributions to both core features and plugin examples.
  • Licensing: MIT license ensures no licensing constraints, making it ideal for both commercial and open‑source projects.

Use Cases

  1. Personal Finance Platform: A solo developer can deploy OpenBudgeteer behind a reverse proxy, integrate it with their bank’s API via webhooks, and expose budgeting dashboards to family members.
  2. Small Business Accounting: Companies can embed OpenBudgeteer into their existing .NET microservice ecosystem, using the plugin system to generate automated expense reports and sync with accounting software.
  3. Educational Tool: Universities can host a multi‑tenant instance for finance courses, leveraging the bucket model to teach budgeting concepts while providing an API for student projects.

Advantages

  • Performance: Blazor Server’s SignalR model keeps UI latency low, while EF Core optimizes queries for MariaDB.
  • Flexibility: The MVVM architecture decouples UI from business logic, enabling developers to swap front‑ends (e.g., Blazor WebAssembly) with minimal code changes.
  • Scalability: Docker images and optional Redis backplane make it straightforward to scale horizontally for high‑traffic scenarios.
  • Extensibility: The plugin contract and webhook support allow rapid integration with external systems without modifying core code.
  • Open Source: MIT licensing and active community mean developers can tailor the application to niche requirements without legal overhead.

OpenBudgeteer blends modern .NET practices with a proven budgeting methodology, offering developers a turnkey platform that can be extended, scaled, and integrated into almost any self

Open SourceReady to get started?

Join the community and start self-hosting OpenBudgeteer today

Weekly Views

Loading...
Support Us
Most Popular

Infrastructure Supporter

$5/month

Keep our servers running and help us maintain the best directory for developers

Repository Health

Loading health data...

Information

Category
other
License
AGPL-3.0
Stars
888
Technical Specs
Pricing
Open Source
Database
MySQL
Docker
Official
Supported OS
LinuxDocker
Author
TheAxelander
TheAxelander
Last Updated
Jul 28, 2025