1
0
mirror of https://github.com/oceanprotocol/docs.git synced 2024-11-26 19:49:26 +01:00
docs/developers/contracts/fees.md

110 lines
7.8 KiB
Markdown
Raw Normal View History

2022-01-18 07:31:08 +01:00
---
description: The Ocean Protocol defines various fees for creating a sustainability loop.
---
# Fees
2023-06-13 18:29:52 +02:00
One transaction may have fees going to several entities, such as the market where the asset was published, or the Ocean Community. Here are all of them:
* Publish Market: the market where the asset was published.
* Consume Market: the market where the asset was consumed.
* Provider: the entity facilitating asset consumption. May serve up data, run compute, etc.
* Ocean Community: Ocean Community Wallet.
### Publish fee
When you publish an asset on the Ocean marketplace, there are currently no charges for publishing fees :tada:
However, if you're building a custom marketplace, you have the flexibility to include a publishing fee by adding an extra transaction in the publish flow. Depending on your marketplace's unique use case, you, as the marketplace owner, can decide whether or not to implement this fee. We believe in giving you the freedom to tailor your marketplace to your specific needs and preferences.
| Value in Ocean Market | Value in Other Markets |
| --------------------- | ------------------------------ |
| 0% | Customizable in market config. |
### Consume(aka. Order) fee
When a user exchanges a [datatoken](datatokens.md) for the privilege of downloading an asset or initiating a compute job that utilizes the asset, consume fees come into play. These fees are associated with accessing an asset and include:
2023-07-16 09:19:03 +02:00
1. **Publisher Market** Consumption Fee
2023-06-13 18:29:52 +02:00
* Defined during the ERC20 [creation](https://github.com/oceanprotocol/contracts/blob/b937a12b50dc4bdb7a6901c33e5c8fa136697df7/contracts/templates/ERC721Template.sol#L334).
* Defined as Address, Token, Amount. The amount is an absolute value(not a percentage).
2023-07-16 09:19:03 +02:00
* A marketplace can charge a specified amount per order.
2023-06-13 18:29:52 +02:00
* Eg: A market can set a fixed fee of 10 USDT per order, no matter what pricing schemas are used (fixedrate with ETH, BTC, dispenser, etc).
2023-07-16 09:19:03 +02:00
2. **Consume Market** Consumption Fee
* A market can specify what fee it wants on the order function.
3. **Provider Consumption** Fees
2023-06-29 17:52:01 +02:00
* Defined by the [Provider](../provider/README.md) for any consumption.
2023-06-13 18:29:52 +02:00
* Expressed in: Address, Token, Amount (absolute), Timeout.
2023-07-16 09:19:03 +02:00
* You can retrieve them when calling the initialize endpoint.
2023-06-13 18:29:52 +02:00
* Eg: A provider can charge a fixed fee of 10 USDT per consume, irrespective of the pricing schema used (e.g., fixed rate with ETH, BTC, dispenser).
4. **Ocean Community** Fee
2023-10-19 14:54:19 +02:00
* Ocean's smart contracts collect **Ocean Community fees** during order operations. These fees are reinvested in community projects and distributed to the veOCEAN holders through Data Farming.
2023-06-13 18:29:52 +02:00
* This fee is set at the [smart contract](https://github.com/oceanprotocol/contracts/blob/main/contracts/communityFee/OPFCommunityFeeCollector.sol) level.
2023-10-11 21:22:40 +02:00
* It can be updated by Ocean Protocol Foundation. See details in the [smart contracts](https://github.com/oceanprotocol/contracts/blob/main/contracts/pools/FactoryRouter.sol#L391-L407).
2023-06-13 18:29:52 +02:00
<details>
<summary>Update Ocean Community Fees</summary>
The Ocean Protocol Foundation can [change](https://github.com/oceanprotocol/contracts/blob/main/contracts/pools/FactoryRouter.sol#L391-L407) the Ocean community fees.
```solidity
/**
* @dev updateOPCFee
* Updates OP Community Fees
* @param _newSwapOceanFee Amount charged for swapping with ocean approved tokens
* @param _newSwapNonOceanFee Amount charged for swapping with non ocean approved tokens
* @param _newConsumeFee Amount charged from consumeFees
* @param _newProviderFee Amount charged for providerFees
*/
function updateOPCFee(uint256 _newSwapOceanFee, uint256 _newSwapNonOceanFee,
uint256 _newConsumeFee, uint256 _newProviderFee) external onlyRouterOwner {
swapOceanFee = _newSwapOceanFee;
swapNonOceanFee = _newSwapNonOceanFee;
consumeFee = _newConsumeFee;
providerFee = _newProviderFee;
emit OPCFeeChanged(msg.sender, _newSwapOceanFee, _newSwapNonOceanFee, _newConsumeFee, _newProviderFee);
}
```
</details>
2023-07-16 09:19:03 +02:00
Each of these fees plays a role in ensuring fair compensation and supporting the Ocean community.
2023-06-13 18:29:52 +02:00
| Fee | Value in Ocean Market | Value in Other Markets |
| ---------------- | :-------------------: | -------------------------------------------------------- |
| Publisher Market | 0 | Customizable in market config. |
| Consume Market | 0 | Customizable in market config. |
| Provider | 0 | Customizable. See details [below](fees.md#provider-fee). |
| Ocean Community | 0.03 DT | 0.03 DT |
2023-06-13 18:29:52 +02:00
### Provider fee
2023-07-16 09:19:03 +02:00
[Providers](../provider/README.md) facilitate data consumption, initiate compute jobs, encrypt and decrypt DDOs, and verify user access to specific data assets or services.
2023-06-13 18:29:52 +02:00
2023-07-16 09:19:03 +02:00
Provider fees serve as [compensation](../community-monetization.md#3.-running-your-own-provider) to the individuals or organizations operating their own provider instances when users request assets.
2023-06-13 18:29:52 +02:00
2023-06-29 17:52:01 +02:00
* Defined by the [Provider](../provider/README.md) for any consumption.
2023-06-13 18:29:52 +02:00
* Expressed in: Address, Token, Amount (absolute), Timeout.
2023-07-16 09:19:03 +02:00
* You can retrieve them when calling the initialize endpoint.
* These fees can be set as a **fixed amount** rather than a percentage.
2023-06-13 18:29:52 +02:00
* Providers have the flexibility to specify the token in which the fees must be paid, which can differ from the token used in the consuming market.
2023-06-29 17:52:01 +02:00
* Provider fees can be utilized to charge for [computing](../compute-to-data/README.md) resources. Consumers can select the desired payment amount based on the compute resources required to execute an algorithm within the [Compute-to-Data](../compute-to-data/README.md) environment, aligning with their specific needs.
2023-06-13 18:29:52 +02:00
* Eg: A provider can charge a fixed fee of 10 USDT per consume, irrespective of the pricing schema used (e.g., fixed rate with ETH, BTC, dispenser).
* Eg: A provider may impose a fixed fee of 15 DAI to reserve compute resources for 1 hour, enabling the initiation of compute jobs.
These fees play a crucial role in incentivizing individuals and organizations to operate provider instances and charge consumers based on their resource usage. By doing so, they contribute to the growth and sustainability of the Ocean Protocol ecosystem.
| Type | OPF Provider | 3rd party Provider |
| ---------------------------------------------------------------------------- | :--------------------: | --------------------------------------------------------------------- |
| Token to charge the fee: `PROVIDER_FEE_TOKEN` | OCEAN | <p>Customizable by the Provider Owner. <br>E.g. <code>USDC</code></p> |
| Download: `COST_PER_MB` | 0 | Customizable in the Provider `envvars`. |
| <p>Compute: <code>COST_PER_MIN</code><br>Environment: 1 CPU, 60 secs max</p> | 0 | Customizable in the OperatorEngine `envvars`. |
| <p>Compute: <code>COST_PER_MIN</code><br>Environment: 1 CPU, 1 hour max</p> | 1.0 OCEAN/min | Customizable in the OperatorEngine `envvars`. |
| Ocean Community | 0% of the Provider fee | 0% of the Provider fee. |
{% hint style="info" %}
Stay up-to-date with the latest information! The values within the system are regularly updated. We recommend verifying the most recent values directly from the [contracts](https://github.com/oceanprotocol/contracts) and the [market](https://github.com/oceanprotocol/market).
{% endhint %}