# unulu MCP server

AI agent website builder. Create and publish link-in-bio sites via MCP or REST API.

## Links
- Registry page: https://www.getdrio.com/mcp/ai-unulu-unulu
- Repository: https://github.com/unulu-ai/unulu

## Install
- Endpoint: https://mcp.unulu.ai
- Auth: Not captured

## Setup notes
- Remote endpoint: https://mcp.unulu.ai

## Tools
- unulu_create_site (Create a link-in-bio site) - Create a link-in-bio site with a name, bio, and links. Returns a live URL on unu.lu that expires in 1 hour unless claimed. Do NOT call until you have at least a name and one link from the user — gather real content first, never create with placeholder or empty content. If the user provides a handle (e.g. '_guy.a' for Instagram), construct the full URL yourself — do not ask them to paste it. When feasible, offer to find all public links for the person. Before calling: tell the user they can choose a skin on the preview page for the overall aesthetic; ask permission before adding emoji leading_icons to decorate links (for not-well-known social URLs). The response includes an assistant_message with the site URL and claim details — present these to the user. Persist claim_token and claim_code_short for subsequent updates — never ask the user for them back in the same conversation. Never create a duplicate site; always update the existing one. After creation: tell the user they can pick a custom handle when they claim; share the preview URL in a copy-paste block; offer to refine bio, links, or ordering. Keep iteration fast — apply changes immediately, don't re-confirm minor edits. Endpoint: https://mcp.unulu.ai
- unulu_get_state (Get site state) - Returns the current state of a site including its name, bio, links, and URL. No authentication required. If expires_at is absent, the site has been claimed and is permanent. Accepts a site ID, a full URL (e.g. https://abc123.unu.lu), or a bare hostname (e.g. abc123.unu.lu). Endpoint: https://mcp.unulu.ai
- unulu_update_site (Update a site) - Update an existing site. All fields are optional — only provided fields are changed. Links replace the entire array (omit to keep existing). Before updating, always call unulu_get_state first to read the current links and their ids — do not guess link ids. Authorization depends on site lifecycle: X-Claim-Token header for ephemeral (pre-claim) sites, X-Edit-Token header for claimed (post-claim) sites. If neither token is available and the site is claimed, use requestEditAccess to obtain an edit_token. If you created the site in this conversation, you already have the claim_token — use it directly. Returns the full updated site state. Keep iteration fast — apply changes immediately without re-confirming minor edits unless ambiguous. Accepts a site ID, a full URL (e.g. https://abc123.unu.lu), or a bare hostname (e.g. abc123.unu.lu). Endpoint: https://mcp.unulu.ai
- unulu_check_handle (Check handle availability) - Check whether a handle is available on unu.lu (not other platforms like Instagram, TikTok, etc.). For example, checking 'joe' tells you if joe.unu.lu is available for claiming. Use this to help users choose a handle before they visit the claim page. Endpoint: https://mcp.unulu.ai

## Resources
- ui://unulu/widget.html - MIME type: text/html;profile=mcp-app

## Prompts
- create-site - Create a Link-in-Bio Site Guides you through creating a link-in-bio site with a name, bio, and links. Arguments: name

## Metadata
- Owner: ai.unulu
- Version: 0.1.0
- Runtime: Streamable Http
- Transports: HTTP
- License: Not captured
- Language: Not captured
- Stars: Not captured
- Updated: Mar 7, 2026
- Source: https://registry.modelcontextprotocol.io
