MCP Hello World Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@MCP Hello World Serversay hello"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Hello World App
A minimal MCP App boilerplate: a single Node/TypeScript MCP server that
exposes one tool (say_hello) and serves a tiny Angular UI as an
MCP App resource.
It mirrors the architecture of the parent invoice-preview-mcp-app project,
stripped down to a "Hello World".
Architecture
MCP Host (e.g. Cursor)
│ calls tool say_hello
▼
Express server (:8080)
├─ POST/GET/DELETE /mcp → MCP Streamable HTTP transport
├─ MCP resource → ui://hello-world/app (inlined Angular HTML)
├─ GET /ui/* → HTTP fallback for assets
└─ GET /healthz
▲
│ build pipeline
ng build → scripts/inline-bundle.mjs (CSS + JS inlined into one HTML)When the agent calls say_hello, the tool result carries
_meta.ui.resourceUri = "ui://hello-world/app", which tells the host to open
the Angular UI in an iframe. Inside the iframe the UI calls say_hello again
through the MCP bridge (postMessage, with an HTTP fallback to /mcp).
Related MCP server: Hello World MCP FastAPI Endpoint
Project layout
├── package.json # npm workspaces: server + ui
├── tsconfig.base.json
├── scripts/inline-bundle.mjs # inlines the Angular build for MCP iframes
├── .cursor/mcp.json # points Cursor at http://127.0.0.1:8080/mcp
├── server/ # MCP + Express server (TypeScript)
│ └── src/
│ ├── index.ts # entry point
│ ├── core/
│ │ ├── config/server-env.ts # env parsing
│ │ ├── http/ # Express app + CORS
│ │ ├── infrastructure/ # base-url / CSP helpers
│ │ └── mcp/ # server factory, transport, tool registry
│ ├── tools/ # one folder per MCP tool
│ │ └── say-hello/ # register-say-hello.ts + schemas
│ └── ui/ # MCP App resource + HTTP fallback
└── ui/ # Angular Hello World UIAdding a new tool
Create
server/src/tools/<your-tool>/register-<your-tool>.ts(plus a*.schemas.tsif it takes input).Add its registrar to the array in
server/src/core/mcp/tool-registry.ts.
Getting started
npm install
npm run build # builds the server (tsc) and the UI (ng build + inline)
npm start # node server/dist/index.js → http://localhost:8080Then add .cursor/mcp.json to your Cursor MCP config (or copy the
hello-world-local entry), and ask the agent to run the say_hello tool.
Key conventions
Convention | Why |
MIME | Required by the MCP Apps spec |
| Stable asset filenames for resource serving |
| Relative paths inside the iframe |
inline-bundle script | MCP iframes often block external script fetches |
| Tells the host which UI to open |
CORS on | The iframe has a null/opaque origin |
| Enables the HTTP tool-call fallback |
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/9kubczas4/mcp-app-angular-boilerplate'
If you have feedback or need assistance with the MCP directory API, please join our Discord server