Skip to content

Latest commit

 

History

History
113 lines (69 loc) · 6.64 KB

README.md

File metadata and controls

113 lines (69 loc) · 6.64 KB

NEM DNS

alt text

This blog post will demonstrate how the NEM blockchain can be used for a smart, decentralized and reliable DNS service for internet services, for example the translation of domain names to IP addresses. The project include

  • MIT licensed GitHub code
  • Translation of domain names to IP addresses
  • Chrome extension for fast searching .nem domains using the browser address bar
  • Domain name lookup of associated information
  • Demonstration of easy updatable records for the .nem domain owner

What is DNS

The Domain Name System (DNS) is a hierarchical naming system for computers, services, or other resources connected to the Internet or a private network. It associates various information with domain names assigned to each of the participating entities. Most prominently, it translates more readily memorized domain names to the numerical IP addresses needed for locating and identifying computer services and devices with the underlying network protocols. By providing a worldwide, distributed directory service, the Domain Name System is an essential component of the functionality on the Internet, that has been in use since 1985.

Why do we need a blockchain DNS

The classic DNS system despite its high performance, has many weaknesses. The classic DNS system is vulnerable for attacks. For instance, an attacker can hack it and then forward your traffic to fake websites by hijacking DNS responses for intermediate caching servers. In many parts of the world, authorities are censoring and blocking domains for more or less righteous reasons. The price for owning / maintaining a domain name can be costly and the speed of updating domain records is slow.

NEM is a peer-to-peer network that has no domain registrars, domain zone owners, or intermediate caches. The NEM blockchain has proven to be one of the most secure blockchains and information cannot be tampered with. Each NIS has a validated copy of the entire blockchain , the complete database of domain names, messages and transactions. Data reliability is based on the fact that the database is the same for all NIS ensured by the blockchain technology itself and a public consensus mechanism. No one, except the owner of each private key, can change or cancel any record in the chain after it has been submitted and validated.

Controlling a namespace

The owner of a NEM namespace can use the NEM DNS in a few easy steps. The DNS is built around the namespace platform in the NEM ecosystem and an associated pointer address (PA). The namespace owner needs to send a transaction to the namespace pointer address including a non-encrypted message in json format with information related to the namespace. The message can include relevant information such as IP address, ownership info, physical address, contact info and much more. To update the record the owner can simply send a new transaction with the new information.

Example of JSON object:
 {"dns":"yes","ip1":"your ip", "email": "your email"}
 
 // the "dns" = "yes" key will signal that the massage contains DNS info
 // the "ip1" key is the primary IP related to your .nem domain

The pointer address (PA) is found sha256 hashing the namespace name and deriving a NEM public address. You can find a tool on the demo website for calculating the pointer address related to your namespace.

Example of finding PA:
function getPointerAccount(namespace){

	passphrase = sha256(namespace);
	
	var privateKey =  nem.crypto.helpers.derivePassSha(passphrase, 1).priv;
	
	var keyPair = nem.crypto.keyPair.create(privateKey);
	
	var publicKey = keyPair.publicKey.toString();
	
	var address = nem.model.address.toAddress(publicKey, nem.model.network.data.testnet.id);
	
	return address;

}

pointerAdd = getPointerAccount('helloworld');

//getPointerAccount for the namespace 'helloworld' will return TCGD57YKW5TFEY5TWTN7XBJXEZBGGURYXJ54FLDE

alt text

Searching the DNS

Searching the DNS can be done in several ways, this project have made available two different options. (1) using a website, (2) a chrome extension for easy search using the browser address bar. Both options uses JavaScript and the utilities of the NIS api. When requesting a search for the .nem domain name the algorithm will do two NIS requests, the first one will establish ownership of the domain.

Example:

http://104.128.226.60:7890/namespace?namespace=helloworld

Example of returned JSON object:
{"owner":"TCFSDG3XDH2SXWPVJ2Q4LV2SLS57TFJUATT2UJSZ","fqn":"helloworld","height":1387671}

When ownership of the domain is established the algorithm will do a second request related to the pointer address. This request will look for incoming transactions from the owner account. Looping thought the transactions searching for the newest DNS transaction with DNS information.

Example:

http://104.128.226.60:7890/account/transfers/incoming?address=TCGD57YKW5TFEY5TWTN7XBJXEZBGGURYXJ54FLDE

var stop =0;
$.each(data['data'], function( index, value ) {
					
	if ( nem.model.address.toAddress(value['transaction']['signer']...
	, nem.model.network.data.testnet.id)== ownerAdd){

	  var payload = convertFromHex(value['transaction']['message']['payload']);
	  var objPayload = jQuery.parseJSON( payload );
	  if (objPayload['dns']=='yes' && stop==0){

	    stop =1;

	    if(typeRe==1){window.location ='http://'+objPayload['ip1']};
	    if(typeRe==2){alert(payload);};

	  }

	}
									

});

Code from this project is available via GitHub under MIT license. The project and website demo can be downloaded from GitHub or you can try the demo http://nem-dns.bitballoon.com/ running on the testnet.

Chrome browser extension

You can also try the chrome extension by manually installing it. You will have to navigate to the chrome extensions page chrome://extensions (copy past this into your chrome browser), activate developer mode, download the NEM DNS chrome extension from the GitHub page and then load unpacked extension from google chrome. Now a NEM icon should appear in the right corner of the browser and you are ready to search NEM domains. You can try navigating to "www.hello.nem".

alt text

The extension is working in the background adding a webRequest listener. When an request is executed in the address bar by the user the extension will analyze the request to check if it’s an .nem domain request.

Credits

Icons made by DinosoftLabs & Freepik from www.flaticon.com, Creative Commons BY 3.0