This project provides a java wrapper over the Govee v1.0 API (https://developer.govee.com/ and https://govee-public.s3.amazonaws.com/developer-docs/GoveeDeveloperAPIReference.pdf).
It can be used to interface with govee lights or appliances, including the ability to subscribe to events from devices via MQTT.
See Govee getting starting document
Get an instance of the GoveeAPI object like GoveeApi.getInstance("API_KEY")
. This object can be stored and reused without fear of leaving open connections.
This object has methods for interacting with devices and appliances.
- Listing devices
List<GoveeDevice> devices = GoveeApi.getInstance(API_KEY).getDevices().getData();
- Getting status of a device:
GoveeDevice device = GoveeApi.getInstance(API_KEY)
.getDeviceStatus(TEST_SKU, TEST_DEVICEID)
.getDevice();
- Turning on a humidifier:
GoveeDeviceCommandResponse response = GoveeApi.getInstance(API_KEY)
.sendDeviceCommand(IHumidifierCommands.turnOn(TEST_MODEL, TEST_DEVICEID));
- Turning off a humidifier:
GoveeDeviceCommandResponse response = GoveeApi.getInstance(API_KEY)
.sendDeviceCommand(IHumidifierCommands.turnOff(TEST_MODEL, TEST_DEVICEID));
- Setting humidifier manual mode:
GoveeDeviceCommandResponse response = GoveeApi.getInstance(API_KEY)
.sendDeviceCommand(IHumidifierCommands.setManualHumidityMode(TEST_MODEL, TEST_DEVICEID, 1));
- Setting humidifier auto mode:
GoveeApi.getInstance(API_KEY)
.sendDeviceCommand(IHumidifierCommands.setAutoHumidityMode(TEST_MODEL, TEST_DEVICEID));
GoveeApi.getInstance(API_KEY)
.sendDeviceCommand(IHumidifierCommands.setAutoHumidityTargetPercent(TEST_MODEL, TEST_DEVICEID, 42));
- Subscribing to Govee events
GoveeApi.getInstance(API_KEY).subscribeToGoveeEvents(new GoveeEventSubscriber() {
@Override
public void messageReceived(GoveeEvent event) {
//TODO: do something with the received event
}
});
- Create an
application.properties
file in/src/test/resources/application.properties
- Add your api key into the file like
govee_api_key=[my secret api key]
- To run tests with a specific device, you'll need the device model number and the device id (available by calling the
getDevices
api)- Add the model like:
govee_device_sku=[device model]
- Add the deviceId like:
govee_device_id=[device id]
- Add the model like:
- Run
This library is available as a GitHub package and can be installed by adding to your pom.xml
<dependency>
<groupId>com.bigboxer23</groupId>
<artifactId>govee-java-api</artifactId>
<version>1.0.0</version>
</dependency>
Since it is a GitHub package, GitHub requires maven authenticate as a valid user to fetch from their package repository.
Instructions:
- Create
~/.m2/settings.xml
if it does not exist - Create a GitHub personal access token if you do not have one (
settings
->developer settings
->tokens classic
) - In below example need to update
username
to your own GitHub username. Updatepassword
to include your GitHub access token created in the previous step - Example file:
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 https://maven.apache.org/xsd/settings-1.0.0.xsd">
<localRepository />
<interactiveMode />
<usePluginRegistry />
<offline />
<pluginGroups />
<servers>
<server>
<id>github</id>
<username>[my username]</username>
<password>[my GH Access Token]</password>
</server>
</servers>
<mirrors />
<proxies />
</settings>