ADR-41: Collection Items Approval Flow Enhancement

More details about this document
Latest published version:
https://adr.decentraland.org/adr/ADR-41
Authors:
menduz
pentreathm
cazala
nachomazzara
Feedback:
GitHub decentraland/adr (pull requests, new issue, open issues)
Edit this documentation:
GitHub View commits View commits on githistory.xyz

Statement of the problem

The Catalysts accepts only:

The first one is risky because the catalyst does not have a way to validate the content submitted and someone can submit as many contents as they wish flooding the storage. All the content submitted to the catalyst must be validated by content hashing.

Consensus changes

The consensus rules of the catalyst will modify the validations to the deployment of collection entities, that validation will now verify that:

Alternative A ✅

These two transactions will simulate an approve(hash).

Check here for further reference of smart contracts.

Create a Decentraland collection

Matic CollectionMatic Collection FactoryBuilder ServerBuilderCreatorMatic CollectionMatic Collection FactoryBuilder ServerBuilderCreatorCreate collection & upload itemsSave collection & itemsPublish collectionDeploy collectionCreate collection

Create third party Item

Matic Third Party RegistryBuilder ServerBuilderCreatorMatic Third Party RegistryBuilder ServerBuilderCreatorCreate collection & upload itemsSave collection & itemsPublish itemsUpload items

Create and update items

Builder ServerBuilderUserBuilder ServerBuilderUserUpload new version of itemEdit item metadataSave item

Propagate deployments to Cataysts

DAO PeerMatic CollectionBuilderBuilder serverCommitteeDAO PeerMatic CollectionBuilderBuilder serverCommitteeFetch all \nitems from a collectionapprove(content_hashes[])Create new deployments for the catalyst using\nspecific assets from content hashessendTx: approve(content_hashes)Update item hashes & approve collectiontxMinedDeploy entititiesapproved content_hashes[]Check and accept deployments

Get (non-catalyst) content to test in-world

ExplorerBuilder serverExplorerBuilder serverfetch items

Change editable parameters from items (Decentraland Collections only)

beneficiary, price, name, description, category, body shapes.

Builder ServerMatic CollectionBuilderCreatorsBuilder ServerMatic CollectionBuilderCreatorsUpdate item\n price & beneficiarySend TXConsolidate by fetching\nthe collection subgraph

Approve process (committee)

DAO CatalystMatic CollectionCommitteeBuilder ServerBuilderCreatorDAO CatalystMatic CollectionCommitteeBuilder ServerBuilderCreatorPlay and upload collectionReview by committeeUpload approved content to catalystUpload new versionssave itemUpload new versionssave itemUpload new versionssave itemUpload new versionssave itemItem/collection ready to reviewPublish if needed(first time)Collection ready for reviewApprove hash1 + categoryApprove hash2 + categoryapprove items with hashessendTx: approve(content_hashes)Wait for txtxMinedUpload hashed entity, using any signerValidate hashes

Alternative B

Using non-DAO catalyst with new flags to provide a decentralized way of storing the items instead of the builder-server.

This alternative is not needed for the time being cause the builder-server is already used when the collection items are not published yet.

Development proposed

Milestone 1

Milestone 2

License

Copyright and related rights waived via CC0-1.0. DRAFT Living