Aranet4 CO2 Monitor
STDIOMCP server to manage Aranet4 CO2 sensor and fetch data from device memory.
MCP server to manage Aranet4 CO2 sensor and fetch data from device memory.
MCP server to manage your Aranet4 CO2 sensor. Built upon Aranet4-Python.
[!TIP] For the standalone python version without MCP logic, see aranet4-archiver.
init aranet4
in your client to set up everything for the mcp server to work with your device.Clone repo:
git clone [email protected]:diegobit/aranet4-mcp-server.git`
cd aranet4-mcp-server
Prepare environment:
pyproject.toml
handles dependencied and virtual environments.pip install .
Add to MCP client configuration:
"aranet4": { "command": "{{PATH_TO_UV}}", // run `which uv` "args": [ "--directory", "{{PATH_TO_SRC}}/aranet4-mcp-server/", "run", "src/server.py" ] }
~/Library/Application Support/Claude/claude_desktop_config.json
~/.cursor/mcp.json
Configure:
init aranet4
to get a guided configuration.config.yaml
. You need to provide the mac address and the device name. You can get the mac address with aranetctl --scan
from Aranet4-Python (installed with this repo dependencies).Dockerfile is available. Remember to pass env variables or update config.yaml
.
Configuration and utils:
init_aranet4_config
: assisted configuration of device.scan_devices
: scan nearby bluetooth aranet4 devices.get_configuration_and_db_stats
: get current config.yaml and general stats from the local sqlite3 db.set_configuration
: set values in config.yaml.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.
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:
com.diegobit.aranet4-fetch.plist
.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.