mirror of
https://github.com/oceanprotocol/docs.git
synced 2024-11-26 19:49:26 +01:00
GITBOOK-337: change request with no subject merged in GitBook
This commit is contained in:
parent
074500361e
commit
d4fd85d7b6
@ -1,2 +1,162 @@
|
||||
---
|
||||
description: Technical details about most used ocean.py functions
|
||||
---
|
||||
|
||||
# Technical Details
|
||||
|
||||
At the beginning of most flows, we create an `ocean` object, which is an instance of class [`Ocean`](https://github.com/oceanprotocol/ocean.py/blob/main/ocean\_lib/ocean/ocean.py). It exposes useful information, including the following.
|
||||
|
||||
Ocean class:
|
||||
|
||||
<details>
|
||||
|
||||
<summary><a href="https://github.com/oceanprotocol/ocean.py/blob/main/ocean_lib/ocean/ocean.py#L43"><code>Ocean</code> - The Ocean class is the entry point into Ocean Protocol.</a></summary>
|
||||
|
||||
In order to initialize a Ocean object, you must provide `config_dict` which is a `Dictionary` instance and optionally a `DataServiceProvider` instance.
|
||||
|
||||
[Here ](https://github.com/oceanprotocol/ocean.py/blob/main/ocean\_lib/ocean/ocean.py#LL43C1-L96C53)is the source code.
|
||||
|
||||
{% code overflow="wrap" %}
|
||||
```python
|
||||
class Ocean:
|
||||
"""The Ocean class is the entry point into Ocean Protocol."""
|
||||
|
||||
@enforce_types
|
||||
def __init__(self, config_dict: Dict, data_provider: Optional[Type] = None) -> None:
|
||||
"""Initialize Ocean class.
|
||||
|
||||
Usage: Make a new Ocean instance
|
||||
|
||||
`ocean = Ocean({...})`
|
||||
|
||||
This class provides the main top-level functions in ocean protocol:
|
||||
1. Publish assets metadata and associated services
|
||||
- Each asset is assigned a unique DID and a DID Document (DDO)
|
||||
- The DDO contains the asset's services including the metadata
|
||||
- The DID is registered on-chain with a URL of the metadata store
|
||||
to retrieve the DDO from
|
||||
|
||||
`ddo = ocean.assets.create(metadata, publisher_wallet)`
|
||||
|
||||
2. Discover/Search ddos via the current configured metadata store (Aquarius)
|
||||
|
||||
- Usage:
|
||||
`ddos_list = ocean.assets.search('search text')`
|
||||
|
||||
An instance of Ocean is parameterized by a `Config` instance.
|
||||
|
||||
:param config_dict: variable definitions
|
||||
:param data_provider: `DataServiceProvider` instance
|
||||
"""
|
||||
config_errors = {}
|
||||
for key, value in config_defaults.items():
|
||||
if key not in config_dict:
|
||||
config_errors[key] = "required"
|
||||
continue
|
||||
|
||||
if not isinstance(config_dict[key], type(value)):
|
||||
config_errors[key] = f"must be {type(value).__name__}"
|
||||
|
||||
if config_errors:
|
||||
raise Exception(json.dumps(config_errors))
|
||||
|
||||
self.config_dict = config_dict
|
||||
|
||||
network_name = config_dict["NETWORK_NAME"]
|
||||
check_network(network_name)
|
||||
|
||||
if not data_provider:
|
||||
data_provider = DataServiceProvider
|
||||
|
||||
self.assets = OceanAssets(self.config_dict, data_provider)
|
||||
self.compute = OceanCompute(self.config_dict, data_provider)
|
||||
|
||||
logger.debug("Ocean instance initialized: ")
|
||||
```
|
||||
{% endcode %}
|
||||
|
||||
</details>
|
||||
|
||||
Config dict attribute:
|
||||
|
||||
<details>
|
||||
|
||||
<summary><a href="https://github.com/oceanprotocol/ocean.py/blob/main/ocean_lib/ocean/ocean.py#LL265C1-L268C32"><code>ocean.config_dict</code> or <code>ocean.config -> dict</code></a></summary>
|
||||
|
||||
It is a helper method for retrieving the user's configuration for ocean.py.\
|
||||
It can be called only by Ocean object and returns a python dictionary.
|
||||
|
||||
```python
|
||||
@property
|
||||
@enforce_types
|
||||
def config(self) -> dict: # alias for config_dict
|
||||
return self.config_dict
|
||||
```
|
||||
|
||||
</details>
|
||||
|
||||
OCEAN token:
|
||||
|
||||
<details>
|
||||
|
||||
<summary><a href="https://github.com/oceanprotocol/ocean.py/blob/main/ocean_lib/ocean/ocean.py#LL100C1-L103C52"><code>ocean.OCEAN_address -> str</code></a></summary>
|
||||
|
||||
It is a helper method for retrieving the OCEAN's token address.\
|
||||
It can be called only by Ocean object and returns the address as a `string`.
|
||||
|
||||
```python
|
||||
@property
|
||||
@enforce_types
|
||||
def OCEAN_address(self) -> str:
|
||||
return get_ocean_token_address(self.config)
|
||||
```
|
||||
|
||||
[`get_ocean_token_address`](https://github.com/oceanprotocol/ocean.py/blob/main/ocean\_lib/ocean/util.py#LL31C1-L38C89) function is an utilitary function which gets the address from `address.json` file
|
||||
|
||||
{% code overflow="wrap" %}
|
||||
```python
|
||||
@enforce_types
|
||||
def get_ocean_token_address(config_dict: dict) -> str:
|
||||
"""Returns the Ocean token address for given network or web3 instance
|
||||
Requires either network name or web3 instance.
|
||||
"""
|
||||
addresses = get_contracts_addresses(config_dict)
|
||||
|
||||
return Web3.toChecksumAddress(addresses.get("Ocean").lower()) if addresses else None
|
||||
```
|
||||
{% endcode %}
|
||||
|
||||
</details>
|
||||
|
||||
<details>
|
||||
|
||||
<summary><a href="https://github.com/oceanprotocol/ocean.py/blob/main/ocean_lib/ocean/ocean.py#LL105C1-L113C32"><code>ocean.OCEAN_token</code> or <code>ocean.OCEAN -> Datatoken</code></a></summary>
|
||||
|
||||
It is a helper method for retrieving the OCEAN token object (Datatoken class).\
|
||||
It can be called within Ocean class and returns the OCEAN Datatoken.
|
||||
|
||||
```python
|
||||
@property
|
||||
@enforce_types
|
||||
def OCEAN_token(self) -> DatatokenBase:
|
||||
return DatatokenBase.get_typed(self.config, self.OCEAN_address)
|
||||
|
||||
@property
|
||||
@enforce_types
|
||||
def OCEAN(self): # alias for OCEAN_token
|
||||
return self.OCEAN_token
|
||||
```
|
||||
|
||||
</details>
|
||||
|
||||
Ocean smart contracts:
|
||||
|
||||
* `ocean.data_nft_factory -> DataNFTFactoryContract`
|
||||
* `ocean.dispenser -> Dispenser` - faucets for free data
|
||||
* `ocean.fixed_rate_exchange -> FixedRateExchange` - exchanges for priced data
|
||||
|
||||
Simple getters:
|
||||
|
||||
* `ocean.get_nft_token(self, token_address: str) -> DataNFT`
|
||||
* `ocean.get_datatoken(self, token_address: str) -> Datatoken`
|
||||
* `ocean.get_user_orders(self, address: str, datatoken: str)`
|
||||
|
Loading…
Reference in New Issue
Block a user