Deploy a new NFT Collection contract.
POSThttps://minatokens.com/api/v1//nft/launch
The launch
endpoint is used to deploy a new NFT Collection on the Mina blockchain.
It allows users to create a new NFT Collection with customizable parameters.
Request
- application/json
Bodyrequired
- oneOf
- LaunchNftCollectionStandardAdminParams
- LaunchNftCollectionAdvancedAdminParams
Must be "nft:launch"
Possible values: [nft:launch
]
Optional. The address of the collection.
Optional. The address of the NFT.
The address (public key) of the sender.
The private key of the sender. It is NOT recommended to use this field. Please use the sender
field instead. Use this field at your own risk and only if you know what you are doing and do not have access to mina-signer or wallet to get the signature.
Optional. The nonce for the transaction.
Optional. A memo for the transaction.
Optional. The developer fee for the transaction.
Must be "standard" for standard admin contract.
Possible values: [standard
]
The symbol of the NFT collection. Use NFT as a default value.
The URL of the NFT collection.
The name of the NFT collection.
The creator of the NFT collection. Should be the public key of the creator starting with B62.
The base URL of the NFT collection, can be 'ipfs' or url with or without https://
. Default is 'ipfs'.
collectionData object
masterNFT objectrequired
Optional. The address of the admin contract.
Optional. Private key for the collection contract.
Optional. Private key for the admin contract.
Must be "nft:launch"
Possible values: [nft:launch
]
Optional. The address of the collection.
Optional. The address of the NFT.
The address (public key) of the sender.
The private key of the sender. It is NOT recommended to use this field. Please use the sender
field instead. Use this field at your own risk and only if you know what you are doing and do not have access to mina-signer or wallet to get the signature.
Optional. The nonce for the transaction.
Optional. A memo for the transaction.
Optional. The developer fee for the transaction.
Must be "advanced" for advanced admin contract.
Possible values: [advanced
]
The symbol of the NFT collection. Use NFT as a default value.
The URL of the NFT collection.
The name of the NFT collection.
The creator of the NFT collection. Should be the public key of the creator starting with B62.
The base URL of the NFT collection, can be 'ipfs' or url with or without https://
. Default is 'ipfs'.
collectionData object
masterNFT objectrequired
Optional. The address of the admin contract.
Optional. Private key for the collection contract.
Optional. Private key for the admin contract.
The address of the upgrade authority contract
adminData object
whitelist object
Responses
- 200
- 400
- 401
- 403
- 429
- 500
- 503
Successful deployment of a new NFT Collection.
- application/json
- Schema
- Example (auto)
Schema
The address initiating the transaction.
The nonce for the transaction.
A memo for the transaction.
The fee for the transaction.
walletPayload objectrequired
minaSignerPayload objectrequired
The payload for the prover.
The signed data for the transaction.
The raw transaction data.
Optional. Whether to broadcast the transaction after proving.
The symbol of the NFT collection.
The name of the NFT collection.
The name of the NFT.
The storage of the NFT (IPFS hash).
The private metadata of the NFT.
The metadata root of the NFT.
The serialized metadata map of the NFT.
request objectrequired
{
"sender": "string",
"nonce": 0,
"memo": "string",
"fee": 0,
"walletPayload": {
"nonce": 0,
"transaction": "string",
"onlySign": true,
"feePayer": {
"fee": 0,
"memo": "string"
}
},
"minaSignerPayload": {
"zkappCommand": {},
"feePayer": {
"feePayer": "string",
"fee": 0,
"nonce": 0,
"memo": "string"
}
},
"proverPayload": "string",
"signedData": "string",
"transaction": "string",
"sendTransaction": true,
"symbol": "string",
"collectionName": "string",
"nftName": "string",
"storage": "string",
"privateMetadata": "string",
"metadataRoot": "string",
"map": {},
"request": {
"txType": "nft:launch",
"collectionAddress": "string",
"nftAddress": "string",
"sender": "string",
"senderPrivateKey": "string",
"nonce": 0,
"memo": "string",
"developerFee": 0,
"adminContract": "standard",
"symbol": "string",
"url": "string",
"collectionName": "string",
"creator": "string",
"baseURL": "string",
"collectionData": {
"royaltyFee": 0,
"transferFee": 0,
"requireTransferApproval": true,
"mintingIsLimited": true,
"isPaused": true
},
"masterNFT": {
"name": "string",
"address": "string",
"addressPrivateKey": "string",
"tokenId": 0,
"data": {
"owner": "string",
"approved": "string",
"version": 0,
"id": "string",
"canChangeOwnerByProof": true,
"canTransfer": true,
"canApprove": true,
"canChangeMetadata": true,
"canChangeStorage": true,
"canChangeName": true,
"canChangeMetadataVerificationKeyHash": true,
"canPause": true,
"isPaused": true,
"requireOwnerAuthorizationToUpgrade": true
},
"fee": 0,
"metadata": "string",
"storage": "string",
"metadataVerificationKeyHash": "string",
"expiry": 0
},
"adminContractAddress": "string",
"collectionContractPrivateKey": "string",
"adminContractPrivateKey": "string"
}
}
Bad request - invalid input parameters.
- application/json
- Schema
- Example (auto)
Schema
Error message detailing the issue.
{
"error": "string"
}
Unauthorized - user not authenticated.
- application/json
- Schema
- Example (auto)
Schema
Error message detailing the issue.
{
"error": "string"
}
Forbidden - user doesn't have permission.
- application/json
- Schema
- Example (auto)
Schema
Error message detailing the issue.
{
"error": "string"
}
Too many requests.
- application/json
- Schema
- Example (auto)
Schema
Error message detailing the issue.
{
"error": "string"
}
Internal server error - something went wrong during the request.
- application/json
- Schema
- Example (auto)
Schema
Error message detailing the issue.
{
"error": "string"
}
Service unavailable - blockchain or other external service is down.
- application/json
- Schema
- Example (auto)
Schema
Error message detailing the issue.
{
"error": "string"
}
Authorization: x-api-key
name: x-api-keytype: apiKeyin: headerdescription: API key for authorization. Get your API key at https://minatokens.com/api
- curl
- javascript
- nodejs
- python
- rust
- ocaml
- go
- java
- powershell
- CURL
curl -L 'https://minatokens.com/api/v1/nft/launch' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'x-api-key: <x-api-key>' \
-d '{
"txType": "nft:launch",
"collectionAddress": "string",
"nftAddress": "string",
"sender": "string",
"senderPrivateKey": "string",
"nonce": 0,
"memo": "string",
"developerFee": 0,
"adminContract": "standard",
"symbol": "string",
"url": "string",
"collectionName": "string",
"creator": "string",
"baseURL": "string",
"collectionData": {
"royaltyFee": 0,
"transferFee": 0,
"requireTransferApproval": true,
"mintingIsLimited": true,
"isPaused": true
},
"masterNFT": {
"name": "string",
"address": "string",
"addressPrivateKey": "string",
"tokenId": 0,
"data": {
"owner": "string",
"approved": "string",
"version": 0,
"id": "string",
"canChangeOwnerByProof": true,
"canTransfer": true,
"canApprove": true,
"canChangeMetadata": true,
"canChangeStorage": true,
"canChangeName": true,
"canChangeMetadataVerificationKeyHash": true,
"canPause": true,
"isPaused": true,
"requireOwnerAuthorizationToUpgrade": true
},
"fee": 0,
"metadata": "string",
"storage": "string",
"metadataVerificationKeyHash": "string",
"expiry": 0
},
"adminContractAddress": "string",
"collectionContractPrivateKey": "string",
"adminContractPrivateKey": "string"
}'