2022-09-05 23:57:11 +03:00
|
|
|
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
|
exports.dnsEncode = exports.namehash = exports.isValidName = exports.ensNormalize = void 0;
|
2022-09-16 05:58:45 +03:00
|
|
|
const index_js_1 = require("../crypto/index.js");
|
|
|
|
const index_js_2 = require("../utils/index.js");
|
2023-01-28 09:53:29 +03:00
|
|
|
const xnf_1 = require("@adraffy/ens-normalize/xnf");
|
2022-09-05 23:57:11 +03:00
|
|
|
const Zeros = new Uint8Array(32);
|
|
|
|
Zeros.fill(0);
|
|
|
|
function checkComponent(comp) {
|
2023-01-27 07:36:26 +03:00
|
|
|
(0, index_js_2.assertArgument)(comp.length !== 0, "invalid ENS name; empty component", "comp", comp);
|
2022-09-05 23:57:11 +03:00
|
|
|
return comp;
|
|
|
|
}
|
|
|
|
function ensNameSplit(name) {
|
2023-01-28 09:53:29 +03:00
|
|
|
const bytes = (0, index_js_2.toUtf8Bytes)(ensNormalize(name));
|
2022-09-05 23:57:11 +03:00
|
|
|
const comps = [];
|
|
|
|
if (name.length === 0) {
|
|
|
|
return comps;
|
|
|
|
}
|
|
|
|
let last = 0;
|
|
|
|
for (let i = 0; i < bytes.length; i++) {
|
|
|
|
const d = bytes[i];
|
|
|
|
// A separator (i.e. "."); copy this component
|
|
|
|
if (d === 0x2e) {
|
|
|
|
comps.push(checkComponent(bytes.slice(last, i)));
|
|
|
|
last = i + 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// There was a stray separator at the end of the name
|
2023-01-27 07:36:26 +03:00
|
|
|
(0, index_js_2.assertArgument)(last < bytes.length, "invalid ENS name; empty component", "name", name);
|
2022-09-05 23:57:11 +03:00
|
|
|
comps.push(checkComponent(bytes.slice(last)));
|
|
|
|
return comps;
|
|
|
|
}
|
2023-01-28 09:53:29 +03:00
|
|
|
/**
|
|
|
|
* Returns the ENS %%name%% normalized.
|
|
|
|
*/
|
2022-09-05 23:57:11 +03:00
|
|
|
function ensNormalize(name) {
|
2023-01-28 09:53:29 +03:00
|
|
|
try {
|
|
|
|
return (0, xnf_1.ens_normalize)(name);
|
|
|
|
}
|
|
|
|
catch (error) {
|
|
|
|
(0, index_js_2.assertArgument)(false, `invalid ENS name (${error.message})`, "name", name);
|
|
|
|
}
|
2022-09-05 23:57:11 +03:00
|
|
|
}
|
|
|
|
exports.ensNormalize = ensNormalize;
|
2023-01-28 09:53:29 +03:00
|
|
|
/**
|
|
|
|
* Returns ``true`` if %%name%% is a valid ENS name.
|
|
|
|
*/
|
2022-09-05 23:57:11 +03:00
|
|
|
function isValidName(name) {
|
|
|
|
try {
|
|
|
|
return (ensNameSplit(name).length !== 0);
|
|
|
|
}
|
|
|
|
catch (error) { }
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
exports.isValidName = isValidName;
|
2023-01-28 09:53:29 +03:00
|
|
|
/**
|
|
|
|
* Returns the [[link-namehash]] for %%name%%.
|
|
|
|
*/
|
2022-09-05 23:57:11 +03:00
|
|
|
function namehash(name) {
|
2022-11-09 10:57:02 +03:00
|
|
|
(0, index_js_2.assertArgument)(typeof (name) === "string", "invalid ENS name; not a string", "name", name);
|
2022-09-05 23:57:11 +03:00
|
|
|
let result = Zeros;
|
|
|
|
const comps = ensNameSplit(name);
|
|
|
|
while (comps.length) {
|
2022-09-16 05:58:45 +03:00
|
|
|
result = (0, index_js_1.keccak256)((0, index_js_2.concat)([result, (0, index_js_1.keccak256)((comps.pop()))]));
|
2022-09-05 23:57:11 +03:00
|
|
|
}
|
2022-09-16 05:58:45 +03:00
|
|
|
return (0, index_js_2.hexlify)(result);
|
2022-09-05 23:57:11 +03:00
|
|
|
}
|
|
|
|
exports.namehash = namehash;
|
2023-01-28 09:53:29 +03:00
|
|
|
/**
|
|
|
|
* Returns the DNS encoded %%name%%.
|
|
|
|
*
|
|
|
|
* This is used for various parts of ENS name resolution, such
|
|
|
|
* as the wildcard resolution.
|
|
|
|
*/
|
2022-09-05 23:57:11 +03:00
|
|
|
function dnsEncode(name) {
|
2022-09-16 05:58:45 +03:00
|
|
|
return (0, index_js_2.hexlify)((0, index_js_2.concat)(ensNameSplit(name).map((comp) => {
|
2022-09-05 23:57:11 +03:00
|
|
|
// DNS does not allow components over 63 bytes in length
|
|
|
|
if (comp.length > 63) {
|
|
|
|
throw new Error("invalid DNS encoded entry; length exceeds 63 bytes");
|
|
|
|
}
|
|
|
|
const bytes = new Uint8Array(comp.length + 1);
|
|
|
|
bytes.set(comp, 1);
|
|
|
|
bytes[0] = bytes.length - 1;
|
|
|
|
return bytes;
|
|
|
|
}))) + "00";
|
|
|
|
}
|
|
|
|
exports.dnsEncode = dnsEncode;
|
|
|
|
//# sourceMappingURL=namehash.js.map
|