mirror of
https://github.com/bwssytems/ha-bridge.git
synced 2025-12-18 16:17:30 +00:00
102 lines
3.8 KiB
Java
102 lines
3.8 KiB
Java
package com.bwssystems.HABridge.plugins.http;
|
|
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import com.bwssystems.HABridge.BridgeSettings;
|
|
import com.bwssystems.HABridge.Home;
|
|
import com.bwssystems.HABridge.api.CallItem;
|
|
import com.bwssystems.HABridge.api.NameValue;
|
|
import com.bwssystems.HABridge.api.hue.HueError;
|
|
import com.bwssystems.HABridge.api.hue.HueErrorResponse;
|
|
import com.bwssystems.HABridge.dao.DeviceDescriptor;
|
|
import com.bwssystems.HABridge.hue.BrightnessDecode;
|
|
import com.bwssystems.HABridge.hue.DeviceDataDecode;
|
|
import com.bwssystems.HABridge.hue.MultiCommandUtil;
|
|
import com.bwssystems.HABridge.hue.TimeDecode;
|
|
import com.google.gson.Gson;
|
|
|
|
public class HTTPHome implements Home {
|
|
private static final Logger log = LoggerFactory.getLogger(HTTPHome.class);
|
|
private HTTPHandler anHttpHandler;
|
|
|
|
public HTTPHome(BridgeSettings bridgeSettings) {
|
|
super();
|
|
createHome(bridgeSettings);
|
|
}
|
|
|
|
@Override
|
|
public String deviceHandler(CallItem anItem, MultiCommandUtil aMultiUtil, String lightId, int intensity,
|
|
Integer targetBri,Integer targetBriInc, DeviceDescriptor device, String body) {
|
|
String responseString = null;
|
|
|
|
String theUrl = anItem.getItem().getAsString();
|
|
if(theUrl != null && !theUrl.isEmpty () && (theUrl.startsWith("http://") || theUrl.startsWith("https://"))) {
|
|
//Backwards Compatibility Items
|
|
if(anItem.getHttpVerb() == null || anItem.getHttpVerb().isEmpty())
|
|
{
|
|
if(device.getHttpVerb() != null && !device.getHttpVerb().isEmpty())
|
|
anItem.setHttpVerb(device.getHttpVerb());
|
|
}
|
|
|
|
if(anItem.getHttpHeaders() == null || anItem.getHttpHeaders().isEmpty()) {
|
|
if(device.getHeaders() != null && !device.getHeaders().isEmpty() )
|
|
anItem.setHttpHeaders(device.getHeaders());
|
|
}
|
|
|
|
log.debug("executing HUE api request to Http "
|
|
+ (anItem.getHttpVerb() == null ? "GET" : anItem.getHttpVerb()) + ": "
|
|
+ anItem.getItem().getAsString());
|
|
|
|
String anUrl = BrightnessDecode.calculateReplaceIntensityValue(theUrl,
|
|
intensity, targetBri, targetBriInc, false);
|
|
anUrl = DeviceDataDecode.replaceDeviceData(anUrl, device);
|
|
anUrl = TimeDecode.replaceTimeValue(anUrl);
|
|
|
|
String aBody = null;
|
|
if(anItem.getHttpBody()!= null && !anItem.getHttpBody().isEmpty()) {
|
|
aBody = BrightnessDecode.calculateReplaceIntensityValue(anItem.getHttpBody(),
|
|
intensity, targetBri, targetBriInc, false);
|
|
aBody = DeviceDataDecode.replaceDeviceData(aBody, device);
|
|
aBody = TimeDecode.replaceTimeValue(aBody);
|
|
}
|
|
// make call
|
|
if (anHttpHandler.doHttpRequest(anUrl, anItem.getHttpVerb(), anItem.getContentType(), aBody,
|
|
new Gson().fromJson(anItem.getHttpHeaders(), NameValue[].class)) == null) {
|
|
log.warn("Error on calling url to change device state: " + anUrl);
|
|
responseString = new Gson().toJson(HueErrorResponse.createResponse("6", "/lights/" + lightId,
|
|
"Error on calling url to change device state", "/lights/"
|
|
+ lightId + "state", null, null).getTheErrors(), HueError[].class);
|
|
}
|
|
} else {
|
|
log.warn("HTTP Call to be presented as http(s)://<ip_address>(:<port>)/payload, format of request unknown: " + theUrl);
|
|
responseString = new Gson().toJson(HueErrorResponse.createResponse("6", "/lights/" + lightId,
|
|
"Error on calling url to change device state", "/lights/"
|
|
+ lightId + "state", null, null).getTheErrors(), HueError[].class);
|
|
}
|
|
|
|
return responseString;
|
|
}
|
|
|
|
@Override
|
|
public Home createHome(BridgeSettings bridgeSettings) {
|
|
anHttpHandler = new HTTPHandler();
|
|
log.info("Http Home created.");
|
|
return this;
|
|
}
|
|
|
|
@Override
|
|
public Object getItems(String type) {
|
|
// Not a resource
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public void closeHome() {
|
|
if(anHttpHandler != null)
|
|
anHttpHandler.closeHandler();
|
|
anHttpHandler = null;
|
|
}
|
|
|
|
}
|