aranet4-mcp-server
SImple MCP server to manage your aranet4 device and local db.
diegobit
README
aranet4-mcp-server
MCP server to manage your Aranet4 CO2 sensor. Built upon Aranet4-Python.
[!TIP] For the standalone python version without MCP logic, see aranet4-archiver.
Features:
- Scan for nearby devices.
- Fetch new data from embedded device memory and save to a local sqlite db for tracking and later viewing. For automatic updates, see at the bottom.
- Ask questions about recent measurements or about a specific past date.
- [For MCP clients that support images] Ask data to be plotted to also have a nice visualization!
- Assisted configuration! 💫 After installation, just ask
init aranet4
in your client to set up everything for the mcp server to work with your device.
Installation
-
Clone repo:
git clone git@github.com:diegobit/aranet4-mcp-server.git` cd aranet4-mcp-server
-
Prepare environment:
- Recommended (with uv): Nothing to do. The provided
pyproject.toml
handles dependencied and virtual environments. - Alternative (with pip): install with
pip install .
- Recommended (with uv): Nothing to do. The provided
-
Add to MCP client configuration:
"aranet4": { "command": "{{PATH_TO_UV}}", // run `which uv` "args": [ "--directory", "{{PATH_TO_SRC}}/aranet4-mcp-server/", "run", "server.py" ] }
- Claude Desktop MacOS config file path:
~/Library/Application Support/Claude/claude_desktop_config.json
- Cursor MacOS config file path:
~/.cursor/mcp.json
- Claude Desktop MacOS config file path:
-
Configure:
- Recommended (AI assisted config!): start your client and ask
init aranet4
to get a guided configuration. - Alternative (manual): edit file
config.yaml
. You need to provide the mac address and the device name. You can get the mac address witharanetctl --scan
from Aranet4-Python (installed with this repo dependencies).
- Recommended (AI assisted config!): start your client and ask
List of tools
Configuration and utils:
init_aranet4_config
: assisted configuration of device.scan_devices
: scan nearby bluetooth aranet4 devices.get_configuration
: get current config.yaml.set_configuration
: set values in config.yaml.get_database_stats
: get general stats from the local sqlite3 db.
To update historical data:
fetch_new_data
: fetch new data from configured nearby aranet4 device and save to local db.
To query historical data:
-
get_recent_data
: get recent data from local db. Can specify how many measurements. -
get_data_by_timerange
: get data in specific timerange from local db. Can specify how many measurements (careful, if the range is big and the limit is low, datapoints will be skipped).For both, ask to receive a plot to have it generated and displayed.
Automatic data fetch job
If you want your local db to always be updated, you can setup a cronjob or a launch agent that fetches data automatically every few hours. In MacOS, do as follows:
- Configure absolute paths in
com.diegobit.aranet4-fetch.plist
. - Install LaunchAgent:
cp com.diegobit.aranet4-fetch.plist ~/Library/LaunchAgents/ launchctl load ~/Library/LaunchAgents/com.diegobit.aranet4-fetch.plist
For other platforms, just run fetch-job.py
periodically however you prefer.
Recommended Servers
Crypto Price & Market Analysis MCP Server
A Model Context Protocol (MCP) server that provides comprehensive cryptocurrency analysis using the CoinCap API. This server offers real-time price data, market analysis, and historical trends through an easy-to-use interface.
MCP PubMed Search
Server to search PubMed (PubMed is a free, online database that allows users to search for biomedical and life sciences literature). I have created on a day MCP came out but was on vacation, I saw someone post similar server in your DB, but figured to post mine.
dbt Semantic Layer MCP Server
A server that enables querying the dbt Semantic Layer through natural language conversations with Claude Desktop and other AI assistants, allowing users to discover metrics, create queries, analyze data, and visualize results.
mixpanel
Connect to your Mixpanel data. Query events, retention, and funnel data from Mixpanel analytics.

Sequential Thinking MCP Server
This server facilitates structured problem-solving by breaking down complex issues into sequential steps, supporting revisions, and enabling multiple solution paths through full MCP integration.

Nefino MCP Server
Provides large language models with access to news and information about renewable energy projects in Germany, allowing filtering by location, topic (solar, wind, hydrogen), and date range.
Vectorize
Vectorize MCP server for advanced retrieval, Private Deep Research, Anything-to-Markdown file extraction and text chunking.
Mathematica Documentation MCP server
A server that provides access to Mathematica documentation through FastMCP, enabling users to retrieve function documentation and list package symbols from Wolfram Mathematica.
kb-mcp-server
An MCP server aimed to be portable, local, easy and convenient to support semantic/graph based retrieval of txtai "all in one" embeddings database. Any txtai embeddings db in tar.gz form can be loaded
Research MCP Server
The server functions as an MCP server to interact with Notion for retrieving and creating survey data, integrating with the Claude Desktop Client for conducting and reviewing surveys.