You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
Muhammed Tanrikulu 7d8ab5df15
version bump, include idna-map into dist
3 years ago
test Fix handling of ens domains containing international characters 7 years ago
.gitignore configure project as npm under ensdomains scope (#2) 3 years ago
.npmignore configure project as npm under ensdomains scope (#2) 3 years ago
README.md configure project as npm under ensdomains scope (#2) 3 years ago
circle.yml Add node version requirement 8 years ago
index.js Fix handling of ens domains containing international characters 7 years ago
package.json version bump, include idna-map into dist 3 years ago
yarn.lock bump idna-uts46-hx to 3.4.x 3 years ago

README.md

Eth ENS Namehash (Fork)

A javascript library for generating Ethereum Name Service (ENS) namehashes per spec.

Available on NPM

Installation

npm install @ensdomains/eth-ens-namehash -S

Usage

var namehash = require('@ensdomains/eth-ens-namehash')
var hash = namehash.hash('foo.eth')
// '0xde9b09fd7c5f901e23a3f19fecc54828e9c848539801e86591bd9801b019f84f'

// Also supports normalizing strings to ENS compatibility:
var input = getUserInput()
var normalized = namehash.normalize(input)

Security Warning

ENS Supports UTF-8 characters, and so many duplicate names are possible. For example:

  • faceboоk.eth
  • facebook.eth

The first one has non-ascii chars. (control+F on this page and search for facebook, only the second one will match).

namehash.normalize() doesn't automagically remap those, and so other precautions should be taken to avoid user phishing.

Development

This module supports advanced JavaScript syntax, but exports an ES5-compatible module. To re-build the exported module after making changes, run npm run bundle (must have browserify installed).