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

more examples

This commit is contained in:
Matthias Kretschmann 2021-11-04 13:29:30 +01:00
parent ae70ca79ca
commit 3f80e563a1
Signed by: m
GPG Key ID: 606EEEF3C479A91F

View File

@ -5,6 +5,8 @@ slug: /concepts/did-ddo/
section: concepts section: concepts
--- ---
**v4.0.0**
## Overview ## Overview
This document describes how Ocean assets follow the DID/DDO spec, such that Ocean assets can inherit DID/DDO benefits and enhance interoperability. This document describes how Ocean assets follow the DID/DDO spec, such that Ocean assets can inherit DID/DDO benefits and enhance interoperability.
@ -40,6 +42,8 @@ The DDO is stored on-chain as part of the NFT contract and it is stored encrypte
Here is the complete flow: Here is the complete flow:
![DDO_flow](images/DDO_flow.png)
```text ```text
title DDO flow title DDO flow
@ -58,8 +62,6 @@ Aquarius -> Aquarius : cache DDO
Aquarius -> Aquarius : enhance cached DDO in response with additional infos like `events` & `stats` Aquarius -> Aquarius : enhance cached DDO in response with additional infos like `events` & `stats`
``` ```
![DDO_flow](images/DDO_flow.png)
## DID Structure ## DID Structure
In Ocean, a DID is a string that looks like: In Ocean, a DID is a string that looks like:
@ -78,26 +80,16 @@ It follows [the generic DID scheme](https://w3c-ccg.github.io/did-spec/#the-gene
## DDO Attributes ## DDO Attributes
A DDO has these required attributes: A DDO in Ocean has these required attributes:
| Attribute | Type | Description | | Attribute | Type | Description |
| -------------------- | --------------------------- | ---------------------------------------------------------------------------------------------- | | -------------------- | --------------------------- | ---------------------------------------------------------------------------------------------- |
| **`@context`** | Array of `string` | Contexts used for validation. | | **`@context`** | Array of `string` | Contexts used for validation. |
| **`id`** | `string` | Computed as `sha256(address of ERC721 contract + chainId)`. | | **`id`** | `string` | Computed as `sha256(address of ERC721 contract + chainId)`. |
| **`created`** | `ISO Date Time string` | Contains the date of publishing in ISO Date Time Format, e.g. `2000-10-31T01:30:00`. |
| **`updated`** | `ISO Date Time string` | Contains the the date of last update in ISO Date Time Format, e.g. `2000-10-31T01:30:00`. |
| **`services`** | [Services](#services) | Stores an array of services defining access to the asset. |
| **`files`** | [Files](#files) | Stores information about the asset's files. |
| **`encryptedFiles`** | [Files](#files) | Added after publishing. |
| **`credentials`** | [Credentials](#credentials) | Describes the credentials needed to access a dataset in addition to the `services` definition. |
In Ocean, the DDO at its root has:
| Attribute | Type | Description |
| -------------------- | --------------------------- | ---------------------------------------------------------------------------------------------- |
| **`version`** | `string` | Version information referring to this DDO spec version, like `4.0.0`. | | **`version`** | `string` | Version information referring to this DDO spec version, like `4.0.0`. |
| **`chainId`** | `number` | Stores chainId of the network the DDO was published to. | | **`chainId`** | `number` | Stores chainId of the network the DDO was published to. |
| **`metadata`** | [Metadata](#metadata) | Stores metadata information about the asset. | | **`created`** | `ISO Date Time string` | Contains the date of publishing in ISO Date Time Format, e.g. `2000-10-31T01:30:00`. |
| **`updated`** | `ISO Date Time string` | Contains the the date of last update in ISO Date Time Format, e.g. `2000-10-31T01:30:00`. |
| **`services`** | [Services](#services) | Stores an array of services defining access to the asset. | | **`services`** | [Services](#services) | Stores an array of services defining access to the asset. |
| **`files`** | [Files](#files) | Stores information about the asset's files. | | **`files`** | [Files](#files) | Stores information about the asset's files. |
| **`encryptedFiles`** | [Files](#files) | Added after publishing. | | **`encryptedFiles`** | [Files](#files) | Added after publishing. |
@ -121,17 +113,31 @@ This object holds information describing the actual actual asset.
| **`tags`** | Array of Text | No | Array of keywords or tags used to describe this content. Empty by default. | | **`tags`** | Array of Text | No | Array of keywords or tags used to describe this content. Empty by default. |
| **`additionalInformation`** | Object | No | Stores additional information, this is customizable by publisher | | **`additionalInformation`** | Object | No | Stores additional information, this is customizable by publisher |
### Metadata: Algorithm Example:
An asset of type `algorithm` has the following additional attributes under `algorithm` in metadata object: ```json
{
"metadata": {
"description": "Sample description",
"name": "Sample asset",
"type": "dataset",
"author": "OPF",
"license": "https://market.oceanprotocol.com/terms"
}
}
```
### Algorithm Metadata
An asset of type `algorithm` has the following additional attributes under `algorithm` within the `metadata` object:
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
| --------------- | ------------------ | -------- | ------------------------------------------------------- | | --------------- | ----------- | -------- | ------------------------------------------------------- |
| **`language`** | `string` | no | Language used to implement the software | | **`language`** | `string` | no | Language used to implement the software |
| **`version`** | `string` | no | Version of the software. | | **`version`** | `string` | no | Version of the software. |
| **`container`** | `Container Object` | yes | Object describing the Docker container image. See below | | **`container`** | `container` | yes | Object describing the Docker container image. See below |
The `container` object has the following attributes: The `container` object has the following attributes defining the Docker image the algorithm needs to run:
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
| ---------------- | -------- | -------- | ----------------------------------------------------------------- | | ---------------- | -------- | -------- | ----------------------------------------------------------------- |
@ -145,13 +151,13 @@ The `container` object has the following attributes:
Services define the access to the asset. Services define the access to the asset.
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
| ---------------------- | --------------------- | -------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------- | | ---------------------- | --------------------- | -------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
| **`type`** | Text | **Yes** | Type of service (access, compute, wss, etc | | **`type`** | Text | **Yes** | Type of service (access, compute, wss, etc |
| **`name`** | Text | No | Service friendly name | | **`name`** | Text | No | Service friendly name |
| **`description`** | Text | No | Service description | | **`description`** | Text | No | Service description |
| **`datatokenAddress`** | Text | Yes | Datatoken address | | **`datatokenAddress`** | Text | Yes | Datatoken address |
| **`providerEndpoint`** | Text | **Yes** | Provider URI | | **`providerEndpoint`** | Text | **Yes** | Provider URI |
| **`timeout`** | Number | **Yes** | describing how long the sevice can be used after consumption is initiated. A timeout of 0 represents no time limit. Expressed in seconds. | | **`timeout`** | Number | **Yes** | describing how long the service can be used after consumption is initiated. A timeout of 0 represents no time limit. Expressed in seconds. |
| **`files`** | Array of files object | **Yes** | Array of `File` objects for publishing. These will be transformed to `encryptedFiles` during publish process. See [Files](#files) | | **`files`** | Array of files object | **Yes** | Array of `File` objects for publishing. These will be transformed to `encryptedFiles` during publish process. See [Files](#files) |
| **`privacy`** | Object | **Yes for compute assets** | If asset is of compute `type`, holds information about the compute-related privacy settings. | | **`privacy`** | Object | **Yes for compute assets** | If asset is of compute `type`, holds information about the compute-related privacy settings. |
@ -259,8 +265,7 @@ Example:
"files": { "files": {
"files": [ "files": [
{ {
"contentLength": "3975", "url": "https://demo.com/file.csv"
"contentType": "text/csv"
} }
], ],
"encryptedFiles": "0x044736da6dae39889ff570c34540f24e5e084f4e5bd81eff3691b729c2dd1465ae8292fc721e9d4b1f10f56ce12036c9d149a4dab454b0795bd3ef8b7722c6001e0becdad5caeb2005859642284ef6a546c7ed76f8b350480691f0f6c6dfdda6c1e4d50ee90e83ce3cb3ca0a1a5a2544e10daa6637893f4276bb8d7301eb35306ece50f61ca34dcab550b48181ec81673953d4eaa4b5f19a45c0e9db4cd9729696f16dd05e0edb460623c843a263291ebe757c1eb3435bb529cc19023e0f49db66ef781ca692655992ea2ca7351ac2882bf340c9d9cb523b0cbcd483731dc03f6251597856afa9a68a1e0da698cfc8e81824a69d92b108023666ee35de4a229ad7e1cfa9be9946db2d909735" "encryptedFiles": "0x044736da6dae39889ff570c34540f24e5e084f4e5bd81eff3691b729c2dd1465ae8292fc721e9d4b1f10f56ce12036c9d149a4dab454b0795bd3ef8b7722c6001e0becdad5caeb2005859642284ef6a546c7ed76f8b350480691f0f6c6dfdda6c1e4d50ee90e83ce3cb3ca0a1a5a2544e10daa6637893f4276bb8d7301eb35306ece50f61ca34dcab550b48181ec81673953d4eaa4b5f19a45c0e9db4cd9729696f16dd05e0edb460623c843a263291ebe757c1eb3435bb529cc19023e0f49db66ef781ca692655992ea2ca7351ac2882bf340c9d9cb523b0cbcd483731dc03f6251597856afa9a68a1e0da698cfc8e81824a69d92b108023666ee35de4a229ad7e1cfa9be9946db2d909735"