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

Merge pull request #1244 from oceanprotocol/oceanjs-fixes

Oceanjs fixes
This commit is contained in:
Ana 2023-10-04 10:48:48 +03:00 committed by GitHub
commit 65f9bd4a5c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 136 additions and 117 deletions

View File

@ -26,6 +26,7 @@ The below tabs show partially filled `.env` file content for some of the support
{% tabs %} {% tabs %}
{% tab title="Mainnet" %} {% tab title="Mainnet" %}
{% code title=".env" %} {% code title=".env" %}
```bash ```bash
# Mandatory environment variables # Mandatory environment variables
@ -38,11 +39,13 @@ PRIVATE_KEY=<secret>
AQUARIUS_URL=https://v4.aquarius.oceanprotocol.com/ AQUARIUS_URL=https://v4.aquarius.oceanprotocol.com/
PROVIDER_URL=https://v4.provider.oceanprotocol.com PROVIDER_URL=https://v4.provider.oceanprotocol.com
``` ```
{% endcode %} {% endcode %}
{% endtab %} {% endtab %}
{% tab title="Polygon" %} {% tab title="Polygon" %}
{% code title=".env" %} {% code title=".env" %}
```bash ```bash
# Mandatory environment variables # Mandatory environment variables
@ -55,11 +58,13 @@ PRIVATE_KEY=<secret>
AQUARIUS_URL=https://v4.aquarius.oceanprotocol.com/ AQUARIUS_URL=https://v4.aquarius.oceanprotocol.com/
PROVIDER_URL=https://v4.provider.oceanprotocol.com PROVIDER_URL=https://v4.provider.oceanprotocol.com
``` ```
{% endcode %} {% endcode %}
{% endtab %} {% endtab %}
{% tab title="Local (using Barge)" %} {% tab title="Local (using Barge)" %}
{% code title=".env" %} {% code title=".env" %}
```bash ```bash
# Mandatory environment variables # Mandatory environment variables
OCEAN_NETWORK=development OCEAN_NETWORK=development
@ -70,6 +75,7 @@ PROVIDER_URL=http://172.15.0.4:8030
# Replace PRIVATE_KEY if needed # Replace PRIVATE_KEY if needed
PRIVATE_KEY=0xc594c6e5def4bab63ac29eed19a134c130388f74f019bc74b8f4389df2837a58 PRIVATE_KEY=0xc594c6e5def4bab63ac29eed19a134c130388f74f019bc74b8f4389df2837a58
``` ```
{% endcode %} {% endcode %}
{% endtab %} {% endtab %}
{% endtabs %} {% endtabs %}
@ -87,10 +93,12 @@ Let's install Ocean.js library into your current project by running:
{% tabs %} {% tabs %}
{% tab title="Terminal" %} {% tab title="Terminal" %}
{% code overflow="wrap" %} {% code overflow="wrap" %}
```bash ```bash
npm init npm init
npm i @oceanprotocol/lib@latest dotenv crypto-js ethers@5.7.4 @truffle/hdwallet-provider npm i @oceanprotocol/lib@latest dotenv crypto-js ethers@5.7.4 @truffle/hdwallet-provider
``` ```
{% endcode %} {% endcode %}
{% endtab %} {% endtab %}
{% endtabs %} {% endtabs %}
@ -104,69 +112,66 @@ Create the configuration file in the working directory i.e. at the same path whe
{% tabs %} {% tabs %}
{% tab title="config.js" %} {% tab title="config.js" %}
{% code title="config.js" %} {% code title="config.js" %}
```javascript ```javascript
require('dotenv').config(); require("dotenv").config();
const { Aquarius, ZERO_ADDRESS, ConfigHelper, configHelperNetworks } = require('@oceanprotocol/lib'); const {
const { providers } = require('ethers') Aquarius,
const ethers = require('ethers'); ConfigHelper,
configHelperNetworks,
} = require("@oceanprotocol/lib");
const ethers = require("ethers");
import fs from "fs";
import { homedir } from "os";
async function oceanConfig() { async function oceanConfig() {
const provider = new ethers.providers.JsonRpcProvider(
// Get configuration for the given network
const provider = new providers.JsonRpcProvider(
process.env.OCEAN_NETWORK_URL || configHelperNetworks[1].nodeUri process.env.OCEAN_NETWORK_URL || configHelperNetworks[1].nodeUri
)
const ethersProvider = new ethers.Wallet(
process.env.PRIVATE_KEY,
provider
); );
const publisherAccount = new ethers.Wallet(process.env.PRIVATE_KEY, provider);
const publisherAccount = wallet.connect(provider);
let oceanConfig = new ConfigHelper().getConfig( let oceanConfig = new ConfigHelper().getConfig(
parseInt(String((await publisherAccount.provider.getNetwork()).chainId)) parseInt(String((await publisherAccount.provider.getNetwork()).chainId))
) );
const aquarius = new Aquarius(oceanConfig?.metadataCacheUri) const aquarius = new Aquarius(oceanConfig?.metadataCacheUri);
// If using local development environment, read the addresses from local file. // If using local development environment, read the addresses from local file.
// The local deployment address file can be generated using barge. // The local deployment address file can be generated using barge.
if (process.env.OCEAN_NETWORK === 'development') { if (process.env.OCEAN_NETWORK === "development") {
const addresses = JSON.parse( const addresses = JSON.parse(
// eslint-disable-next-line security/detect-non-literal-fs-filename // eslint-disable-next-line security/detect-non-literal-fs-filename
fs.readFileSync( fs.readFileSync(
process.env.ADDRESS_FILE || process.env.ADDRESS_FILE ||
`${homedir}/.ocean/ocean-contracts/artifacts/address.json`, `${homedir}/.ocean/ocean-contracts/artifacts/address.json`,
'utf8' "utf8"
) )
).development ).development;
oceanConfig = { oceanConfig = {
...oceanConfig, ...oceanConfig,
oceanTokenAddress: addresses.Ocean, oceanTokenAddress: addresses.Ocean,
poolTemplateAddress: addresses.poolTemplate,
fixedRateExchangeAddress: addresses.FixedPrice, fixedRateExchangeAddress: addresses.FixedPrice,
dispenserAddress: addresses.Dispenser, dispenserAddress: addresses.Dispenser,
nftFactoryAddress: addresses.ERC721Factory, nftFactoryAddress: addresses.ERC721Factory,
sideStakingAddress: addresses.Staking, opfCommunityFeeCollector: addresses.OPFCommunityFeeCollector,
opfCommunityFeeCollector: addresses.OPFCommunityFeeCollector
}; };
} }
oceanConfig = { oceanConfig = {
...oceanConfig, ...oceanConfig,
publisherAccount: publisherAccount, publisherAccount: publisherAccount,
consumerAccount: consumerAccount, consumerAccount: publisherAccount,
stakerAccount: stakerAccount, aquarius: aquarius,
aquarius: aquarius
}; };
return oceanConfig return oceanConfig;
}; }
module.exports = { module.exports = {
oceanConfig oceanConfig,
} };
``` ```
{% endcode %} {% endcode %}
{% endtab %} {% endtab %}
{% endtabs %} {% endtabs %}

