Skip to content

Domain Subdomains

Paginate direct child names under a parent domain.
query DomainSubdomains($name: InterpretedName!) {
  domain(by: {name: $name}) {
    name
    subdomains(first: 10) {
      edges {
        node {
          name
        }
      }
    }
  }
}
{
  "name": "eth"
}
{
  "data": {
    "domain": {
      "name": "eth",
      "subdomains": {
        "edges": [
          {
            "node": {
              "name": "⌐◨-◨.eth"
            }
          },
          {
            "node": {
              "name": "♂♂♂♂.eth"
            }
          },
          {
            "node": {
              "name": "♾♾♾♾.eth"
            }
          },
          {
            "node": {
              "name": "⚱⚱⚱⚱.eth"
            }
          },
          {
            "node": {
              "name": "🏴‍☠.eth"
            }
          },
          {
            "node": {
              "name": "🐮💻🐛.eth"
            }
          },
          {
            "node": {
              "name": "👑👑👑👑👑👑.eth"
            }
          },
          {
            "node": {
              "name": "👨🏼‍💻.eth"
            }
          },
          {
            "node": {
              "name": "👱‍♀👱‍♀.eth"
            }
          },
          {
            "node": {
              "name": "🔞🔞🔞🔞🔞.eth"
            }
          }
        ]
      }
    }
  }
}
# POST JSON to your ENSNode Omnigraph endpoint (same path enssdk uses).
curl -sS -X POST "https://api.v2-sepolia.ensnode.io/api/omnigraph" \
  -H "Content-Type: application/json" \
  -d @- <<'EOF'
{
  "query": "query DomainSubdomains($name: InterpretedName!) { domain(by: {name: $name}) { name subdomains(first: 10) { edges { node { name } } } } }",
  "variables": {
    "name": "eth"
  }
}
EOF
import { createEnsNodeClient } from "enssdk/core";
import { asInterpretedName } from "enssdk";
import { graphql, omnigraph } from "enssdk/omnigraph";

const client = createEnsNodeClient({ 
  url: process.env.ENSNODE_URL || "https://api.v2-sepolia.ensnode.io"
}).extend(omnigraph);

const DomainSubdomainsQuery = graphql(`
  query DomainSubdomains($name: InterpretedName!) {
    domain(by: {name: $name}) {
      name
      subdomains(first: 10) {
        edges {
          node {
            name
          }
        }
      }
    }
  }
`);

const result = await client.omnigraph.query({
  query: DomainSubdomainsQuery,
  variables: {
    name: asInterpretedName("eth"),
  },
});

if (result.errors) throw new Error(JSON.stringify(result.errors));
console.log(JSON.stringify(result.data, null, 2));
import { OmnigraphProvider, useOmnigraphQuery, graphql } from "enskit/react/omnigraph";
import { createEnsNodeClient } from "enssdk/core";
import { asInterpretedName } from "enssdk";
import { omnigraph } from "enssdk/omnigraph";

const client = createEnsNodeClient({
  url: import.meta.env.VITE_ENSNODE_URL || "https://api.v2-sepolia.ensnode.io"
}).extend(omnigraph);

const DomainSubdomainsQuery = graphql(`
  query DomainSubdomains($name: InterpretedName!) {
    domain(by: {name: $name}) {
      name
      subdomains(first: 10) {
        edges {
          node {
            name
          }
        }
      }
    }
  }
`);

function DomainSubdomainsResult() {
  const [result] = useOmnigraphQuery({
    query: DomainSubdomainsQuery,
    variables: {
      name: asInterpretedName("eth"),
    },
  });
  const { data, fetching, error } = result;
  if (!data && fetching) return <p>Loading…</p>;
  if (error) return <p>Error: {error.message}</p>;
  if (!data) return <p>No data returned.</p>;
  const formatted = JSON.stringify(
    data,
    (_, value) => (typeof value === "bigint" ? value.toString() : value),
    2,
  );
  return <code>{formatted}</code>;
}

export default function App() {
  return (
    <OmnigraphProvider client={client}>
      <DomainSubdomainsResult />
    </OmnigraphProvider>
  );
}

        # 1. Create project
mkdir -p my-ens-script/src && cd my-ens-script
npm init -y && touch src/index.ts
npm pkg set type=module scripts.start="tsx src/index.ts"
# 2. Install dependencies
npm install enssdk@1.13.1 && npm install -D tsx typescript @types/node
# 3. Paste the TypeScript snippet above into src/index.ts
# 4. Run
ENSNODE_URL=https://api.v2-sepolia.ensnode.io npm start
      

        # 1. Create project
mkdir -p my-ens-script/src && cd my-ens-script
pnpm init && touch src/index.ts
pnpm pkg set type=module scripts.start="tsx src/index.ts"
# 2. Install dependencies
pnpm add enssdk@1.13.1 && pnpm add -D tsx typescript @types/node
# 3. Paste the TypeScript snippet above into src/index.ts
# 4. Run
ENSNODE_URL=https://api.v2-sepolia.ensnode.io pnpm start
      

        # 1. Create project
npm create vite@latest my-ens-app -- --template react-ts --no-interactive --no-immediate
cd my-ens-app
# 2. Install dependencies
npm install
npm install enskit@1.13.1 enssdk@1.13.1
# 3. Copy the TSX snippet above into src/App.tsx
# 4. Run
VITE_ENSNODE_URL=https://api.v2-sepolia.ensnode.io npm run dev
      

        # 1. Create project
pnpm create vite@latest my-ens-app --template react-ts --no-interactive --no-immediate
cd my-ens-app
# 2. Install dependencies
pnpm install
pnpm add enskit@1.13.1 enssdk@1.13.1
# 3. Copy the TSX snippet above into src/App.tsx
# 4. Run
VITE_ENSNODE_URL=https://api.v2-sepolia.ensnode.io pnpm run dev
      
Run in ENSAdmin
GraphQL Query
query DomainSubdomains($name: InterpretedName!) {
domain(by: {name: $name}) {
name
subdomains(first: 10) {
edges {
node {
name
}
}
}
}
}

Payload and transport examples

{
"name": "eth"
}

Response is an illustrative snapshot; live data depends on your ENSNode instance. The curl tab shows a POST to https://api.v2-sepolia.ensnode.io/api/omnigraph

Back to Examples