Crawler Summary

alldomains answer-first brief

Solana domain name service for registering Web3 domains (.molt, .bonk, etc). Use when: (1) Checking domain availability, (2) Getting domain prices, (3) Registering Solana domains, (4) Working with TLDs like .molt, .bonk, .poor, etc. --- name: alldomains description: > Solana domain name service for registering Web3 domains (.molt, .bonk, etc). Use when: (1) Checking domain availability, (2) Getting domain prices, (3) Registering Solana domains, (4) Working with TLDs like .molt, .bonk, .poor, etc. --- AllDomains Solana domain name service API for checking and registering Web3 domains. **Website:** https://alldomains.id **Supported TLDs:** .molt, Capability contract not published. No trust telemetry is available yet. Last updated 4/14/2026.

Freshness

Last checked 4/14/2026

Best For

alldomains is best for general automation workflows where OpenClaw compatibility matters.

Not Ideal For

Contract metadata is missing or unavailable for deterministic execution.

Evidence Sources Checked

editorial-content, GITHUB OPENCLEW, runtime-metrics, public facts pack

Claim this agent
Agent DossierGitHubSafety: 94/100

alldomains

Solana domain name service for registering Web3 domains (.molt, .bonk, etc). Use when: (1) Checking domain availability, (2) Getting domain prices, (3) Registering Solana domains, (4) Working with TLDs like .molt, .bonk, .poor, etc. --- name: alldomains description: > Solana domain name service for registering Web3 domains (.molt, .bonk, etc). Use when: (1) Checking domain availability, (2) Getting domain prices, (3) Registering Solana domains, (4) Working with TLDs like .molt, .bonk, .poor, etc. --- AllDomains Solana domain name service API for checking and registering Web3 domains. **Website:** https://alldomains.id **Supported TLDs:** .molt,

OpenClawself-declared

Public facts

4

Change events

1

Artifacts

0

Freshness

Apr 14, 2026

Verifiededitorial-contentNo verified compatibility signals

Capability contract not published. No trust telemetry is available yet. Last updated 4/14/2026.

Trust evidence available

Trust score

Unknown

Compatibility

OpenClaw

Freshness

Apr 14, 2026

Vendor

Metasolbot

Artifacts

0

Benchmarks

0

Last release

Unpublished

Executive Summary

Key links, install path, and a quick operational read before the deeper crawl record.

Verifiededitorial-content

Summary

Capability contract not published. No trust telemetry is available yet. Last updated 4/14/2026.

Setup snapshot

git clone https://github.com/metasolbot/alldomains-skill.git
  1. 1

    Setup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.

  2. 2

    Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.

Evidence Ledger

Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.

Verifiededitorial-content
Vendor (1)

Vendor

Metasolbot

profilemedium
Observed Apr 14, 2026Source linkProvenance
Compatibility (1)

Protocol compatibility

OpenClaw

contractmedium
Observed Apr 14, 2026Source linkProvenance
Security (1)

Handshake status

UNKNOWN

trustmedium
Observed unknownSource linkProvenance
Integration (1)

Crawlable docs

6 indexed pages on the official domain

search_documentmedium
Observed Apr 15, 2026Source linkProvenance

Release & Crawl Timeline

Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.

Self-declaredagent-index

Artifacts Archive

Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.

Self-declaredGITHUB OPENCLEW

Extracted files

0

Examples

6

Snippets

0

Languages

typescript

Parameters

Executable Examples

text

https://alldomains.id

text

GET /api/check-domain/{domain.tld}

typescript

type DomainCheckResponse = {
  tld: string;
  exists: boolean | (Record<string, any> | undefined)[];
  domainPrice: {
    mint: string;
    pricing: number;
  }[] | undefined | null;
};

typescript

const domain = "myname.molt";
const response = await fetch(`https://alldomains.id/api/check-domain/${domain}`);
const data = await response.json();

// Check if taken
const domainTaken = data.exists === true || 
  (Array.isArray(data.exists) && data.exists.some(v => v != null));

if (domainTaken) {
  console.log("Domain is taken");
} else {
  console.log("Domain available! Price:", data.domainPrice);
}

text

POST /api/create-domain

typescript

{
  domain: string;      // Domain name without TLD (e.g., "myname")
  durationRate: number; // Years: 1-5
  tld: string;         // TLD with dot (e.g., ".molt")
  publicKey: string;   // Buyer's Solana public key
  simulate?: boolean;  // Optional: simulate first
}

Docs & README

Full documentation captured from public sources, including the complete README when available.

Self-declaredGITHUB OPENCLEW

Docs source

GITHUB OPENCLEW

Editorial quality

ready

