123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- import { keccak256 } from "../crypto/index.js";
- import { concat, hexlify, assertArgument, toUtf8Bytes } from "../utils/index.js";
- import { ens_normalize } from "@adraffy/ens-normalize";
- const Zeros = new Uint8Array(32);
- Zeros.fill(0);
- function checkComponent(comp) {
- assertArgument(comp.length !== 0, "invalid ENS name; empty component", "comp", comp);
- return comp;
- }
- function ensNameSplit(name) {
- const bytes = toUtf8Bytes(ensNormalize(name));
- 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
- assertArgument(last < bytes.length, "invalid ENS name; empty component", "name", name);
- comps.push(checkComponent(bytes.slice(last)));
- return comps;
- }
- /**
- * Returns the ENS %%name%% normalized.
- */
- export function ensNormalize(name) {
- try {
- if (name.length === 0) {
- throw new Error("empty label");
- }
- return ens_normalize(name);
- }
- catch (error) {
- assertArgument(false, `invalid ENS name (${error.message})`, "name", name);
- }
- }
- /**
- * Returns ``true`` if %%name%% is a valid ENS name.
- */
- export function isValidName(name) {
- try {
- return (ensNameSplit(name).length !== 0);
- }
- catch (error) { }
- return false;
- }
- /**
- * Returns the [[link-namehash]] for %%name%%.
- */
- export function namehash(name) {
- assertArgument(typeof (name) === "string", "invalid ENS name; not a string", "name", name);
- assertArgument(name.length, `invalid ENS name (empty label)`, "name", name);
- let result = Zeros;
- const comps = ensNameSplit(name);
- while (comps.length) {
- result = keccak256(concat([result, keccak256((comps.pop()))]));
- }
- return hexlify(result);
- }
- /**
- * Returns the DNS encoded %%name%%.
- *
- * This is used for various parts of ENS name resolution, such
- * as the wildcard resolution.
- */
- export function dnsEncode(name, _maxLength) {
- const length = (_maxLength != null) ? _maxLength : 63;
- assertArgument(length <= 255, "DNS encoded label cannot exceed 255", "length", length);
- return hexlify(concat(ensNameSplit(name).map((comp) => {
- assertArgument(comp.length <= length, `label ${JSON.stringify(name)} exceeds ${length} bytes`, "name", name);
- const bytes = new Uint8Array(comp.length + 1);
- bytes.set(comp, 1);
- bytes[0] = bytes.length - 1;
- return bytes;
- }))) + "00";
- }
- //# sourceMappingURL=namehash.js.map
|