Sponsored by Deepsite.site

Norman Finance MCP Server

Created By
norman-finance8 months ago
Norman is the accounting and tax filing autopilot for entrepreneurs in Germany. It’s like having a personal accounting & tax manager — but built into Claude, Cursor, or your favorite LLM. Norman’s MCP server lets you manage invoicing, accounting, and taxes directly inside your AI workspace.
Content

Norman Finance MCP Server

A Model Context Protocol (MCP) server that allows Large Language Models (LLMs) to interact with the basic Norman Finance API implementation. This server provides access to accounting, invoices, companies, clients, taxes, and more through a standardized protocol.

Features

  • 🔐 Authentication: Securely authenticate with the Norman Finance API
  • 💼 Company Management: View and update company details
  • 📊 Accounting: Access and manage transactions
  • 📝 (e-)Invoicing: Create, view, send, and manage complaint invoices
  • 👥 Client Management: Create and manage clients
  • 💰 Taxes: View tax information and reports, generate official Finanzamt PDF previews
  • 📄 Documents: Upload and manage attachments

Prerequisites

Before using this MCP server, you need to:

  1. Create an account on Norman Finance (or dev.norman.finance for the sandbox environment)
  2. Have your email and password ready for authentication

Installation

pip install norman-mcp-server

From Source

git clone https://github.com/norman-finance/norman-mcp-server.git
cd norman-mcp-server
pip install -e .

Configuration

Environment Variables

The server requires authentication with your Norman Finance credentials. You can provide these through environment variables:

Create a .env file with:

# .env
NORMAN_EMAIL=your-email@example.com
NORMAN_PASSWORD=your-password
NORMAN_ENVIRONMENT=production  # or "sandbox" for the development environment
NORMAN_API_TIMEOUT=100  # Request timeout in seconds

Command Line Arguments

Alternatively, you can provide the credentials through command line arguments:

norman-mcp --email your-email@example.com --password your-password --environment production

Configuring with Claude

To use the Norman Finance MCP server with Claude, add it to your Claude configuration:

{
  "mcpServers": {
    "norman": {
      "command": "norman-mcp",
      "args": [],
      "env": {
        "NORMAN_EMAIL": "your-email@example.com",
        "NORMAN_PASSWORD": "your-password",
        "NORMAN_ENVIRONMENT": "production"
      }
    }
  }
}

If you've installed from source or are running in a local development environment, you should point to the Python module directory directly:

{
  "mcpServers": {
    "norman": {
      "command": "python",
      "args": ["-m", "norman_mcp"],
      "env": {
        "NORMAN_EMAIL": "your-email@example.com",
        "NORMAN_PASSWORD": "your-password",
        "NORMAN_ENVIRONMENT": "production"
      }
    }
  }
}

Usage

With Claude or Other MCP-Compatible LLMs

  1. Start the MCP server:
norman-mcp
  1. Add the server to your Claude configuration using stdio protocol.

Integration with Claude Desktop

You can install the server using the MCP CLI:

mcp install norman-mcp

Configure your Norman Finance credentials when prompted.

Direct Execution

You can also run the server directly with:

python -m norman_mcp

Resources

This MCP server exposes the following resources:

  • company://current - Details about your current company
  • transactions://list/{page}/{page_size} - List of transactions with pagination
  • invoices://list/{page}/{page_size} - List of invoices with pagination
  • clients://list/{page}/{page_size} - List of clients with pagination
  • taxes://list/{page}/{page_size} - List of tax reports with pagination
  • categories://list - List of transaction categories

Tools

The MCP server provides the following tools for Norman Finance API interaction:

Company Management

  • get_company_details() - Get detailed information about your company
  • update_company_details(name, profession, address, etc.) - Update company information
  • get_company_balance() - Get the current balance of the company
  • get_company_tax_statistics() - Get tax statistics for the company
  • get_vat_next_report() - Get the VAT amount for the next report period

Transaction Management

  • search_transactions(description, from_date, to_date, min_amount, max_amount, etc.) - Search for transactions matching criteria
  • create_transaction(amount, description, cashflow_type, etc.) - Create a new transaction
  • update_transaction(transaction_id, amount, description, etc.) - Update an existing transaction
  • categorize_transaction(transaction_amount, transaction_description, transaction_type) - Detect category for a transaction using AI

Invoice Management

  • create_invoice(client_id, items, etc.) - Create a new invoice
  • get_invoice(invoice_id) - Get details about a specific invoice
  • send_invoice(invoice_id, subject, body, etc.) - Send an invoice via email
  • link_transaction(invoice_id, transaction_id) - Link a transaction to an invoice
  • get_einvoice_xml(invoice_id) - Get the e-invoice XML for a specific invoice
  • list_invoices(status, from_date, to_date, etc.) - List invoices with optional filtering

Client Management

  • list_clients() - Get a list of all clients
  • get_client(client_id) - Get detailed information about a specific client
  • create_client(name, client_type, address, etc.) - Create a new client
  • update_client(client_id, name, client_type, etc.) - Update an existing client
  • delete_client(client_id) - Delete a client