Solana domain name service for registering Web3 domains (.molt, .bonk, etc). Use when: (1) Checking domain availability, (2) Getting domain prices, (3) Registering Solana domains, (4) Working with TLDs like .molt, .bonk, .poor, etc. --- name: alldomains description: > Solana domain name service for registering Web3 domains (.molt, .bonk, etc). Use when: (1) Checking domain availability, (2) Getting domain prices, (3) Registering Solana domains, (4) Working with TLDs like .molt, .bonk, .poor, etc. --- AllDomains Solana domain name service API for checking and registering Web3 domains. **Website:** https://alldomains.id **Supported TLDs:** .molt,

Full README

name: alldomains description: > Solana domain name service for registering Web3 domains (.molt, .bonk, etc). Use when: (1) Checking domain availability, (2) Getting domain prices, (3) Registering Solana domains, (4) Working with TLDs like .molt, .bonk, .poor, etc.

AllDomains

Solana domain name service API for checking and registering Web3 domains.

Website: https://alldomains.id Supported TLDs: .molt, .bonk, .poor, .abc, and many more

API Base URL

https://alldomains.id

Check Domain Availability

Endpoint

GET /api/check-domain/{domain.tld}

Response

type DomainCheckResponse = {
  tld: string;
  exists: boolean | (Record<string, any> | undefined)[];
  domainPrice: {
    mint: string;
    pricing: number;
  }[] | undefined | null;
};

Example

const domain = "myname.molt";
const response = await fetch(`https://alldomains.id/api/check-domain/${domain}`);
const data = await response.json();

// Check if taken
const domainTaken = data.exists === true || 
  (Array.isArray(data.exists) && data.exists.some(v => v != null));

if (domainTaken) {
  console.log("Domain is taken");
} else {
  console.log("Domain available! Price:", data.domainPrice);
}

Register Domain

Endpoint

POST /api/create-domain

Request Body

{
  domain: string;      // Domain name without TLD (e.g., "myname")
  durationRate: number; // Years: 1-5
  tld: string;         // TLD with dot (e.g., ".molt")
  publicKey: string;   // Buyer's Solana public key
  simulate?: boolean;  // Optional: simulate first
}

Response

type CreateDomainApiResponse = {
  status: "success" | "error";
  error: string | null;
  msg: string | null;
  instructionBase64: string | null;
  preInstructionsBase64?: string[];
  addressLookupTableAccountsKeys?: string[];
  insufficientFunds?: boolean;
  slippageToleranceExceeded?: boolean;
  simulationError?: boolean;
};

Complete Registration Flow

import {
  Connection,
  PublicKey,
  Keypair,
  TransactionInstruction,
  AddressLookupTableAccount,
  VersionedTransaction,
  TransactionMessage,
} from "@solana/web3.js";

const BASE_URL = "https://alldomains.id";
const RPC_URL = "https://viviyan-bkj12u-fast-mainnet.helius-rpc.com";

// Helper: Create versioned transaction
function createTransaction(
  payerKey: PublicKey,
  instructions: TransactionInstruction[],
  blockhash: string,
  lutAddresses: AddressLookupTableAccount[] = []
): VersionedTransaction {
  const messageV0 = new TransactionMessage({
    payerKey,
    recentBlockhash: blockhash,
    instructions,
  }).compileToV0Message(lutAddresses);
  return new VersionedTransaction(messageV0);
}

// Helper: Get lookup table accounts
async function getAddressLookupTableAccounts(
  connection: Connection,
  keys: string[]
): Promise<AddressLookupTableAccount[]> {
  const accountInfos = await connection.getMultipleAccountsInfo(
    keys.map((key) => new PublicKey(key))
  );
  
  return accountInfos.reduce((acc, accountInfo, index) => {
    if (accountInfo) {
      acc.push(new AddressLookupTableAccount({
        key: new PublicKey(keys[index]),
        state: AddressLookupTableAccount.deserialize(
          Uint8Array.from(accountInfo.data)
        ),
      }));
    }
    return acc;
  }, [] as AddressLookupTableAccount[]);
}

// Helper: Decode base64 instructions
function decodeInstructions(base64Instructions: string[]): TransactionInstruction[] {
  return base64Instructions.map((instructionBase64) => {
    const decoded = JSON.parse(
      Buffer.from(instructionBase64, "base64").toString()
    );
    return new TransactionInstruction({
      keys: decoded.keys.map((key: any) => ({
        pubkey: new PublicKey(key.pubkey),
        isSigner: key.isSigner,
        isWritable: key.isWritable,
      })),
      programId: new PublicKey(decoded.programId),
      data: Buffer.from(decoded.data),
    });
  });
}

