# Implementing virtual cash This chapter describes step by step how you can implement virtual cash management with the Investment API. We show you the necessary API calls with sample code for a virtual cash increase or decrease. If you want to learn more about the concept, go to ['Introduction'](/products/byol/guides/virtual_cash/concept), and in the chapter ['Use Cases'](/products/byol/guides/virtual_cash/use_cases) you can find out more about some example processes related to virtual cash. ## Prerequisites The settlement of trades must be executed via Upvest's post-trade settlement and treasury procedure. In this process, payments do not have to be made for the deposits, but only for the corresponding orders. ## Increasing virtual cash To submit a virtual cash increase, make the following request: **POST** [`virtual_cash_balances/increases`](/api/virtual-cash-balances/create_virtual_cash_increase) **Example request** { "account_group_id": "2596db3b-0d03-4651-9eda-970910479dfb", "amount": "200.00", "currency": "EUR" } | Parameter | Description | | --- | --- | | `account_group_id` | **Required**. ID of the account group for which the balance increase is to be applied. | | `amount` | **Required**. The amount by which to increase. | | `currency` | **Required**. The currency in which the increase is to be made. Currently only EUR is possible. | **Example response** { "id": "6ffa6b16-2380-4e7a-88b2-ae625c8eef99", "created_at": "2020-08-24T14:15:22Z", "updated_at": "2020-08-24T14:15:22Z", "account_group_id": "ac1c39e9-2101-46b8-a624-d10a9e351b6c", "amount": "200.00", "currency": "EUR", "status": "ISSUED" } ### Webhooks For the increase you will receive the following [event](/api/virtual-cash-balances/virtual_cash_increase_event): - The request for the increase was created. - The increase request was confirmed. | Event | Description | | --- | --- | | `VIRTUAL_CASH_INCREASE.ISSUED` | The request for the increase was created. | | `VIRTUAL_CASH_INCREASE.CONFIRMED` | The increase request was confirmed so that the balance is now available for trading. | ## Decreasing virtual cash In some cases, if the increase you made was more than was needed for the order, it is best to reduce the remaining balance. This way we can keep the balance free of rounding dust and misleading cash balances. To submit a virtual cash decrease, make the following request: **POST** [`virtual_cash_balances/decreases`](/api/virtual-cash-balances/create_virtual_cash_decrease) **Example request** { "account_group_id": "2596db3b-0d03-4651-9eda-970910479dfb", "amount": "200.00", "currency": "EUR" } | Parameter | Description | | --- | --- | | `account_group_id` | **Required**. ID of the account group for which the balance increase is to be applied. | | `amount` | **Required**. The amount by which to increase. | | `currency` | **Required**. The currency in which the increase is to be made. Currently only EUR is possible. | **Example response** { "id": "6ffa6b16-2380-4e7a-88b2-ae625c8eef99", "created_at": "2020-08-24T14:15:22Z", "updated_at": "2020-08-24T14:15:22Z", "account_group_id": "ac1c39e9-2101-46b8-a624-d10a9e351b6c", "amount": "200.00", "currency": "EUR", "status": "ISSUED" } ### Webhooks For the increase you will receive the following [event](/api/virtual-cash-balances/virtual_cash_decrease_event): - The request for the decrease was created. - The decrease request was confirmed. - The decrease went into the backlog. | Event | Description | | --- | --- | | `VIRTUAL_CASH_DECREASE.ISSUED` | The request for the decrease was created. | | `VIRTUAL_CASH_DECREASE.CONFIRMED` | The decrease request was confirmed; the cash balance has left the specified account. | | `VIRTUAL_CASH_DECREASE.QUEUED` | The decrease went into the backlog due to lack of funds. It will be moved to `Confirmed` status once funds arrive. | ## Cancelling a virtual cash decrease It is possible to cancel a virtual cash decrease. It is only possible to cancel a virtual cash decrease if it has the `ISSUED` or `QUEUED` status. To cancel a virtual cash decrease, make the following request: **DELETE** [`/virtual_cash_balances/decreases/{virtual_cash_decrease_id}`](/api/virtual-cash-balances/cancel_virtual_cash_decrease) | Path parameter | Description | | --- | --- | | `virtual_cash_decrease_id` | **Required**. Specify the ID of the decrease that you want to delete. | ### Webhook For the increase you will receive the following event: - The specified virtual cash decrease was cancelled. | Event | Description | | --- | --- | | `VIRTUAL_CASH_DECREASE.CANCELLED` | The specified virtual cash decrease was cancelled. |