2019-05-15 01:48:48 +03:00
|
|
|
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
|
var bytes_1 = require("@ethersproject/bytes");
|
|
|
|
var strings_1 = require("@ethersproject/strings");
|
|
|
|
var keccak256_1 = require("@ethersproject/keccak256");
|
2019-08-02 09:10:58 +03:00
|
|
|
var logger_1 = require("@ethersproject/logger");
|
|
|
|
var _version_1 = require("./_version");
|
|
|
|
var logger = new logger_1.Logger(_version_1.version);
|
2019-05-15 01:48:48 +03:00
|
|
|
///////////////////////////////
|
|
|
|
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("^((.*)\\.)?([^.]+)$");
|
2019-07-28 01:02:24 +03:00
|
|
|
function isValidName(name) {
|
|
|
|
try {
|
|
|
|
var comps = name.split(".");
|
|
|
|
for (var i = 0; i < comps.length; i++) {
|
|
|
|
if (strings_1.nameprep(comps[i]).length === 0) {
|
|
|
|
throw new Error("empty");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
catch (error) { }
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
exports.isValidName = isValidName;
|
2019-05-15 01:48:48 +03:00
|
|
|
function namehash(name) {
|
|
|
|
if (typeof (name) !== "string") {
|
2019-08-02 09:10:58 +03:00
|
|
|
logger.throwArgumentError("invalid address - " + String(name), "name", name);
|
2019-05-15 01:48:48 +03:00
|
|
|
}
|
|
|
|
var result = Zeros;
|
|
|
|
while (name.length) {
|
|
|
|
var partition = name.match(Partition);
|
2019-07-28 01:02:24 +03:00
|
|
|
var label = strings_1.toUtf8Bytes(strings_1.nameprep(partition[3]));
|
2019-05-15 01:48:48 +03:00
|
|
|
result = keccak256_1.keccak256(bytes_1.concat([result, keccak256_1.keccak256(label)]));
|
|
|
|
name = partition[2] || "";
|
|
|
|
}
|
|
|
|
return bytes_1.hexlify(result);
|
|
|
|
}
|
|
|
|
exports.namehash = namehash;
|
|
|
|
function id(text) {
|
|
|
|
return keccak256_1.keccak256(strings_1.toUtf8Bytes(text));
|
|
|
|
}
|
|
|
|
exports.id = id;
|
|
|
|
exports.messagePrefix = "\x19Ethereum Signed Message:\n";
|
|
|
|
function hashMessage(message) {
|
|
|
|
if (typeof (message) === "string") {
|
|
|
|
message = strings_1.toUtf8Bytes(message);
|
|
|
|
}
|
|
|
|
return keccak256_1.keccak256(bytes_1.concat([
|
|
|
|
strings_1.toUtf8Bytes(exports.messagePrefix),
|
|
|
|
strings_1.toUtf8Bytes(String(message.length)),
|
|
|
|
message
|
|
|
|
]));
|
|
|
|
}
|
|
|
|
exports.hashMessage = hashMessage;
|