// Main: Register domain
async function registerDomain(
  domain: string,
  tld: string,
  payer: Keypair,
  durationYears: number = 1
) {
  const connection = new Connection(RPC_URL);
  
  // Step 1: Check availability
  const checkResponse = await fetch(
    `${BASE_URL}/api/check-domain/${domain}${tld}`
  );
  const checkData = await checkResponse.json();
  
  const isTaken = checkData.exists === true ||
    (Array.isArray(checkData.exists) && checkData.exists.some((v: any) => v != null));
  
  if (isTaken) {
    throw new Error(`Domain ${domain}${tld} is already taken`);
  }
  
  console.log("Domain available! Price:", checkData.domainPrice);
  
  // Step 2: Get registration instructions
  const createResponse = await fetch(`${BASE_URL}/api/create-domain`, {
    method: "POST",
    headers: { "Content-Type": "application/json" },
    body: JSON.stringify({
      domain,
      durationRate: durationYears,
      tld,
      publicKey: payer.publicKey.toString(),
      simulate: true,
    }),
  });
  
  const createData = await createResponse.json();
  
  if (createData.status === "error") {
    throw new Error(`Failed: ${createData.error} | ${createData.msg}`);
  }
  
  if (!createData.instructionBase64 || 
      !createData.addressLookupTableAccountsKeys ||
      !createData.preInstructionsBase64) {
    throw new Error("Missing instruction data");
  }
  
  // Step 3: Decode instructions
  const mainInstruction = decodeInstructions([createData.instructionBase64])[0];
  const preInstructions = decodeInstructions(createData.preInstructionsBase64);
  
  // Step 4: Get lookup tables
  const lookupTables = await getAddressLookupTableAccounts(
    connection,
    createData.addressLookupTableAccountsKeys
  );
  
  // Step 5: Build transaction
  const { blockhash } = await connection.getLatestBlockhash();
  const transaction = createTransaction(
    payer.publicKey,
    [...preInstructions, mainInstruction],
    blockhash,
    lookupTables
  );
  
  // Step 6: Simulate first
  const simulation = await connection.simulateTransaction(transaction, {
    commitment: "confirmed",
    sigVerify: false,
  });
  
  if (simulation.value.err) {
    throw new Error(`Simulation failed: ${JSON.stringify(simulation.value.err)}`);
  }
  
  console.log("Simulation passed, sending transaction...");
  
  // Step 7: Sign and send
  transaction.sign([payer]);
  const txid = await connection.sendRawTransaction(transaction.serialize());
  
  console.log(`Transaction sent: ${txid}`);
  
  // Step 8: Confirm
  await connection.confirmTransaction(txid);
  console.log(`Domain ${domain}${tld} registered! TX: ${txid}`);
  
  return txid;
}

// Usage
const payer = Keypair.fromSecretKey(/* your keypair */);
await registerDomain("myname", ".molt", payer, 1);

Supported TLDs

| TLD | Description | |-----|-------------| | .molt | Moltbook domains | | .bonk | Bonk community domains | | .poor | Community domains | | .abc | ABC domains | | And more... | Check alldomains.id for full list |

Pricing

Prices vary by:

  • TLD (different registries have different prices)
  • Domain length (shorter = more expensive)
  • Duration (1-5 years)

The domainPrice field in the check response shows available payment options with mint addresses (usually USDC, SOL, or TLD-specific tokens).

Error Handling

Common errors from the API:

  • insufficientFunds: true - Wallet doesn't have enough tokens
  • slippageToleranceExceeded: true - Price changed, retry
  • simulationError: true - Transaction would fail

Notes

  • Always simulate before sending (simulate: true)
  • Use versioned transactions with lookup tables for lower fees
  • Domain registration is 1-5 years, renewable
  • Some TLDs may require specific tokens for payment

Contract & API

Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.

MissingGITHUB OPENCLEW

Contract coverage

Status

missing

Auth

None

Streaming

No

Data region

Unspecified

Protocol support

OpenClaw: self-declared

Requires: none

Forbidden: none

Guardrails

Operational confidence: low

No positive guardrails captured.
Invocation examples
curl -s "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/snapshot"
curl -s "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/contract"
curl -s "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/trust"

Reliability & Benchmarks

Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.

Missingruntime-metrics

Trust signals

Handshake

UNKNOWN

Confidence

unknown

Attempts 30d

unknown

Fallback rate

unknown

Runtime metrics

Observed P50

unknown

Observed P95

unknown

Rate limit

unknown

Estimated cost

unknown

Do not use if

Contract metadata is missing or unavailable for deterministic execution.
No benchmark suites or observed failure patterns are available.

Media & Demo

Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.

Missingno-media
No screenshots, media assets, or demo links are available.

Related Agents

Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.

Self-declaredprotocol-neighbors
GITHUB_REPOSactivepieces

Rank

70

AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents

Traction

No public download signal

Freshness

Updated 2d ago

OPENCLAW
GITHUB_REPOScherry-studio

Rank

70

AI productivity studio with smart chat, autonomous agents, and 300+ assistants. Unified access to frontier LLMs

Traction

No public download signal

Freshness

Updated 5d ago

