mirror of
https://github.com/oceanprotocol/docs.git
synced 2024-11-26 19:49:26 +01:00
79 lines
2.7 KiB
Markdown
79 lines
2.7 KiB
Markdown
|
# Creating a data NFT
|
||
|
|
||
|
This tutorial guides you through the process of creating your own data NFT using Ocean libraries. To know more about data NFT please refer [this page](../../core-concepts/datanft-and-datatoken.md).
|
||
|
|
||
|
#### Prerequisites
|
||
|
|
||
|
* [Obtain an API key](configuration.md)
|
||
|
* [Set up the .env file](configuration.md)
|
||
|
* [Install the dependencies](configuration.md)
|
||
|
* [Create a configuration file](configuration.md)
|
||
|
|
||
|
#### Create a script to deploy dataNFT
|
||
|
|
||
|
The provided script demonstrates how to create a data NFT using Oceanjs. 
|
||
|
|
||
|
First, create a new file in the working directory, alongside the `config.js` and `.env` files. Name it `create_dataNFT.js` (or any appropriate name). Then, copy the following code into the new created file:
|
||
|
|
||
|
{% tabs %}
|
||
|
{% tab title="create_dataNFT.js" %}
|
||
|
{% code title="create_dataNFT.js" %}
|
||
|
```javascript
|
||
|
// Note: Make sure .env file and config.js are created and setup correctly
|
||
|
const { oceanConfig } = require('./config.js');
|
||
|
const { ZERO_ADDRESS, NftFactory } = require ('@oceanprotocol/lib');
|
||
|
|
||
|
// Deinfe a function which will create a dataNFT using Ocean.js library
|
||
|
const createDataNFT = async () => {
|
||
|
let config = await oceanConfig();
|
||
|
// Create a NFTFactory
|
||
|
const factory = new NftFactory(config.nftFactoryAddress, config.publisherAccount);
|
||
|
|
||
|
const publisherAccount = await config.publisherAccount.getAddress();
|
||
|
|
||
|
// Define dataNFT parameters
|
||
|
const nftParams = {
|
||
|
name: '72120Bundle',
|
||
|
symbol: '72Bundle',
|
||
|
// Optional parameters
|
||
|
templateIndex: 1,
|
||
|
tokenURI: 'https://example.com',
|
||
|
transferable: true,
|
||
|
owner: publisherAccount
|
||
|
};
|
||
|
|
||
|
const bundleNFT = await factory.createNFT(nftParams);
|
||
|
|
||
|
const trxReceipt = await bundleNFT.wait()
|
||
|
|
||
|
return {
|
||
|
trxReceipt
|
||
|
};
|
||
|
};
|
||
|
|
||
|
// Call the create createDataNFT() function
|
||
|
createDataNFT()
|
||
|
.then(({ nftAddress }) => {
|
||
|
console.log(`DataNft address ${nftAddress}`);
|
||
|
process.exit();
|
||
|
})
|
||
|
.catch((err) => {
|
||
|
console.error(err);
|
||
|
process.exit(1);
|
||
|
});
|
||
|
```
|
||
|
{% endcode %}
|
||
|
|
||
|
Run script:
|
||
|
|
||
|
```bash
|
||
|
node create_dataNFT.js
|
||
|
```
|
||
|
{% endtab %}
|
||
|
{% endtabs %}
|
||
|
|
||
|
* Checkout our [code examples](https://github.com/oceanprotocol/ocean.js/blob/main/CodeExamples.md#L0-L1) or [compute to data examples](https://github.com/oceanprotocol/ocean.js/blob/main/ComputeExamples.md#L417) to see how you can use ocean.js.
|
||
|
* If you have any difficulties or if you have further questions about how to use ocean.js please reach out to us on [Discord](https://discord.gg/TnXjkR5).
|
||
|
* If you notice any bugs or issues with ocean.js please [open an issue on github](https://github.com/oceanprotocol/ocean.js/issues/new?assignees=\&labels=bug\&template=bug\_report.md\&title=).
|
||
|
* Visit the [Ocean Protocol website](https://docs.oceanprotocol.com/) for general information about Ocean Protocol.
|