50 lines
1.5 KiB
TypeScript
50 lines
1.5 KiB
TypeScript
'use strict';
|
|
|
|
import { concat, hexlify } from './bytes';
|
|
import { toUtf8Bytes } from './utf8';
|
|
import { keccak256 } from './keccak256';
|
|
|
|
import { Arrayish } from './types';
|
|
|
|
var Zeros = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]);
|
|
var Partition = new RegExp("^((.*)\\.)?([^.]+)$");
|
|
var UseSTD3ASCIIRules = new RegExp("^[a-z0-9.-]*$");
|
|
|
|
export function namehash(name: string): string {
|
|
name = name.toLowerCase();
|
|
|
|
// Supporting the full UTF-8 space requires additional (and large)
|
|
// libraries, so for now we simply do not support them.
|
|
// It should be fairly easy in the future to support systems with
|
|
// String.normalize, but that is future work.
|
|
if (!name.match(UseSTD3ASCIIRules)) {
|
|
throw new Error('contains invalid UseSTD3ASCIIRules characters');
|
|
}
|
|
|
|
var result: string | Uint8Array = Zeros;
|
|
while (name.length) {
|
|
var partition = name.match(Partition);
|
|
var label = toUtf8Bytes(partition[3]);
|
|
result = keccak256(concat([result, keccak256(label)]));
|
|
|
|
name = partition[2] || '';
|
|
}
|
|
|
|
return hexlify(result);
|
|
}
|
|
|
|
|
|
export function id(text: string): string {
|
|
return keccak256(toUtf8Bytes(text));
|
|
}
|
|
|
|
export function hashMessage(message: Arrayish | string): string {
|
|
var payload = concat([
|
|
toUtf8Bytes('\x19Ethereum Signed Message:\n'),
|
|
toUtf8Bytes(String(message.length)),
|
|
((typeof(message) === 'string') ? toUtf8Bytes(message): message)
|
|
]);
|
|
return keccak256(payload);
|
|
}
|
|
|