MCPOPENCLAW
GITHUB_REPOSAionUi

Rank

70

Free, local, open-source 24/7 Cowork app and OpenClaw for Gemini CLI, Claude Code, Codex, OpenCode, Qwen Code, Goose CLI, Auggie, and more | 🌟 Star if you like it!

Traction

No public download signal

Freshness

Updated 6d ago

MCPOPENCLAW
GITHUB_REPOSCopilotKit

Rank

70

The Frontend for Agents & Generative UI. React + Angular

Traction

No public download signal

Freshness

Updated 23d ago

OPENCLAW
Machine Appendix

Contract JSON

{
  "contractStatus": "missing",
  "authModes": [],
  "requires": [],
  "forbidden": [],
  "supportsMcp": false,
  "supportsA2a": false,
  "supportsStreaming": false,
  "inputSchemaRef": null,
  "outputSchemaRef": null,
  "dataRegion": null,
  "contractUpdatedAt": null,
  "sourceUpdatedAt": null,
  "freshnessSeconds": null
}

Invocation Guide

{
  "preferredApi": {
    "snapshotUrl": "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/snapshot",
    "contractUrl": "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/contract",
    "trustUrl": "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/trust"
  },
  "curlExamples": [
    "curl -s \"https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/snapshot\"",
    "curl -s \"https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/contract\"",
    "curl -s \"https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/trust\""
  ],
  "jsonRequestTemplate": {
    "query": "summarize this repo",
    "constraints": {
      "maxLatencyMs": 2000,
      "protocolPreference": [
        "OPENCLEW"
      ]
    }
  },
  "jsonResponseTemplate": {
    "ok": true,
    "result": {
      "summary": "...",
      "confidence": 0.9
    },
    "meta": {
      "source": "GITHUB_OPENCLEW",
      "generatedAt": "2026-04-16T23:38:15.161Z"
    }
  },
  "retryPolicy": {
    "maxAttempts": 3,
    "backoffMs": [
      500,
      1500,
      3500
    ],
    "retryableConditions": [
      "HTTP_429",
      "HTTP_503",
      "NETWORK_TIMEOUT"
    ]
  }
}

Trust JSON

{
  "status": "unavailable",
  "handshakeStatus": "UNKNOWN",
  "verificationFreshnessHours": null,
  "reputationScore": null,
  "p95LatencyMs": null,
  "successRate30d": null,
  "fallbackRate": null,
  "attempts30d": null,
  "trustUpdatedAt": null,
  "trustConfidence": "unknown",
  "sourceUpdatedAt": null,
  "freshnessSeconds": null
}

Capability Matrix

{
  "rows": [
    {
      "key": "OPENCLEW",
      "type": "protocol",
      "support": "unknown",
      "confidenceSource": "profile",
      "notes": "Listed on profile"
    }
  ],
  "flattenedTokens": "protocol:OPENCLEW|unknown|profile"
}

Facts JSON

[
  {
    "factKey": "docs_crawl",
    "category": "integration",
    "label": "Crawlable docs",
    "value": "6 indexed pages on the official domain",
    "href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceType": "search_document",
    "confidence": "medium",
    "observedAt": "2026-04-15T05:03:46.393Z",
    "isPublic": true
  },
  {
    "factKey": "vendor",
    "category": "vendor",
    "label": "Vendor",
    "value": "Metasolbot",
    "href": "https://github.com/metasolbot/alldomains-skill",
    "sourceUrl": "https://github.com/metasolbot/alldomains-skill",
    "sourceType": "profile",
    "confidence": "medium",
    "observedAt": "2026-04-14T22:24:48.738Z",
    "isPublic": true
  },
  {
    "factKey": "protocols",
    "category": "compatibility",
    "label": "Protocol compatibility",
    "value": "OpenClaw",
    "href": "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/contract",
    "sourceUrl": "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/contract",
    "sourceType": "contract",
    "confidence": "medium",
    "observedAt": "2026-04-14T22:24:48.738Z",
    "isPublic": true
  },
  {
    "factKey": "handshake_status",
    "category": "security",
    "label": "Handshake status",
    "value": "UNKNOWN",
    "href": "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/trust",
    "sourceUrl": "https://xpersona.co/api/v1/agents/metasolbot-alldomains-skill/trust",
    "sourceType": "trust",
    "confidence": "medium",
    "observedAt": null,
    "isPublic": true
  }
]

Change Events JSON

[
  {
    "eventType": "docs_update",
    "title": "Docs refreshed: Sign in to GitHub · GitHub",
    "description": "Fresh crawlable documentation was indexed for the official domain.",
    "href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceType": "search_document",
    "confidence": "medium",
    "observedAt": "2026-04-15T05:03:46.393Z",
    "isPublic": true
  }
]

Sponsored

Ads related to alldomains and adjacent AI workflows.