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

Merge branch 'master' into fix/market-url

This commit is contained in:
Matthias Kretschmann 2020-11-12 19:14:42 +01:00
commit 12bada2679
Signed by: m
GPG Key ID: 606EEEF3C479A91F
18 changed files with 1326 additions and 3472 deletions

View File

@ -35,30 +35,6 @@ module.exports = {
{ {
from: '/tutorials/wallets/', from: '/tutorials/wallets/',
to: '/concepts/wallets/' to: '/concepts/wallets/'
},
{
from: '/references/ocean.js/',
to: 'https://github.com/oceanprotocol/ocean.js'
},
{
from: '/references/react/',
to: 'https://github.com/oceanprotocol/react'
},
{
from: '/references/ocean.py/',
to: 'https://github.com/oceanprotocol/ocean.py'
},
{
from: '/references/ocean-contracts/',
to: 'https://github.com/oceanprotocol/ocean-contracts'
},
{
from: '/references/aquarius/',
to: 'https://github.com/oceanprotocol/aquarius'
},
{
from: '/references/provider-py/',
to: 'https://github.com/oceanprotocol/provider-py'
} }
] ]
} }

View File

@ -1,26 +0,0 @@
---
title: Example Code Using Squid
description: Examples of code using the Squid libraries.
---
## squid-py Examples
- [The squid-py tutorials in Jupyter notebooks](/tutorials/jupyter-notebooks/)
- [The squid_py/examples/ directory of the squid-py repository](https://github.com/oceanprotocol/squid-py/tree/develop/examples)
- [The squid-py tests](https://github.com/oceanprotocol/squid-py/tree/develop/tests)
- [ocean-cli-py](https://github.com/bigchaindb-gmbh/ocean-cli-py) is an Ocean Protocol command-line interface built using squid-py
## squid-js Examples
- [The React App Tutorial](/tutorials/react-setup/)
- [The Commons Marketplace source code](https://github.com/oceanprotocol/commons)
- [The Pleuston source code](https://github.com/oceanprotocol/pleuston)
- The squid-js tests:
- [Unit tests](https://github.com/oceanprotocol/squid-js/tree/develop/test)
- [Integration tests](https://github.com/oceanprotocol/squid-js/tree/develop/integration/ocean)
## squid-java Examples
- [The squid-java README.md file](https://github.com/oceanprotocol/squid-java/blob/develop/README.md)
- [The squid-java tests](https://github.com/oceanprotocol/squid-java/tree/develop/src/test)
- [ocean-cli](https://github.com/bigchaindb-gmbh/ocean-cli) is an Ocean Protocol command-line interface built using squid-java

View File

@ -3,11 +3,12 @@ title: Overview of Tutorials
description: description:
--- ---
These tutorials cover: These tutorials go beyond the Quickstarts to cover:
- Using Web3 wallets with Ocean - Using Web3 wallets with Ocean
- Getting ETH and OCEAN on Ethereum mainnet, and Rinkeby testnet - Getting ETH and OCEAN on Ethereum mainnet, and Rinkeby testnet
- Set up a marketplace
- Run a compute-to-data environment
- Storage setup - Azure, AWS or local - Storage setup - Azure, AWS or local
- Building a React app with Ocean. This is a great way to understand Ocean end-to-end.

View File

@ -14,9 +14,10 @@ In Ocean, marketplaces and publishers are different roles. A common setup is for
## Develop a First Cut of the App ## Develop a First Cut of the App
Here are some approaches: Here are some approaches:
-Fork [Ocean Market](/references/market/) code
-Do the [React App Tutorial](/tutorials/react-setup/) then grow your app from there. It uses [Ocean React hooks](/references/react/). - Fork [Ocean Market](/references/market/) code
-Build up from [ocean.js](/references/ocean.js/) or [ocean.py](/references/ocean.py/) drivers - Build from [Ocean React hooks](/references/react/).
- Build up from [ocean.js](/references/ocean.js/) or [ocean.py](/references/ocean.py/) drivers
## Prepare Some Initial Data Assets ## Prepare Some Initial Data Assets

View File

@ -1,48 +0,0 @@
---
title: Compute using a published algorithm on a Data Set
description: Compute using a published algorithm on a Data Set
---
## Requirements
This is a continuation of the [React App Setup](/tutorials/react-setup/) tutorial, so make sure you have done all the steps described in there.
1. [React App Setup](/tutorials/react-setup/)
Open `src/Compute.js` from your `marketplace/` folder.
## Define Compute Output
First, let's define some options for our upcoming job:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 163-182 GITHUB-EMBED
and use them
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 61-70 GITHUB-EMBED
## Order the dataset
Next, we have to order the dataset that we are going to compute upon. We are going to use the ddoAssetId, which was set during publishing of the asset.
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 73 GITHUB-EMBED
## Start the compute job
And finally, start the job:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 76-82 GITHUB-EMBED
## Final Result
Now that we have all the requirements, we need a function to handle it.
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 58-89,92-94 GITHUB-EMBED
The last thing we need is a button to start our compute job:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 202-207 GITHUB-EMBED
\*\* Notice that the button will be disabled if there were no previous published Datasets and Algorithms.
**Move on to [Get Status of a Compute Job](react-compute-status).**

View File

@ -1,64 +0,0 @@
---
title: Compute using a raw algorithm on a Data Set
description: Compute using a raw algorithm on a Data Set
---
## Requirements
This is a continuation of the [React App Setup](/tutorials/react-setup/) tutorial, so make sure you have done all the steps described in there.
1. [React App Setup](/tutorials/react-setup/)
Open `src/Compute.js` from your `marketplace/` folder.
## Define Raw Code
Sometime, you just need to quickly run an test algorithm. Instead of publishing it as an asset, you can use the code directly.
To do that, we are going to use a textbox for copy/paste and a button to show/hide it.
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 184-195 GITHUB-EMBED
## Define Algorithm MetaData
We need to define all the requirments for the algorithm:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/asset-compute.js jsx 35-44 GITHUB-EMBED
and them import it to our Compute.js:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 4 GITHUB-EMBED
## Define Compute Output
Let's define some options for our upcoming job:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 163-182 GITHUB-EMBED
and use them
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 61-70 GITHUB-EMBED
## Order the dataset
Next, we have to order the dataset that we are going to compute upon. We are going to use the ddoAssetId, which was set during publishing of the asset.
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 73 GITHUB-EMBED
## Start the compute job
We need a function to start the job:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 58-89 GITHUB-EMBED
Get the pasted code:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 96-100 GITHUB-EMBED
The last thing we need is a button inside the `render()` function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 208-211 GITHUB-EMBED
\*\* Notice that the button will be disabled if there were no previous published Datasets.
**Move on to [Get Status of a Compute Job](react-compute-status).**

View File

@ -1,32 +0,0 @@
---
title: Get Status of a Compute Job
description: Get Status of a Compute Job
---
## Requirements
For this setup, we need a compute job that has been started from [Compute using a published algorithm on a Data Set](/tutorials/react-compute-published-algorithm/) or [Compute using a raw algorithm on a Data Set](/tutorials/react-compute-raw/)
## Create an Area to display the status
First, let's define an area to display status:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 213-226 GITHUB-EMBED
## Get Job Status
Since we have the agreementId and jobId, we can get status from a compute job:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 106 GITHUB-EMBED
## Final Result
Let's wrap that into a function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 102-112 GITHUB-EMBED
and have a button for it:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 223 GITHUB-EMBED
\*\* Notice that the button will be disabled if jobId is missing.

View File

@ -1,65 +0,0 @@
---
title: Search & Consume a Data Set
description: Tutorial to get and use a data set in a basic React app.
---
## Requirements
This is a continuation of the React App Tutorial. Make sure you already did the previous steps:
1. [React App Setup](/tutorials/react-setup/)
2. [Publish a Data Set](/tutorials/react-publish-data-set/)
Open `src/index.js` from your `marketplace/` folder.
## Search Assets
In the previous tutorial we added asset publishing. We can now search for published assets for consumption.
We will store the search results in the local component state so we have to set its initial state first:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 15-19 GITHUB-EMBED
Just after the `registerAsset()` function we add a new `searchAssets` function that will handle search:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/2765a7e6ae9a948d311d3949636cf832d2664900/src/index.js jsx 54-67 GITHUB-EMBED
Now we need a button to start our search inside the `render()` function, just after the _Register asset_ button:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/2765a7e6ae9a948d311d3949636cf832d2664900/src/index.js jsx 115 GITHUB-EMBED
## Consume Asset
Consuming means downloading one or multiple files attached to an asset. During that process the initial `url` value we added during the publish process for each file will be decrpyted and the file can be downloaded.
With the following code we start the consume process with the first search result, then go on to download its first attached file. Put it after the `searchAssets()` function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/index.js jsx 73-95 GITHUB-EMBED
We still need a button to start consumption. In the render function, just after the _Search assets_ button, add:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/2765a7e6ae9a948d311d3949636cf832d2664900/src/index.js jsx 116-118 GITHUB-EMBED
With all these buttons in place, you should see this:
![React app with all actions in place](images/react-app-06.png)
Go ahead and click the _Search assets_ button, and then the _Consume asset_ button. Approve all the MetaMask dialog boxes.
Have a look into `console.log` to see the various steps of the search and consume process. If you have no errors in your `console.log` and can see your asset files listed, you have a working marketplace.
## Final Result
Here is the full source of `src/index.js` that you should have if you followed this tutorial:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/master/src/index.js jsx GITHUB-EMBED
## Git repository and CodeSandbox
All code snippets in this tutorial are sourced from the [oceanprotocol/react-tutorial](https://github.com/oceanprotocol/react-tutorial) GitHub repository:
<repo name="react-tutorial"></repo>
The final source of this tutorial is also available as a CodeSandbox:
[![Edit react-tutorial](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/github/oceanprotocol/react-tutorial/tree/master/?fontsize=14)

View File

@ -1,40 +0,0 @@
---
title: Publish a Algorithm
description: Tutorial to add Algorithm dataset publishing capabilities to a basic React app.
---
## Requirements
This is a continuation of the [React App Setup](/tutorials/react-setup/) tutorial, so make sure you have done all the steps described in there.
1. [React App Setup](/tutorials/react-setup/)
Open `src/Compute.js` from your `marketplace/` folder.
## Define Asset
First, let's add the data asset that we want to publish.
To do that, we need to define the Algorithm asset based on the [OEP-08](https://github.com/oceanprotocol/OEPs/tree/master/8) metadata structure. An algorithm asset can have multiple `files` attached to it and each file's `url` value will be encrypted during the publish process.
Let's create a new file `src/asset-compute.js` and fill it with:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/asset-compute.js jsx 1-33 GITHUB-EMBED
\*\* Notice the “ALGO” macro in the entrypoint attribute, this is replaced with the downloaded executable algorithm inside the pod
Then import this asset definition at the top of `src/Compute.js`:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 4 GITHUB-EMBED
## Handle Asset Publishing
Now that we have an asset to submit, we need a function to handle it. Just before `render() {` let's add this `publishalgo` function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 42-56 GITHUB-EMBED
The last thing we need is a button to start our registration inside the `render()` function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 153 GITHUB-EMBED
**Move on to [Compute using a published algorithm on a Data Set](/tutorials/react-compute-published-algorithm/).**

View File

@ -1,32 +0,0 @@
---
title: Publish a Data Set with Compute features
description: Tutorial to add a dataset with compute capabilities to a basic React app.
---
## Requirements
This is a continuation of the [React App Setup](/tutorials/react-setup/) tutorial, so make sure you have done all the steps described in there.
1. [React App Setup](/tutorials/react-setup/)
Open `src/Compute.js` from your `marketplace/` folder.
## Define Asset
We will use the same asset as in [Publish a Data Set](/tutorials/react-publish-data-set), but we are going to allow only compute features, without the ability to download the asset.
This is achiveable by adding a 'compute' service to the DDO:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 23-27 GITHUB-EMBED
## Handle Asset Publishing
Note that ocean.assets.create will define an 'access' service if the services list is missing. Since we are providing this attribute, our asset will have only a 'compute' service and no 'access' service.
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 18-40 GITHUB-EMBED
The last thing we need is a button to start our registration inside the `render()` function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/107d1fa7d0c583cc8042339f1f5090ff9ee0920b/src/Compute.js jsx 143 GITHUB-EMBED
**Move on to [Publish a Algorithm](/tutorials/react-publish-algorithm/).**

View File

@ -1,56 +0,0 @@
---
title: Publish a Data Set
description: Tutorial to add dataset publishing capabilities to a basic React app.
---
## Requirements
This is a continuation of the [React App Setup](/tutorials/react-setup/) tutorial, so make sure you have done all the steps described in there.
1. [React App Setup](/tutorials/react-setup/)
Open `src/index.js` from your `marketplace/` folder.
## Define Asset
First, let's add the asset that we want to publish.
To do that, we need to define the asset based on the [OEP-08](https://github.com/oceanprotocol/OEPs/tree/master/8) metadata structure. An asset can have multiple `files` attached to it and each file's `url` value will be encrypted during the publish process. To download that file later on, this value will be decrypted during the consume process.
Let's create a new file `src/asset.js` and fill it with:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/asset.js js GITHUB-EMBED
Then import this asset definition at the top of `src/index.js`:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 5 GITHUB-EMBED
## Handle Asset Publishing
Now that we have an asset to submit, we need a function to handle it. Just before `render() {` let's add this `registerAsset` function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 15,16,18-20,41-55 GITHUB-EMBED
The last thing we need is a button to start our registration inside the `render()` function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 114-116 GITHUB-EMBED
Note how we disable the button when Web3 is not available to reduce user confusion. Within the Ocean Protocol flow of registering, searching, and consuming, only searching is possible without Web3.
In your browser, you should now end up like this:
![React app with publish button](images/react-app-04.png)
When you click on the _Register asset_ button, you should get four separate dialog boxes from MetaMask, in a series, i.e. the second one only appears after you accept/approve the first one, and so on.
Have a look into `console.log` to see the various steps of the register process. If you have no errors in your `console.log`, then you have successfully registered an asset.
![Successful asset publishing](images/react-app-05.png)
## Final Result
Here is the full source of `src/index.js` that you should have if you followed this tutorial:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 1-5,6-16,18-28,35-52,96-116,122-127 GITHUB-EMBED
**Move on to [Get & Use a Data Set](/tutorials/react-get-use-data-set/).**

View File

@ -1,178 +0,0 @@
---
title: React App Setup
description: This tutorial shows how you can build a basic [React](https://reactjs.org/) app with [Create React App](https://github.com/facebook/create-react-app) that uses the Ocean [JavaScript driver](https://github.com/oceanprotocol/ocean.js) to publish a data set, get a data set, and more. *WARNING this has not been updated yet for Ocean V3.*
---
## Git repository and CodeSandbox
All code snippets in this tutorial are sourced from the [oceanprotocol/react-tutorial](https://github.com/oceanprotocol/react-tutorial) GitHub repository:
<repo name="react-tutorial"></repo>
The final source of this tutorial is also available as a CodeSandbox:
[![Edit react-tutorial](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/github/oceanprotocol/react-tutorial/tree/master/?fontsize=14)
## Requirements
- `Node.js` >= 10 is installed. You can check using `node -v`
- `npm` >= 5.2 is installed. You can check using `npm -v`
- A Web3 capable browser, like Firefox/Chrome with [MetaMask](https://metamask.io) installed, [connected to Rinkeby testnet](https://docs.oceanprotocol.com/tutorials/connect-to-networks/)
- Some ETH from the Rinkeby Faucet. [Here](tutorials/get-ether-and-ocean-tokens/) are instructions.
## New Create React App
We are going to use Create React App to bootstrap our React app. You could use `npx create-react-app marketplace` but it creates more files than needed for the scope of this tutorial.
So let's go minimal and build up our app from scratch with this structure:
```text
marketplace/
├── package.json
├── public/
├──── index.html
├── src/
├──── index.js
```
First, create a new project folder for your new app, e.g. `marketplace`. Within that, add a new file `package.json` with the following content:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/master/package.json json GITHUB-EMBED
Notice the `@oceanprotocol/ocean.js` dependency, which is the [Ocean Protocol JavaScript library](https://github.com/oceanprotocol/ocean.js). Save that file, and in your terminal install the dependencies we have just defined in `package.json`:
```bash
npm install
```
Then create the HTML file used to render the React app into. For that, create a folder `public/` and in it a file `index.html` with the following content:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/master/public/index.html html GITHUB-EMBED
## Add Basic Markup
Create a new folder `src/` and within that a `index.js` file with the following content as our base, where we already import ocean.js and web3.js:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 1-4,6,14,100-110,122-127 GITHUB-EMBED
At this point you can start up the app and see the result in your browser:
```bash
npm start
```
Go to [localhost:3000](http://localhost:3000) to inspect your newly created app:
![Initial React App](images/react-app-01.png)
## Setup Web3
We already are importing web3.js but we still need to enable account access for the browsers supporting it, and make sure nothing breaks in browsers which are not Web3-capable.
To do that we add a simple check at top of `src/index.js` and then enable account access with:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 7-12 GITHUB-EMBED
And let's also output some warning for non-Web3 browsers within our `render()` function:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 112 GITHUB-EMBED
This should give you the following markup:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 1-4,6-14,100-112,122-127 GITHUB-EMBED
After those steps go to your browser. You should see MetaMask asking you to allow access to your account:
![MetaMask confirmation](images/react-app-02.png)
> Note: If you see an error like `inpage.js:1 MetaMask - RPC Error: Internal JSON-RPC error.` in your browser console, don't worry about it. It's a MetaMask thing and won't affect functionality.
## Create Ocean Instance
Now that we are successfully connected with Web3, we can set up our Ocean instance.
At the beginning of your component, create a new Ocean instance with all required endpoint configurations within the `componentDidMount` lifecycle method. All Ocean Protocol operations can be executed from this Ocean instance.
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/e639e9ed4432e8b72ca453d50ed7bdaa36f1efb4/src/index.js jsx 15-16,19-28,35-39 GITHUB-EMBED
This will initiate a connection to all Ocean components in Rinkeby, load the contracts, and finally store the Ocean object in the local component state for reuse.
We also set the `verbose` option of ocean.js so we better see what's going on.
## Final Result
That's it, if you have no errors in your `console.log` then you have successfully initialized an Ocean instance in your brand new React app and you are ready for the [next part of this tutorial](/tutorials/react-publish-data-set/).
![Initial React App with Ocean initiated](images/react-app-03.png)
Here is the full source of `src/index.js` that you should have if you followed this tutorial:
GITHUB-EMBED https://github.com/oceanprotocol/react-tutorial/blob/2765a7e6ae9a948d311d3949636cf832d2664900/src/index.js jsx 1-4,6-16,18-27,34-38,96-109,119-124 GITHUB-EMBED
**Move on to [Publish a Data Set](/tutorials/react-publish-data-set/).**
## Bonus: Connect against local network
Instead of remotely connecting to Rinkeby, you can connect to your own [local network](concepts/network-local). It uses Ethereum Ganache plus Ocean Barge.
```bash
git clone https://github.com/oceanprotocol/barge.git
cd barge/
./start_ocean.sh --no-commons
```
Compiling and deploying the contracts in your local network may take a few minutes.
### Copy Contract Artifacts
At the end of the contract compiling and deploying you need to copy the resulting contract artifacts from the Docker container to your local `@oceanprotocol/keeper-contracts` dependency folder. The _keeper-contracts_ Docker container will output all artifacts in a hidden folder in your home folder so you can copy from there:
```bash
cp ~/.ocean/keeper-contracts/artifacts/* ./node_modules/@oceanprotocol/keeper-contracts/artifacts/
```
### Get ETH for the local network
You will also need some ETH for your local network. [This tutorial](/tutorials/get-ETH-and-OCEAN-tokens) describes how to get it into your MetaMask account.
You can execute this, replacing `<YOUR ADDRESS>` with your MetaMask account address:
```bash
curl --data '{"address": "<YOUR ADDRESS>", "agent": "curl"}' -H "Content-Type: application/json" -X POST http://localhost:3001/faucet
```
### Adjust App Config
Finally, move back to your marketplace React app and modify the Ocean instance config in `src/index.js` to use the local network's endpoints:
```jsx
const ocean = await new Ocean.getInstance({
web3Provider: web3,
nodeUri: 'http://localhost:8545',
aquariusUri: 'http://aquarius:5000',
brizoUri: 'http://localhost:8030',
brizoAddress: '0x00bd138abd70e2f00903268f3db08f2d25677c9e',
secretStoreUri: 'http://localhost:12001',
verbose: true
})
```
> If you are on macOS, you need to additionally tweak your `/etc/hosts` file so Brizo can connect to Aquarius within Docker. This is only required on macOS and is a [known limitation of Docker for Mac](https://docs.docker.com/docker-for-mac/networking/#known-limitations-use-cases-and-workarounds):
>
> ```bash
> sudo vi /etc/hosts
>
> # add this line, and save
> 127.0.0.1 aquarius
> ```
>
> And then use `aquariusUri: 'http://aquarius:5000'` in your Ocean instance config.
Then start up the app as usual:
```bash
npm start
```
**Move on to [Publish a Data Set](/tutorials/react-publish-data-set/).**

View File

@ -1,6 +1,9 @@
- group: Drivers - group: Drivers
items: items:
- name: ocean.js - name: ocean.js
links:
- name: Reference
url: /references/ocean.js/
- name: ocean.py - name: ocean.py
- name: react - name: react

View File

@ -6,7 +6,12 @@
- group: ocean.js - group: ocean.js
items: items:
- title: API Reference - title: API Reference
link: https://github.com/oceanprotocol/ocean.js link: /references/ocean.js
- group: aquarius
items:
- title: API Reference
link: /references/aquarius/
- group: react - group: react
items: items:
@ -23,12 +28,7 @@
- title: API Reference - title: API Reference
link: https://github.com/oceanprotocol/ocean-contracts link: https://github.com/oceanprotocol/ocean-contracts
- group: aquarius
items:
- title: API Reference
link: /references/aquarius/
- group: provider-py - group: provider-py
items: items:
- title: API Reference - title: API Reference
link: /references/provider-py/ link: https://github.com/oceanprotocol/provider-py

View File

@ -19,25 +19,6 @@
- title: Set Up a Marketplace - title: Set Up a Marketplace
link: /tutorials/marketplace/ link: /tutorials/marketplace/
- group: React App Tutorial
items:
- title: Setup
link: /tutorials/react-setup/
- title: Publish a Data Set
link: /tutorials/react-publish-data-set/
- title: Search & Consume a Data Set
link: /tutorials/react-get-use-data-set/
- title: Publish a Data Set with Compute features
link: /tutorials/react-publish-data-set-compute/
- title: Publish a Algorithm
link: /tutorials/react-publish-algorithm/
- title: Compute using a published algorithm on a Data Set
link: /tutorials/react-compute-published-algorithm/
- title: Compute using a raw algorithm on a Data Set
link: /tutorials/react-compute-raw/
- title: Get Status of a Compute Job
link: /tutorials/react-compute-status/
- group: Compute-to-Data - group: Compute-to-Data
items: items:
- title: Run a Compute-to-Data Environment - title: Run a Compute-to-Data Environment

View File

@ -77,8 +77,8 @@ exports.createPages = ({ graphql, actions }) => {
} }
} }
squidJs: github { oceanJs: github {
repository(name: "squid-js", owner: "oceanprotocol") { repository(name: "ocean.js", owner: "oceanprotocol") {
name name
releases( releases(
first: 30 first: 30
@ -88,7 +88,7 @@ exports.createPages = ({ graphql, actions }) => {
node { node {
isPrerelease isPrerelease
isDraft isDraft
releaseAssets(first: 1, name: "squid-js.json") { releaseAssets(first: 1, name: "lib.json") {
edges { edges {
node { node {
name name
@ -155,13 +155,14 @@ exports.createPages = ({ graphql, actions }) => {
// API: brizo, aquarius // API: brizo, aquarius
await createSwaggerPages(createPage) await createSwaggerPages(createPage)
// API: squid-js // API: ocean.js
const lastRelease = result.data.squidJs.repository.releases.edges.filter( const lastRelease = result.data.oceanJs.repository.releases.edges.filter(
({ node }) => !node.isPrerelease && !node.isDraft ({ node }) => !node.isPrerelease && !node.isDraft
)[0].node.releaseAssets.edges[0].node )[0].node.releaseAssets.edges[0].node
await createTypeDocPage( await createTypeDocPage(
createPage, createPage,
result.data.squidJs.repository.name, result.data.oceanJs.repository.name,
lastRelease.downloadUrl lastRelease.downloadUrl
) )
@ -214,9 +215,6 @@ const createTypeDocPage = async (createPage, name, downloadUrl) => {
'ddo/DDO', 'ddo/DDO',
'ddo/Service', 'ddo/Service',
'aquarius/Aquarius', 'aquarius/Aquarius',
'keeper/ContractHandler',
'keeper/EventHandler',
'keeper/Web3Provider',
'models/Config', 'models/Config',
'models/Balance', 'models/Balance',
'ocean/utils/OceanUtils', 'ocean/utils/OceanUtils',
@ -234,10 +232,10 @@ const createTypeDocPage = async (createPage, name, downloadUrl) => {
// Create pages from swagger json files // Create pages from swagger json files
// //
// https://github.com/swagger-api/swagger-js // https://github.com/swagger-api/swagger-js
const fetchSwaggerSpec = async (name) => { const fetchSwaggerSpec = async () => {
try { try {
const client = await Swagger( const client = await Swagger(
`https://${name}.commons.oceanprotocol.com/spec` `https://aquarius.mainnet.oceanprotocol.com/spec`
) )
return client.spec // The resolved spec return client.spec // The resolved spec
@ -255,7 +253,7 @@ const fetchSwaggerSpec = async (name) => {
} }
const createSwaggerPages = async (createPage) => { const createSwaggerPages = async (createPage) => {
const swaggerComponents = ['aquarius', 'brizo'] const swaggerComponents = ['aquarius']
const apiSwaggerTemplate = path.resolve('./src/templates/Swagger/index.jsx') const apiSwaggerTemplate = path.resolve('./src/templates/Swagger/index.jsx')
const getSlug = (name) => { const getSlug = (name) => {
@ -276,19 +274,6 @@ const createSwaggerPages = async (createPage) => {
} }
}) })
const specBrizo = await fetchSwaggerSpec(swaggerComponents[1])
const slugBrizo = getSlug(swaggerComponents[1])
createPage({
path: slugBrizo,
component: apiSwaggerTemplate,
context: {
slug: slugBrizo,
name: swaggerComponents[1],
api: specBrizo
}
})
// Swagger Pet Store example // Swagger Pet Store example
const petStoreSlug = '/references/petstore/' const petStoreSlug = '/references/petstore/'

4090
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -18,40 +18,40 @@
}, },
"dependencies": { "dependencies": {
"@oceanprotocol/art": "^3.0.0", "@oceanprotocol/art": "^3.0.0",
"axios": "^0.20.0", "axios": "^0.21.0",
"classnames": "^2.2.6", "classnames": "^2.2.6",
"gatsby": "^2.24.85", "gatsby": "^2.26.0",
"gatsby-image": "^2.4.21", "gatsby-image": "^2.5.0",
"gatsby-plugin-catch-links": "^2.3.15", "gatsby-plugin-catch-links": "^2.4.0",
"gatsby-plugin-google-analytics": "^2.3.19", "gatsby-plugin-google-analytics": "^2.5.0",
"gatsby-plugin-manifest": "^2.4.35", "gatsby-plugin-manifest": "^2.6.0",
"gatsby-plugin-offline": "^3.2.37", "gatsby-plugin-offline": "^3.4.0",
"gatsby-plugin-react-helmet": "^3.3.14", "gatsby-plugin-react-helmet": "^3.4.0",
"gatsby-plugin-sass": "^2.3.21", "gatsby-plugin-sass": "^2.5.0",
"gatsby-plugin-sharp": "^2.6.43", "gatsby-plugin-sharp": "^2.8.0",
"gatsby-plugin-sitemap": "^2.4.17", "gatsby-plugin-sitemap": "^2.6.0",
"gatsby-plugin-svgr": "^2.0.2", "gatsby-plugin-svgr": "^2.0.2",
"gatsby-plugin-webpack-size": "^1.0.0", "gatsby-plugin-webpack-size": "^1.0.0",
"gatsby-remark-autolink-headers": "^2.3.15", "gatsby-remark-autolink-headers": "^2.5.0",
"gatsby-remark-code-titles": "^1.1.0", "gatsby-remark-code-titles": "^1.1.0",
"gatsby-remark-component": "^1.1.3", "gatsby-remark-component": "^1.1.3",
"gatsby-remark-copy-linked-files": "^2.3.19", "gatsby-remark-copy-linked-files": "^2.4.0",
"gatsby-remark-embed-video": "^3.0.10", "gatsby-remark-embed-video": "^3.0.10",
"gatsby-remark-github": "^2.0.0", "gatsby-remark-github": "^2.0.0",
"gatsby-remark-images": "^3.3.37", "gatsby-remark-images": "^3.5.0",
"gatsby-remark-responsive-iframe": "^2.4.17", "gatsby-remark-responsive-iframe": "^2.5.0",
"gatsby-remark-smartypants": "^2.3.13", "gatsby-remark-smartypants": "^2.4.0",
"gatsby-remark-vscode": "^3.1.0", "gatsby-remark-vscode": "^3.2.0",
"gatsby-source-filesystem": "^2.3.35", "gatsby-source-filesystem": "^2.5.0",
"gatsby-source-graphql": "^2.7.6", "gatsby-source-graphql": "^2.8.0",
"gatsby-transformer-remark": "^2.8.46", "gatsby-transformer-remark": "^2.10.0",
"gatsby-transformer-sharp": "^2.5.19", "gatsby-transformer-sharp": "^2.6.0",
"gatsby-transformer-xml": "^2.3.15", "gatsby-transformer-xml": "^2.4.0",
"gatsby-transformer-yaml": "^2.4.15", "gatsby-transformer-yaml": "^2.5.0",
"giphy-js-sdk-core": "^1.0.6", "giphy-js-sdk-core": "^1.0.6",
"intersection-observer": "^0.11.0", "intersection-observer": "^0.11.0",
"react": "^16.14.0", "react": "^17.0.1",
"react-dom": "^16.14.0", "react-dom": "^17.0.1",
"react-helmet": "^6.1.0", "react-helmet": "^6.1.0",
"react-scrollspy": "^3.4.3", "react-scrollspy": "^3.4.3",
"rehype-react": "^6.1.0", "rehype-react": "^6.1.0",
@ -59,16 +59,16 @@
"remark-github-plugin": "^1.4.0", "remark-github-plugin": "^1.4.0",
"remark-react": "^8.0.0", "remark-react": "^8.0.0",
"shortid": "^2.2.16", "shortid": "^2.2.16",
"slugify": "^1.4.5", "slugify": "^1.4.6",
"smoothscroll-polyfill": "^0.4.4", "smoothscroll-polyfill": "^0.4.4",
"swagger-client": "^3.11.1" "swagger-client": "^3.12.0"
}, },
"devDependencies": { "devDependencies": {
"@svgr/webpack": "^5.4.0", "@svgr/webpack": "^5.4.0",
"dotenv": "^8.2.0", "dotenv": "^8.2.0",
"eslint": "^7.11.0", "eslint": "^7.13.0",
"eslint-config-oceanprotocol": "^1.5.0", "eslint-config-oceanprotocol": "^1.5.0",
"eslint-config-prettier": "^6.13.0", "eslint-config-prettier": "^6.15.0",
"eslint-plugin-prettier": "^3.1.4", "eslint-plugin-prettier": "^3.1.4",
"markdownlint-cli": "^0.24.0", "markdownlint-cli": "^0.24.0",
"node-sass": "^4.14.1", "node-sass": "^4.14.1",