A go library and simple tools for accessing the Ecobee Thermostat API.
The go-ecobee CLI is built with the underlying go-ecobee API, and serves as it's primary example.
go install -u github.com/rspier/go-ecobee`
go build main.go
# fully static binary
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o main
Obtain an Ecobee API Application ID at https://www.ecobee.com/consumerportal/index.html#/dev
You'll need to know the serial number (Thermostat ID) of your thermostat. You can find it on the About page of the Ecobee portal.
You can store your default thermostat id and appid in
~/.go-ecobee.yaml
or you can use the --thermostat
and --appid
flags to the CLI.
thermostat: <Thermostat ID>
appid: <App ID>
$ go-ecobee --command=status
Current Settings (Home): 68.0 - 75.0. Fan: auto
Holding at 68.0 - 75.0 (Fan: auto) until 2017-04-22 00:00:00
Temperature: 75.0
Bedroom\*: 74.7
My ecobee3\*: 76.2
$ go-ecobee hold --heat 70 --cool 76 --duration 10m
Successfully Held Temperature
$ go-ecobee message --message="Hi there!"
Successfully sent message: "Hi there!"
$ go-ecobee fan --duration=5m
Running fan for 5 minutes"
$ go-ecobee list
${THERMID}: My ecobee3
https://github.com/dominikh/go-tools
staticcheck ./ecobee/ ./cmd/ .
Use includeSensors on the thermostat endpoint to analyze sensors where the presence sensor may have failed -- i.e. present all the time.
This is not an official Google project.