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

Namecoin #72

Open
xloem opened this issue Feb 8, 2016 · 8 comments
Open

Namecoin #72

xloem opened this issue Feb 8, 2016 · 8 comments

Comments

@xloem
Copy link

xloem commented Feb 8, 2016

I just learned about this project and am so excited!

I think the proper solution for storing usernames is namecoin which you should be aware of. It's an old fork of bitcoin which is still active and is designed to solve exactly this problem, and handles name expiry, registration, history view etc with a simple API. It's much cheaper than bitcoin, but is nearly as secure because it is merge-mined (a huge percentage of the bitcoin miners also mine namecoin simultaneously so it has large PoW security). Alternate solutions are far more vulnerable to various issues and attacks. (blockstore can lose data if all peers holding it disappear, datacoin has very low PoW security ...)

@cjb
Copy link
Owner

cjb commented Feb 8, 2016

Hi! I have a mild bias against altcoins, and have heard bad things about Namecoin in particular: that the anti-spam incentives aren’t good, leading to illegal files stored in the blockchain itself, and that there’s no compact representation (like Bitcoin’s Simplified Payment Verification) for determining whether a claimed name is valid without consulting a full history.

As I understand it, these two design flaws combine to mean that you have to store some very illegal files to use a namecoin resolver, which doesn’t sound good to me. (I may be mistaken, since the bad things I heard about Namecoin came from Bitcoin people..)

In any case, if someone submitted a PR that allows namecoin usernames as well as the OP_RETURN ones in the spec, I expect I'd accept it, it's easy to support multiple sources of usernames.

@xloem
Copy link
Author

xloem commented Feb 8, 2016

How would the client decide whether a bitcoin or namecoin username wins, given conflicts? I suppose it would need to prompt the user?

So you know, my perceptions of namecoin are the opposite of what you have said:
Namecoin has anti-spam contingencies which bitcoin lacks -- it requires pre-registration of names, and it requires regular payment to maintain them. Additionally it has all the safeguards of bitcoin because it is a direct fork. Bitcoin core does not have Simplified Payment Verification support yet, and the clients which offer it do not, as far as I know, offer a programmable API. On the reverse, because namecoin names expire after a set time period, only a portion of namecoin block history is required to validate a name, and anything in old namecoin blocks does not need to be stored for a client to function fully. (like bitcoin, the default client does store everything, including all the obscure encoded storage transactions present in both blockchains)

@cjb
Copy link
Owner

cjb commented Feb 9, 2016

We could do that, or just namespace all the usernames, or namespace all the usernames except the bitcoin ones. (git clone gittorrent://namecoin:foo.com/bar/baz)

I'll have to read more about the current state of namecoin, thanks!

@jeffanthony
Copy link

I agree with everything xloem said but we need not worry about Bitcoin and Namecoin key conflicts - it's cryptographically impossible. Furthermore they both operate on SHA-256 algorithm so a user could create one address which works on both blockchains (aka sidechain).

@xloem
Copy link
Author

xloem commented Feb 9, 2016

@jeffanthony the concept for both blockchains is to store information in transactions, not to use the wallet addresses, so equal names could be stored in both chains

incidentally, I was wrong about namecoin requiring regular payments. website states it requires regular renewals which are free for now.

@notpushkin
Copy link

I believe the Namecoin integration should be based on the id/ namespace then. In this namespace, each entry contains some meta information about a person. So, if id/cjb contains this value:

{
  "name": "Chris Ball",
  "email": "[email protected]",
  "gittorrent": "81e24205d4bac8496d3e13282c90ead5045f09ea"
}

it could work for GitTorrent.

As for the address, there are really many ways to represent it:

  1. gittorrent://nmc/cjb/lilypad-email-shirt
  2. gittorrent://nmc/id/cjb/lilypad-email-shirt — this one allows not only id/ namespace, but some others as well
  3. gittorrent://cjb.bit/lilypad-email-shirt — same, but for d/ (domain) namespace

@JeremyRand
Copy link

JeremyRand commented Apr 17, 2020

Hi! Namecoin developer here.

there’s no compact representation (like Bitcoin’s Simplified Payment Verification) for determining whether a claimed name is valid without consulting a full history.

@cjb Lightweight SPV Namecoin resolution was first introduced in July 2016 IIRC. (So a few months after you posted this.) At the moment, there are 2 lightweight SPV Namecoin clients available: ConsensusJ-Namecoin and Electrum-NMC. (Electrum-NMC tends to be more actively developed, because most of our funders like it more.)

incidentally, I was wrong about namecoin requiring regular payments. website states it requires regular renewals which are free for now.

@xloem This isn't accurate; the confusion might stem from the fact that there are two types of fees in Namecoin: name registration fees (which apply only to registrations, not renewals, and which are primarily intended to prevent miners from engaging in squatting) and transaction fees (which are similar to Bitcoin, and apply to all transactions, including name registrations and name renewals). Any chance you could provide a link to where on the Namecoin website you saw that, so that I can make sure the site doesn't have misleading info on it?

FWIW while I'm not likely to submit a patch for Namecoin support anytime soon, I'd be happy to answer questions if someone else wants to work on this.

@xloem
Copy link
Author

xloem commented Apr 17, 2020

I likely wasn't counting transaction fees since usually the user can set them.

In other relevance, there is a hacked together bitcoinsv git remote at https://github.com/xloem/git-remote-bsv.git .

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

No branches or pull requests

5 participants