View File

@ -18,13 +18,13 @@ Later on, when working with the ocean.js library, you can use this order transac
#### Prerequisites #### Prerequisites
* [Obtain an API key](../get-api-keys-for-blockchain-access.md) - [Obtain an API key](../get-api-keys-for-blockchain-access.md)
* [Set up the .env file](configuration.md#create-a-env-file) - [Set up the .env file](configuration.md#create-a-env-file)
* [Install the dependencies](configuration.md#setup-dependencies) - [Install the dependencies](configuration.md#setup-dependencies)
* [Create a configuration file](configuration.md#create-a-configuration-file) - [Create a configuration file](configuration.md#create-a-configuration-file)
{% hint style="info" %} {% hint style="info" %}
The variables **AQUARIUS\_URL** and **PROVIDER\_URL** should be set correctly in `.env` file The variables **AQUARIUS_URL** and **PROVIDER_URL** should be set correctly in `.env` file
{% endhint %} {% endhint %}
#### Create a script to consume an asset #### Create a script to consume an asset
@ -32,41 +32,58 @@ The variables **AQUARIUS\_URL** and **PROVIDER\_URL** should be set correctly in
Create a new file in the same working directory where the configuration file (`config.js`) and `.env` files are present, and copy the code as listed below. Create a new file in the same working directory where the configuration file (`config.js`) and `.env` files are present, and copy the code as listed below.
<pre class="language-javascript" data-overflow="wrap"><code class="lang-javascript">// Note: Make sure .env file and config.js are created and setup correctly <pre class="language-javascript" data-overflow="wrap"><code class="lang-javascript">// Note: Make sure .env file and config.js are created and setup correctly
const { oceanConfig } = require('./config.js'); const { oceanConfig } = require("./config.js");
const { ZERO_ADDRESS, NftFactory, getHash, Nft } = require ('@oceanprotocol/lib'); const {
ZERO_ADDRESS,
NftFactory,
getHash,
ProviderFees,
Datatoken,
ProviderInstance,
Nft,
FixedRateExchange,
approve
} = require("@oceanprotocol/lib");
// replace the did here // replace the did here
const did = "did:op:a419f07306d71f3357f8df74807d5d12bddd6bcd738eb0b461470c64859d6f0f"; const did = "did:op:a419f07306d71f3357f8df74807d5d12bddd6bcd738eb0b461470c64859d6f0f";
// This function takes did as a parameter and updates the data NFT information // This function takes did as a parameter and updates the data NFT information
const consumeAsset = async (did) => { const consumeAsset = async (did) => {
const consumer = await oceanConfig.consumerAccount.getAddress(); const consumer = await oceanConfig.consumerAccount.getAddress();
// Fetch ddo from Aquarius // Fetch ddo from Aquarius
const asset = await await oceanConfig.aquarius.resolve(did); const asset = await await oceanConfig.aquarius.resolve(did);
const nft = new Nft(oceanConfig.consumerAccount); const nft = new Nft(consumer);
await approve( await approve(
consumerAccount, Error,
config, oceanConfig,
await consumerAccount.getAddress(), await consumer.getAddress(),
addresses.Ocean, oceanConfig.Ocean,
freAddress, oceanConfig.fixedRateExchangeAddress,
'1' "1"
) );
const fixedRate = new FixedRateExchange(fixedRateExchangeAddress, consumerAccount) const fixedRate = new FixedRateExchange(
const tx = await fixedRate.buyDatatokens(fixedRateId, '1', '2') oceanConfig.fixedRateExchangeAddress,
consumer
);
<strong> const initializeData = await ProviderInstance.initialize( const txBuyDt = await fixedRate.buyDatatokens(
</strong> resolvedDDO.id, oceanConfig.fixedRateId,
resolvedDDO.services[0].id, "1",
"2"
);
const initializeData = await ProviderInstance.initialize(
asset.id,
asset.services[0].id,
0, 0,
await consumerAccount.getAddress(), await consumer.getAddress(),
providerUrl oceanConfig.providerUri
) );
const providerFees: ProviderFees = { const providerFees: ProviderFees = {
providerFeeAddress: initializeData.providerFee.providerFeeAddress, providerFeeAddress: initializeData.providerFee.providerFeeAddress,
@ -76,32 +93,29 @@ const consumeAsset = async (did) => {
r: initializeData.providerFee.r, r: initializeData.providerFee.r,
s: initializeData.providerFee.s, s: initializeData.providerFee.s,
providerData: initializeData.providerFee.providerData, providerData: initializeData.providerFee.providerData,
validUntil: initializeData.providerFee.validUntil validUntil: initializeData.providerFee.validUntil,
} };
datatoken = new Datatoken(consumerAccount) const datatoken = new Datatoken(consumer);
const tx = await datatoken.startOrder( const tx = await datatoken.startOrder(
freDatatokenAddress, oceanConfig.fixedRateExchangeAddress,
await consumerAccount.getAddress(), await consumer.getAddress(),
0, 0,
providerFees providerFees
) );
const orderTx = await tx.wait() const orderTx = await tx.wait();
const orderStartedTx = getEventFromTx(orderTx, 'OrderStarted') const orderStartedTx = getEventFromTx(orderTx, "OrderStarted");
const downloadURL = await ProviderInstance.getDownloadUrl( const downloadURL = await ProviderInstance.getDownloadUrl(
fixedDDO.id, asset.id,
fixedDDO.services[0].id, asset.services[0].id,
0, 0,
orderStartedTx.transactionHash, orderTx.transactionHash,
providerUrl, oceanConfig.providerUri,
consumerAccount consumer
<strong> ) );
</strong> console.log(`Resolved asset did [${updatedAsset.id}]from aquarius.`);
console.log(`Updated asset state: [${updatedAsset.nft.state}].`);
}; };
// Call setMetadata(...) function defined above // Call setMetadata(...) function defined above