myUplink MCP 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., "@myUplink MCP Servershow me the outdoor temperature from my heat pump"
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.
myUplink MCP Server
A Model Context Protocol (MCP) server that connects Claude (or any MCP client) to your NIBE myUplink heat-pump account.
Features
Tool | What it does |
| Generate the OAuth2 login URL |
| Trade a one-time code for access + refresh tokens |
| Server-to-server auth (no browser required) |
| List all heat-pump systems in the account |
| Detail view of a single system |
| Firmware version, connection state, serial number |
| Read any/all sensor & setting values |
| Write new values (requires Premium + WRITESYSTEM scope) |
| Quick view of the most useful readings |
| Active alarms / notifications |
| Smart-home climate zones |
Related MCP server: Garmin MCP Server
Prerequisites
Node.js 18+
A myUplink account with at least one connected device
An OAuth2 application created at https://dev.myuplink.com/apps
Setup
git clone <this-repo>
cd myuplink-mcp
npm install
cp .env.example .env
# Edit .env – add your CLIENT_ID and CLIENT_SECRET
npm run buildRunning the server
npm start
# or during development:
npm run devClaude Desktop integration
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS):
{
"mcpServers": {
"myuplink": {
"command": "node",
"args": ["/absolute/path/to/myuplink-mcp/dist/index.js"],
"env": {
"MYUPLINK_CLIENT_ID": "your_client_id",
"MYUPLINK_CLIENT_SECRET": "your_client_secret",
"MYUPLINK_REFRESH_TOKEN": "optional_saved_refresh_token"
}
}
}
}First-time authentication (Authorization Code flow)
Call
get_authorization_url→ open the URL in a browserLog in and approve the scopes
Copy the
code=…value from the redirect URLCall
exchange_auth_codewith that codeFrom now on the server auto-refreshes tokens using the refresh token
No-browser alternative (Client Credentials)
If your myUplink application supports it, call authenticate_client_credentials – no browser needed, but only your own account data is accessible.
Common myUplink parameter IDs
Parameter | Description |
40004 | Outdoor temperature (BT1) |
40033 | Room temperature (BT50) |
40013 | Hot water top (BT7) |
43005 | Degree minutes |
43009 | Calculated flow temperature |
44270 | Compressor hours (heating) |
49994 | Priority (off / heating / hot water) |
Find more by calling get_device_points without a filter.
Scopes
Scope | Access |
| Read sensor data and settings |
| Change settings (requires Premium subscription) |
| Receive a refresh token for long-lived sessions |
License
MIT
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/kalmma/myUplink-MCP-Server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server