# Create Web Page MCP server

Create, edit, preview, publish, and manage web pages from MCP-capable AI clients.

## Links
- Registry page: https://www.getdrio.com/mcp/com-create-web-page-create-web-page
- Repository: https://github.com/daniel-lopez-puig/landings
- Website: https://create-web-page.com/docs/mcp

## Install
- Endpoint: https://create-web-page.com/mcp
- Auth: Not captured

## Setup notes
- Remote endpoint: https://create-web-page.com/mcp

## Tools
- account.whoami (Current Account) - Return the current Create Web Page account context. Use this to check whether the user is authenticated or using an anonymous expiring demo. Endpoint: https://create-web-page.com/mcp
- page.intake.start (Start Landing Page Intake) - Quick minimal intake for first-page creation. Returns guided questions to collect business name, source link, primary visitor action, and locale. For a richer onboarding with layout and palette choices, use page.onboarding.start instead. Call once per creation request; do not repeat if the user has already provided a source URL. Does not create a page. Endpoint: https://create-web-page.com/mcp
- page.onboarding.start (Start Guided Page Onboarding) - Default first tool for first-page creation. Returns category choices, layout options, palette, primary action, recommended blocks, and a quality checklist without creating a page. Pass the returned selections to page.onboarding.update, then use createFromBriefHints with page.create_from_brief to build the page. Endpoint: https://create-web-page.com/mcp
- page.onboarding.update (Update Guided Page Onboarding) - Validate deterministic onboarding selections and return the next compact UI/prompt plus the remaining quality checklist. Use after page.onboarding.start as the user chooses category/subcategory, template style, palette, primary action, recommended blocks, desired path, and provides knownFields such as name, description, image availability, action destination, supporting links, and supporting content. Endpoint: https://create-web-page.com/mcp
- source.import (Import Public Source) - Fetch a public website URL and extract a structured brief with business name, description, contact links, and suggested page blocks. Only works with public HTTP/HTTPS pages. Does not bypass login, CAPTCHA, or paywalls. Returns extracted fields and suggestedBlocks for use with page.create_from_brief. Endpoint: https://create-web-page.com/mcp
- page.create (Create Landing Page) - Create a hosted link-in-bio page draft from a style preset. Provide title, displayName, and a preset (or 'auto' to infer from businessType/style). The page starts with empty placeholder blocks for you to fill in via block.update — do not invent content. This tool intentionally creates a draft only and does not return a publish action. After calling it, stop and show the preview URL. Do not call page.publish in the same turn unless the user's current message explicitly asks to publish, make the page live, or get a public share link. Anonymous demo pages expire unless claimed. Endpoint: https://create-web-page.com/mcp
- page.create_from_brief (Create Landing Page From Brief) - Create a hosted landing page draft from a structured brief. Accepts business name, category, layout, palette, primary action, explicit final-audience publicSections, and optional hero image. Planning fields such as audience, offer, primaryGoal, location, businessType, style, and mustInclude are context only and are not rendered as public body copy. Draft previews are customer-facing: do not pass owner instructions, section-planning labels, or placeholder copy as public content. Keep sparse briefs sparse: use only facts supplied by the user or imported public sources, plus light wording polish; do not invent menus, services, hours, facilities, locations, testimonials, guarantees, staff details, prices, or operational claims. Prefer one short section or no extra section when the prompt is minimal. If a requested CTA lacks its real destination, ask for it before creation or provide fallbackLeadForm with public copy. Returns a preview URL, edit token, and next-step hints. This tool intentionally creates a draft only and does not return a publish action. After calling it, stop and show the preview URL. Do not call page.publish in the same turn unless the user's current message explicitly asks to publish, make the page live, or get a public share link. Anonymous pages expire unless claimed via page.claim. Endpoint: https://create-web-page.com/mcp
- block.add (Add Content Block) - Append a new content block to a link-in-bio page. The block must match one of the 13 allowed types (link, social_row, whatsapp, phone_call, email_contact, image, gallery, video_embed, text, map_embed, product_card, lead_form, reviews) with that type's strict props. The server generates the block id and returns it in the response. For already-published pages, this saves an unpublished latest revision only. Do not call page.publish in the same assistant turn after this edit. Stop and tell the user the draft/preview was updated, then wait for a separate user message that explicitly asks to update the live link, publish, or make the changes public before calling page.publish. The response includes nextSteps: after adding a block, share these hints with the user so they know what else would make the page more complete. Endpoint: https://create-web-page.com/mcp
- layouts.list (List Available Layouts) - List supported page layouts. v1 ships link_in_bio only. Endpoint: https://create-web-page.com/mcp
- presets.list (List Style Presets) - List the 8 curated style presets (theme + starter blocks) for link-in-bio. Use to offer the user a choice or to confirm a preset:auto selection. Endpoint: https://create-web-page.com/mcp
- page.get (Get Landing Page) - Read a landing page draft, including its latest content JSON. For anonymous demo pages, include the editToken. Endpoint: https://create-web-page.com/mcp
- page.claim (Claim Demo Page) - Claim an anonymous demo page into the authenticated account using the pageId and editToken returned by page.create. Use this only when the user wants to keep or manage the website permanently. Endpoint: https://create-web-page.com/mcp
- account.pages.list (List Claimed Pages) - List landing pages claimed by the authenticated account. This requires OAuth and is for account management, not first-time demo creation. Endpoint: https://create-web-page.com/mcp
- account.page.manage (Manage Claimed Page) - Read a claimed account page without requiring an editToken. Use after OAuth when the user wants to manage a durable website. Endpoint: https://create-web-page.com/mcp
- page.header.update (Update Page Header) - Update the link-in-bio page header: displayName, bio, verified checkmark, and QR display. Use only the fields you want to change. For already-published pages, this saves an unpublished latest revision only. Do not call page.publish in the same assistant turn after this edit. Stop and tell the user the draft/preview was updated, then wait for a separate user message that explicitly asks to update the live link, publish, or make the changes public before calling page.publish. Endpoint: https://create-web-page.com/mcp
- page.theme.update (Update Page Theme) - Apply a partial theme patch. Theme fields are enum-constrained (button variant/radius/shadow, font family/weight, density, icon_size). Use presets.list first if the user wants a complete restyle. For already-published pages, this saves an unpublished latest revision only. Do not call page.publish in the same assistant turn after this edit. Stop and tell the user the draft/preview was updated, then wait for a separate user message that explicitly asks to update the live link, publish, or make the changes public before calling page.publish. Endpoint: https://create-web-page.com/mcp
- page.meta.update (Update Page Meta) - Update internal page title, URL slug, and SEO title/description. For already-published pages, this saves an unpublished latest revision only. Do not call page.publish in the same assistant turn after this edit. Stop and tell the user the draft/preview was updated, then wait for a separate user message that explicitly asks to update the live link, publish, or make the changes public before calling page.publish. Endpoint: https://create-web-page.com/mcp
- page.preview (Preview Landing Page) - Return the current preview URL for a page. Endpoint: https://create-web-page.com/mcp
- page.publish (Publish Landing Page) - Publish the latest page revision. Call this only when the user's latest message explicitly asks to publish, make the page live, or get a public share link. Do not call this immediately after page.create or page.create_from_brief just because the draft is publish-ready. For anonymous demo pages, include the editToken returned by page.create. The response includes nextSteps: always share these with the user after publishing — they include the claim reminder and any remaining improvements. Endpoint: https://create-web-page.com/mcp
- page.unpublish (Unpublish Landing Page) - Remove a published landing page from public availability while keeping its draft and revision history. Endpoint: https://create-web-page.com/mcp
- block.update (Update Landing Page Block) - Patch one content block by stable blockId. Provide a props patch (merged into existing props) and/or a new type. Block types and props are validated against the strict per-type schema. For already-published pages, this saves an unpublished latest revision only. Do not call page.publish in the same assistant turn after this edit. Stop and tell the user the draft/preview was updated, then wait for a separate user message that explicitly asks to update the live link, publish, or make the changes public before calling page.publish. Endpoint: https://create-web-page.com/mcp
- block.delete (Delete Landing Page Block) - Delete one block by stable blockId. Use page.get first if unsure which id to remove. For already-published pages, this saves an unpublished latest revision only. Do not call page.publish in the same assistant turn after this edit. Stop and tell the user the draft/preview was updated, then wait for a separate user message that explicitly asks to update the live link, publish, or make the changes public before calling page.publish. Endpoint: https://create-web-page.com/mcp
- block.reorder (Reorder Landing Page Block) - Move a block to a new zero-based index in the page main slot. For already-published pages, this saves an unpublished latest revision only. Do not call page.publish in the same assistant turn after this edit. Stop and tell the user the draft/preview was updated, then wait for a separate user message that explicitly asks to update the live link, publish, or make the changes public before calling page.publish. Endpoint: https://create-web-page.com/mcp

## Resources
- ui://widget/landing-actions-v1.html - Landing page actions MIME type: text/html;profile=mcp-app

## Prompts
Not captured

## Metadata
- Owner: com.create-web-page
- Version: 0.1.0
- Runtime: Streamable Http
- Transports: HTTP
- License: Not captured
- Language: Not captured
- Stars: Not captured
- Updated: May 27, 2026
- Source: https://registry.modelcontextprotocol.io
