> ## Documentation Index
> Fetch the complete documentation index at: https://docs.lerian.studio/llms.txt
> Use this file to discover all available pages before exploring further.

# Managing Fee Packages

> Create, edit, and delete Fee Packages from the Console to control how charges are applied to Transactions.

**Fee Packages** are the building blocks of the [Fees Engine](/en/lerian-console/midaz-console/fees-engine-overview). Each package defines a set of fee rules and the conditions under which they apply to Transactions.

<Note>
  The Fees Engine plugin must be enabled in [Midaz module settings](/en/lerian-console/midaz-console/plugin-settings) before this page is available.
</Note>

## What a Fee Package contains

***

A Fee Package lets you:

* **Define fee calculation rules** — flat fees, percentage-based fees, or combined calculations.
* **Set amount ranges** — apply fees only to transactions within a min/max range.
* **Link to transaction routes** — target specific transaction flows.
* **Waive fees for specific accounts** — exempt selected source accounts.
* **Prioritize fee application** — control the order in which multiple fees are applied.

Fee Packages combine with [Accounting Routes](/en/lerian-console/midaz-console/managing-accounting-routes) and [Segments](/en/lerian-console/midaz-console/managing-segments) for granular control.

## Accessing the Fee Packages page

***

In the Midaz Module sidebar, expand **Fees Engine** and select **Fee Packages**. The page lists every configured package.

<Note>
  If you do not have any Fee Packages, the list will appear empty with a prompt to create your first package.
</Note>

### Available actions

From the Fee Packages page, you can:

<Columns cols={2}>
  <Card title="Create a Fee Package" icon="plus" horizontal href="/en/lerian-console/midaz-console/fe-creating-a-package">
    Define new fee calculation rules for transactions
  </Card>

  <Card title="Edit a Fee Package" icon="pen" horizontal href="/en/lerian-console/midaz-console/fe-editing-a-package">
    Update fee configurations and rules
  </Card>

  <Card title="Delete a Fee Package" icon="trash" horizontal href="/en/lerian-console/midaz-console/fe-deleting-a-package">
    Remove a fee package from your configuration
  </Card>
</Columns>

## Understanding Fee Package structure

***

When creating or editing a fee package in Midaz Module, you'll work with:

### Basic information

* **Fee Group Label** (required) - A descriptive name for the fee package
* **Description** (required) - Explanation of the package purpose and when it applies
* **Transaction Route** (optional) - Link to a specific transaction route
* **Segment** (optional) - Associate with a specific segment
* **Ledger** (required) - The ledger this package applies to

### Amount range

* **Minimum Amount** (required) - Lowest transaction amount for fee application
* **Maximum Amount** (required) - Highest transaction amount for fee application
* **Waived Accounts** (optional) - List of account aliases exempt from these fees

### Fee rules

Each fee package can contain multiple fee rules with:

* **Fee Label** - Name identifying this specific fee
* **Application Rule** - How the fee is calculated:
  * `flatFee` - Fixed amount regardless of transaction value
  * `percentual` - Percentage of the transaction amount
  * `maxBetweenTypes` - Higher value between flat and percentage calculations
* **Calculation Type** - `flat` or `percentage`
* **Calculation Value** - The fee amount or percentage
* **Reference Amount** - Base for percentage calculation:
  * `originalAmount` - Calculate on original transaction value
  * `afterFeesAmount` - Calculate after other fees are applied
* **Priority** - Order of fee application (lower numbers apply first)
* **Is Deductible From** - Whether this fee is deducted from the transaction
* **Credit Account** - Account that receives the fee amount

## Common use cases

***

<AccordionGroup>
  <Accordion title="Simple flat fee per transaction">
    Apply a fixed fee to all transactions within an amount range:

    * **Application Rule**: `flatFee`
    * **Calculation**: `flat` with value `2.50`
    * **Example**: $2.50 fee on every transaction between $10 and \$1000
  </Accordion>

  <Accordion title="Percentage-based fee">
    Charge a percentage of the transaction amount:

    * **Application Rule**: `percentual`
    * **Calculation**: `percentage` with value `1.5`
    * **Example**: 1.5% fee on transfers, where $100 transfer = $1.50 fee
  </Accordion>

  <Accordion title="Tiered fee structure">
    Create multiple packages with different amount ranges:

    * Package 1: $0-$100 → 2% fee
    * Package 2: $100-$1000 → 1.5% fee
    * Package 3: \$1000+ → 1% fee
    * Lower fees for higher-value transactions
  </Accordion>

  <Accordion title="Combined flat + percentage (maximum)">
    Apply whichever is higher between flat and percentage:

    * **Application Rule**: `maxBetweenTypes`
    * **Calculations**: `flat: 1.00` and `percentage: 2.0`
    * **Example**: On $30 transaction: max($1.00, $0.60) = $1.00 fee
    * **Example**: On $100 transaction: max($1.00, $2.00) = $2.00 fee
  </Accordion>

  <Accordion title="Fee waiver for premium accounts">
    Exempt specific accounts from fees:

    * Create package with standard fee rules
    * Add premium account aliases to **Waived Accounts** list
    * These accounts transact without incurring the configured fees
  </Accordion>
</AccordionGroup>

## Best practices

***

<Steps>
  <Step title="Plan your fee structure">
    Design your fee packages before implementation. Consider transaction types, amount ranges, and customer segments that require different fee treatments.
  </Step>

  <Step title="Use descriptive labels">
    Choose clear fee group labels and descriptions that explain when and why fees apply. This helps with auditing and customer communication.
  </Step>

  <Step title="Set appropriate amount ranges">
    Define minimum and maximum amounts carefully to avoid gaps or overlaps in your fee structure.
  </Step>

  <Step title="Test fee calculations">
    Use the [Fee Estimation](/en/lerian-console/midaz-console/fe-fee-simulation) feature to verify fee calculations before enabling packages in production.
  </Step>

  <Step title="Manage priority carefully">
    When using multiple fees in a package, set priorities to ensure fees are applied in the correct order.
  </Step>

  <Step title="Document waived accounts">
    Keep track of why certain accounts are waived from fees for audit and compliance purposes.
  </Step>
</Steps>

## Fee calculation flow

***

When a transaction is processed, Fees Engine:

1. Identifies applicable fee packages based on transaction route and segment
2. Filters packages by amount range (transaction must fall within min/max)
3. Checks if source account is in the waived accounts list
4. Applies fee rules in priority order
5. Calculates each fee based on application rule and reference amount
6. Credits fee amounts to designated accounts

<Note>
  Fee packages must be **enabled** to apply to transactions. You can disable packages temporarily without deleting them.
</Note>
