Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RIP-0013 accept change issuer #43

Open
Yuripetusko opened this issue Feb 9, 2022 · 9 comments
Open

RIP-0013 accept change issuer #43

Yuripetusko opened this issue Feb 9, 2022 · 9 comments
Labels
RIP RMRK Improvement Proposal

Comments

@Yuripetusko
Copy link
Member

Yuripetusko commented Feb 9, 2022

RIP Summary

The new owner of the collection should fire an ACCEPT command after it was passed to him through CHANGEISSUER

RIP Details

In order to prevent phishing attempts due to the fact that CHANGEISSUER only passes collection to the new owner and not NFTs, a new owner should ACCEPT incoming collection for issuer change to apply.

Original issuer retains all rights until the new issuer accepts it. The new issuer can only ACCEPT the incoming collection and nothing else

Examples

In the extrinsic version of RMRK standard, this can look like

RMRK::ACCEPTCOLLECTION::1.0.0::${collection_id}

Open Questions

Need to check a dump if someone did CHANGEISSUER multiple times on the same collection, as it should have failed because it wasn't accepted after the first time.

Prior work (optional)

?

Impact

In RMRK1 we need to make sure this doesn't affect any of existing collections. But since there's nothing that an issuer can do with his collection except for CHANGEISSUER again this shouldn't be a problem.

So the only thing that we need to check if someone did CHANGEISSUER multiple times on the same collection, as it should have failed because it wasn't accepted after the first time.

We also need to sync with Kodadot (@vikiival, @yangwao) and any indexer services like SubQuery and SubSquid


Thanks to @mmvds for hilighting this case

@Yuripetusko Yuripetusko added the RIP RMRK Improvement Proposal label Feb 9, 2022
@Yuripetusko
Copy link
Member Author

Probably a new field is needed pendingIssuer

Then original issuer retains all the rights of a collection until pendingIssuer calls ACCEPTCOLLECTION. Once ACCEPTCOLLECTION is called, the issuer is changed to an address under pendingIssuer field and pendingIssuer is cleared

@Swader
Copy link
Contributor

Swader commented Feb 9, 2022

LGTM

@vikiival
Copy link
Contributor

vikiival commented Feb 12, 2022

Hey,

@Yuripetusko slid into my DMs a couple of days ago.
As I understand it correctly the main problem is that:

i.e. someone can create a collection with NFTs, changeIssuer to RMRK - and it will look like legitimate

but since NFT ownership stays - you can now sell NFTs that look like created by the RMRK team

But having a pending state is not good IMHO.

May @Swader can explain the use case (why you need change issuer).

In my thinking process, I only allow changing issuer for empty collections.

@Swader
Copy link
Contributor

Swader commented Feb 12, 2022

  • selling a collection
  • thinking your keys are compromised
  • proxy miting for other people
  • merging brands and consolidating IP
  • etc

@Yuripetusko
Copy link
Member Author

Hey,

@Yuripetusko slid into my DMs a couple of days ago. As I understand it correctly the main problem is that:

i.e. someone can create a collection with NFTs, changeIssuer to RMRK - and it will look like legitimate

but since NFT ownership stays - you can now sell NFTs that look like created by the RMRK team

But having a pending state is not good IMHO.

May @Swader can explain the use case (why you need change issuer).

In my thinking process, I only allow changing issuer for empty collections.

No need for p

@vikiival
Copy link
Contributor

vikiival commented Feb 12, 2022

p?

@Yuripetusko

@Yuripetusko
Copy link
Member Author

p?

@Yuripetusko

Sorry not sure what happened there. And I don't remember what I was going to write. But I don't see a problem with pending Issuer approach

@yangwao
Copy link

yangwao commented Feb 13, 2022

selling a collection

Can you elaborate more on this @Swader ? If I'm paying for collection, should I explicitly accept it? Why is that? Isn't value in transaction enough?

thinking your keys are compromised

How does this solve this ACCEPT? If the author (A) of the collection has compromised keys, how prevent ACCEPT not sending them away to desired and owned account?

merging brands and consolidating IP

Like if someone accidentally sends me their brand?

@Swader
Copy link
Contributor

Swader commented Feb 13, 2022

The question was when is change issuer necessary. My answers address this question by giving a few examples, they do not focus on the accept side of things.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
RIP RMRK Improvement Proposal
Projects
None yet
Development

No branches or pull requests

4 participants