CustomDomain
Learn how to configure and manage Custom Domains for your Cloudflare services (like Pages, Workers) using Alchemy.
The CustomDomain resource lets you attach a custom domain to a Cloudflare Worker.
Worker Domains
Section titled “Worker Domains”The simplest way to bind custom domains is directly on the Worker:
import { Worker } from "alchemy/cloudflare";
const worker = await Worker("api", {  name: "api-worker",  entrypoint: "./src/api.ts",  domains: ["api.example.com", "admin.example.com"],});
// Access the created domainsconsole.log(worker.domains); // Array of created CustomDomain resourcesWith additional options:
const worker = await Worker("api", {  name: "api-worker",  entrypoint: "./src/api.ts",  domains: [    {      domainName: "api.example.com",      zoneId: "YOUR_ZONE_ID", // Optional - will be inferred if not provided      adopt: true, // Adopt existing domain if it exists    },    "admin.example.com", // Zone ID will be inferred  ],});CustomDomain Resource
Section titled “CustomDomain Resource”You can also create custom domains independently:
import { Worker, CustomDomain } from "alchemy/cloudflare";
const worker = await Worker("api", {  name: "api-worker",  entrypoint: "./src/api.ts",});
const domain = await CustomDomain("api-domain", {  name: "api.example.com",  zoneId: "YOUR_ZONE_ID",  workerName: worker.name,});With Environment
Section titled “With Environment”Bind a domain to a specific worker environment:
import { Worker, CustomDomain } from "alchemy/cloudflare";
const domain = await CustomDomain("staging-domain", {  name: "staging.example.com",  zoneId: "YOUR_ZONE_ID",  workerName: "my-worker",  environment: "staging",});