Document Management

  • upload_bulk_attachments(file_paths, cashflow_type) - Upload multiple file attachments in bulk
  • list_attachments(file_name, linked, attachment_type, etc.) - Get list of attachments with optional filters
  • create_attachment(file_path, transactions, attachment_type, etc.) - Create a new attachment
  • link_attachment_transaction(attachment_id, transaction_id) - Link a transaction to an attachment

Tax Management

  • list_tax_reports() - List all available tax reports
  • get_tax_report(report_id) - Retrieve a specific tax report
  • validate_tax_number(tax_number, region_code) - Validate a tax number for a specific region
  • generate_finanzamt_preview(report_id) - Generate a test Finanzamt preview for a tax report
  • list_tax_states() - Get list of available tax states
  • list_tax_settings() - Get list of tax settings for the current company
  • update_tax_setting(setting_id, tax_type, vat_type, etc.) - Update a tax setting

Prompts

The MCP server offers these guided prompts to help users interact with Norman Finance:

  • create_transaction_prompt(amount, description, cashflow_type) - Create a prompt for adding a new transaction
  • create_client_prompt(name, client_type) - Create a prompt for adding a new client
  • send_invoice_prompt(invoice_id) - Create a prompt for sending an invoice via email
  • search_transactions_prompt(date_range) - Create a prompt for searching transactions

Example Interactions

Here are some example interactions with the Norman Finance MCP server:

View Company Details

You can view your company details by accessing the company resource.
[LLM accesses company://current]

List Transactions

To see your recent financial transactions:
[LLM accesses transactions://list/1/10]

Create a Transaction

To create a new expense transaction:
[LLM calls create_transaction with amount=-129.99, description="Office supplies", cashflow_type="EXPENSE"]

Create an Invoice

To create a new invoice, I'll use the create_invoice tool.
[LLM calls create_invoice with client_id, items, etc.]

Development

This section is for contributors who want to develop or extend the Norman Finance MCP server.

Local Development Setup

  1. Clone the repository:

    git clone https://github.com/norman-finance/norman-mcp-server.git
    cd norman-mcp-server
    
  2. Create and activate a virtual environment:

    # Using venv
    python -m venv venv
    source venv/bin/activate  # On Windows: venv\Scripts\activate
    
    # Or using uv (recommended)
    uv venv
    source .venv/bin/activate  # On Windows: .venv\Scripts\activate
    
  3. Install development dependencies:

    # Using pip
    pip install -e ".[dev]"
    
    # Or using uv
    uv pip install -e ".[dev]"
    
  4. Create a .env file with your Norman Finance credentials:

    cp .env.template .env
    # Edit .env with your credentials
    

Running in Development Mode

To run the MCP server in development mode with the MCP Inspector:

mcp dev norman_mcp/server.py

This will start the server and open the MCP Inspector in your browser, allowing you to test resources and tools interactively.

Recommend Servers
TraeBuild with Free GPT-4.1 & Claude 3.7. Fully MCP-Ready.
Howtocook Mcp基于Anduin2017 / HowToCook (程序员在家做饭指南)的mcp server,帮你推荐菜谱、规划膳食,解决“今天吃什么“的世纪难题; Based on Anduin2017/HowToCook (Programmer's Guide to Cooking at Home), MCP Server helps you recommend recipes, plan meals, and solve the century old problem of "what to eat today"
Playwright McpPlaywright MCP server
Serper MCP ServerA Serper MCP Server
MiniMax MCPOfficial MiniMax Model Context Protocol (MCP) server that enables interaction with powerful Text to Speech, image generation and video generation APIs.
Visual Studio Code - Open Source ("Code - OSS")Visual Studio Code
ChatWiseThe second fastest AI chatbot™
TimeA Model Context Protocol server that provides time and timezone conversion capabilities. This server enables LLMs to get current time information and perform timezone conversions using IANA timezone names, with automatic system timezone detection.
MCP AdvisorMCP Advisor & Installation - Use the right MCP server for your needs
Jina AI MCP ToolsA Model Context Protocol (MCP) server that integrates with Jina AI Search Foundation APIs.
EdgeOne Pages MCPAn MCP service designed for deploying HTML content to EdgeOne Pages and obtaining an accessible public URL.
AiimagemultistyleA Model Context Protocol (MCP) server for image generation and manipulation using fal.ai's Stable Diffusion model.
Amap Maps高德地图官方 MCP Server
Tavily Mcp
Context7Context7 MCP Server -- Up-to-date code documentation for LLMs and AI code editors
Baidu Map百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
CursorThe AI Code Editor
Zhipu Web SearchZhipu Web Search MCP Server is a search engine specifically designed for large models. It integrates four search engines, allowing users to flexibly compare and switch between them. Building upon the web crawling and ranking capabilities of traditional search engines, it enhances intent recognition capabilities, returning results more suitable for large model processing (such as webpage titles, URLs, summaries, site names, site icons, etc.). This helps AI applications achieve "dynamic knowledge acquisition" and "precise scenario adaptation" capabilities.
DeepChatYour AI Partner on Desktop
BlenderBlenderMCP connects Blender to Claude AI through the Model Context Protocol (MCP), allowing Claude to directly interact with and control Blender. This integration enables prompt assisted 3D modeling, scene creation, and manipulation.
WindsurfThe new purpose-built IDE to harness magic