We built this standard to use in our Music NFT creator coming to cXc.world. Our NFT creator will allow you to fill out a form and mint the NFT to your own collection, or, if you qualify, you can mint to our exclusive collection.
So why did we make a whole recommendation?
Here at cXc, we like to get down to the nitty-gritty of how things work. Thatβs why we invented a whole new blockchain curation system to run cXc.world instead of using an existing algorithm.
We carried this love over to the NFT scene to offer anyone - project, band, or individual - some suggestions to help structure the data attached to a Music NFT. This will make it easier for low-techy artists to mint their NFTs. Of course, weβll make it even easier for no-techs to mint using our NFT creator, but releasing the standard separately invites all levels and needs to interact with cXc, Atomic Assets, and the WAX ecosystem. A Win-Win-Win!
Below youβll find cXcβs Music NFT Recommendation.
This recommendation is being updated as new needs are presented, but this article is not, so check out cXcβs Music NFT Recommendation on Github for the latest + greatest music NFTs.
cXc Music NFT Schema Recommendation πΈ
The cXc Music NFT Schema serves as a recommendation for any individual, collection, or application to publish a music NFT.
The benefits of using this schema include forward compatibility (Geotags) monetizing NFT plays with traditional platform players, infinite credits and links, and more.
This Schema exists within Atomic Asset's NFT standard on the atomicassets contract.
Feel free to use or modify this schema for your own purposes.
Summary ποΈ
This standard includes:
Name of the NFT (Can be different than track title)
One audio file
One video file
Three images [Main, Back, and Promo]
Title [If different than name]
Album name
Track # [If it's just one track]
Any number of custom credits
Any number of custom platform links
ISO Country code
Readable locale
Pin as GeoJson Point
License
Rarity
Technical Summary βοΈ
All media fields use IPFS.
All other info fields are strings (except "track" is int64)
String arrays are used to store unlimited Credits and Platform links.
Ex.
credits ["Band":"Boaty & The Boats","Bassist: Tim Leary", "Vocalist: Boaty McBoatface"]
platform ["youtube.com/v/gf75ja5","soundcloud.com/my/song"] or ["Soundcloud: soundcloud.com/my/song"]
License is for codes like "CC-BY", or possibly declaring some privilege grant upon receiving NFT.
Geo π
ISO country codes (ISO 3166-1 alpha-3)
Locale string intended to be used in this format "City, County, State" or corresponding values for a given locality
geotag is a GeoJson point stored as a string
Field name | Type | Description |
---|---|---|
name | string | NFT name |
img | string | Primary image / Cover image |
audio | string | Audio file IPFS hash |
video | string | Music video file IPFS has |
backimg | string | Back cover of album / single |
promo | string | Extra image for promo poster, QR code, etc |
title | string | The actual title of the track |
album | string | Title of the album |
track | int64 | Number of the track on the album |
about | string | Description field with info about |
credits | string[] | Array of song credits |
youtube | string | Youtube URL |
spotify | string | Spotify URL |
soundcloud | string | Soundcloud URL |
platforms | string[] | How scarce is this NFT? |
nation | string | Three-letter ISO (USA, BRA, AUS, etc) |
locale | string | Concatanation of lower locales (State, County, City in USA) |
geotag | string | GeoJSON Point stored as string |
license | string | Declare license if needed, (CC0, etc) |
rarity | string | How scarce is this NFT? |
To use this Standard
Paste the following array into the idata
field using the Atomic Assets createschema action to create your own schema on Atomic Assets, and then create template from the schema for each NFT you release. Because this standard uses the string[]
(string array) type, it's currently not possible to use directly on Atomichub UI, but should be in the future.
βΉοΈ Important
Using this schema does not mean that each template must have every field filled,
but you can only choose from fields in your future templates. You may add fields to the schema later, but not remove them. New fields will appear at the end, thus, best modify this standard to your needs before deploying.
cXc Music Schema πΊ
[
{
"name": "name",
"type": "string"
},
{
"name": "img",
"type": "image"
},
{
"name": "audio",
"type": "ipfs"
},
{
"name": "video",
"type": "ipfs"
},
{
"name": "backimg",
"type": "image"
},
{
"name": "promo",
"type": "image"
},
{
"name": "title",
"type": "string"
},
{
"name": "album",
"type": "string"
},
{
"name": "track",
"type": "int64"
},
{
"name": "about",
"type": "string"
},
{
"name": "credits",
"type": "string[]"
},
{
"name": "youtube",
"type": "string"
},
{
"name": "spotify",
"type": "string"
},
{
"name": "soundcloud",
"type": "string"
},
{
"name": "platforms",
"type": "string[]"
},
{
"name": "nation",
"type": "string"
},
{
"name": "locale",
"type": "string"
},
{
"name": "geotag",
"type": "string"
},
{
"name": "license",
"type": "string"
},
{
"name": "rarity",
"type": "string"
}
]
Create a Template π οΈ πΌοΈ.
Use this example (also below) to create a template you can use to drop your own Music NFTs using tools like Atomichub and Neftyblocks.
Modify this schema π οΈ
Change any field you wish when making your own schema
Suggestions:
Artist - If you'd rather have your name here than in credits
Multiple Audio fields - Duplicate the audio fields to include all songs on an album (DYOR on support)
Metadata - Add custom metadata like the key, BPM, time, whatever you want
If you'd rather include all of your links in the Platform field, you can remove the Spotify, Soundcloud, and Youtube field.
Removing Youtube will also disable Youtube player from showing up on Atomichub and likely other marketplaces.
Power of the Schema β¨ π§ββοΈ
There is no magical benefit (yet) of using this standard, just practical ones. Youtube plays can bring extra revenue, as will the links to other players. You may credit all involved, and geographic data opens up new use cases for your NFT.
In the future it's possible for a mapp / dapp (like cXc) to allow users to register their own schemas that adhere to this standard, creating a Music-NFT exclusive platform that doesn't rely on accounts or collection names alone.
Evolution of the Schema π πΈ
This schema will grow and evolve. Feel free to open issues on this repo with your suggestions.
If you translate to another blockchain or NFT standard, please send a pull request adding a file named .md in the main directory containing the code needed to deploy, or open an issue with the code and I can update the repo if you prefer.
Music NFT Template for Atomic Assets
Here is an example of how to format a template according to this recommendation. You will see not every field is used, as you can use only what you need.
To do this you will have to use the atomicassets => createtempl action.
View this template on Atomichub
[
{
"key": "name",
"value": [
"string",
"Bluebirds π₯"
]
},
{
"key": "img",
"value": [
"string",
"QmP1gc43EsmXoaYuT2XPZFWx9SDKk9JxAzpPMP4AUm3aof"
]
},
{
"key": "promo",
"value": [
"string",
"QmYzu7Dz7LqZP3jq4zmt84rpmjWm2AfhH1SF4Et5LbxVJy"
]
},
{
"key": "audio",
"value": [
"string",
"QmWGFx5epoiQBJ3CwBQ3VpNKNJ5VFoKoKDbXExiNLF5zAQ"
]
},
{
"key": "about",
"value": [
"string",
"The quest of a soul opening itβs wings, Bluebirds is a soulβs reflection on the path through this marvelous galaxy. Over a classy beat Douglas expresses an egoic journey, and the desire to look past it while seeking meaning beyond science and religion."
]
},
{
"key": "credits",
"value": [
"STRING_VEC",
["Artist: Sir Douglas Fresh","Beat: Blue Birds by Ours Samplus, live-mixed by Scarfinger"]
]
},
{
"key": "youtube",
"value": [
"string",
"youtube.com/watch?v=trpj6qmLflk"
]
},
{
"key": "soundcloud",
"value": [
"string",
"soundcloud.com/sirdouglasfresh/bluebirds-beat-by-ours-samplus-live-mix-by-scarfinger"
]
},
{
"key": "platforms",
"value": [
"STRING_VEC",
["music.cxc.world/?id=1948"]
]
},
{
"key": "album",
"value": [
"string",
"The Evolution of Sir Douglas Fresh (Mixtape)"
]
},
{
"key": "nation",
"value": [
"string",
"USA"
]
},
{
"key": "locale",
"value": [
"string",
"Accident, Garrett County, MD"
]
},
{
"key": "geotag",
"value": [
"string",
"[39.555,-79.240]"
]
},
{
"key": "rarity",
"value": [
"string",
"Epic"
]
}
].
π₯ FIND OUT MORE ABOUT cXc π₯
Current X Change is dedicated to harmonizing Humans, Collectives, and Gaia. Our media Mapps are just the start. As we refine Purple, we also seek to redefine what it means to come together as humans and co-create. We hope you'll enjoy the tools already here, and are infinitely stoked for what the future holds.
πΊοΈ Experience cXc.world π
ποΈ Step into our vision
π₯ Add Music to cXc.world
πΈ Get to know our Economy
π°BUY & TRADE PURPLE, BLUx π
π£ PURPLE/WAX ~~ π΅ BLUx/WAX ~~ π£π΅ PURPLE/BLUx
Get specifics about these tokens in our Economic Brief
π OFFICIAL cXc MERCH ποΈ
π Shop cXc High-fashion (Made in π¨π¦)
π΄ cXc Stickers, shirts + More on Redbubble
Follow cXc on Social Media π±π
π Discord Musician Community (Collab channels + more)
π Wavvy Music Accolades (NFT Music Awards)
π°π€ Swaps (Instant Liquidity) π‘π£ WAX/PURPLE ~~ π‘π΅ WAX/BLUx
What are BLUx and PURPLE? Find out in our Purple Explainer