mirror of
https://github.com/zyphlar/LanternPowerMonitor.git
synced 2024-03-08 14:07:47 +00:00
Add config flag for hubs to post to self-hosted server with a self-signed SSL certificate.
Support Raspberry Pi 2B by handling missing BLE controller and supporting 32-bit pigpio.
This commit is contained in:
@@ -2,7 +2,7 @@
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<artifactId>lantern-currentmonitor</artifactId>
|
||||
<packaging>jar</packaging>
|
||||
<version>1.1.1</version>
|
||||
<version>1.1.2</version>
|
||||
<name>lantern-currentmonitor</name>
|
||||
|
||||
<parent>
|
||||
|
||||
@@ -7,27 +7,38 @@ import com.lanternsoftware.currentmonitor.bluetooth.BleHelper;
|
||||
import com.lanternsoftware.currentmonitor.bluetooth.BleService;
|
||||
import com.lanternsoftware.datamodel.currentmonitor.HubConfigService;
|
||||
import com.lanternsoftware.util.CollectionUtils;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public class BluetoothConfig {
|
||||
private static final Logger LOG = LoggerFactory.getLogger(BluetoothConfig.class);
|
||||
private final BleApplication app;
|
||||
|
||||
public BluetoothConfig(String _hubName, BleCharacteristicListener _listener) {
|
||||
BleHelper.getAdapter().setPowered(true);
|
||||
BleHelper.requestBusName("com.lanternsoftware");
|
||||
BleHelper.setBasePath("/com/lanternsoftware");
|
||||
HubConfigService service = new HubConfigService();
|
||||
List<BleCharacteristic> chars = CollectionUtils.transform(service.getCharacteristics(), _c->new BleCharacteristic("HubConfig", _c.getUUID(), _c.name(), _c.getFlags()));
|
||||
chars.forEach(_c->_c.setListener(_listener));
|
||||
app = new BleApplication("Lantern", _hubName, new BleService("HubConfig", service.getServiceUUID(), chars));
|
||||
BleApplication a = null;
|
||||
try {
|
||||
BleHelper.getAdapter().setPowered(true);
|
||||
BleHelper.requestBusName("com.lanternsoftware");
|
||||
BleHelper.setBasePath("/com/lanternsoftware");
|
||||
List<BleCharacteristic> chars = CollectionUtils.transform(HubConfigService.getCharacteristics(), _c -> new BleCharacteristic("HubConfig", _c.getUUID(), _c.name(), _c.getFlags()));
|
||||
chars.forEach(_c -> _c.setListener(_listener));
|
||||
a = new BleApplication("Lantern", _hubName, new BleService("HubConfig", HubConfigService.getServiceUUID(), chars));
|
||||
}
|
||||
catch (Throwable _t) {
|
||||
LOG.error("Failed to initialize BLE service", _t);
|
||||
}
|
||||
app = a;
|
||||
}
|
||||
|
||||
public void start() {
|
||||
app.start();
|
||||
if (app != null)
|
||||
app.start();
|
||||
}
|
||||
|
||||
public void stop() {
|
||||
app.stop();
|
||||
if (app != null)
|
||||
app.stop();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -219,7 +219,7 @@ public class MonitorApp {
|
||||
config = new MonitorConfig();
|
||||
ResourceLoader.writeFile(WORKING_DIR + "config.json", DaoSerializer.toJson(config));
|
||||
}
|
||||
pool = new HttpPool(10, 10, config.getSocketTimeout(), config.getConnectTimeout(), config.getSocketTimeout());
|
||||
pool = HttpPool.builder().withValidateSSLCertificates(!config.isAcceptSelfSignedCertificates()).build();
|
||||
if (NullUtils.isNotEmpty(config.getHost()))
|
||||
host = NullUtils.terminateWith(config.getHost(), "/");
|
||||
monitor.setDebug(config.isDebug());
|
||||
|
||||
@@ -19,6 +19,7 @@ public class MonitorConfig {
|
||||
private int socketTimeout;
|
||||
private boolean postSamples = false;
|
||||
private boolean needsCalibration = true;
|
||||
private boolean acceptSelfSignedCertificates = false;
|
||||
private String mqttBrokerUrl;
|
||||
private String mqttUserName;
|
||||
private String mqttPassword;
|
||||
@@ -115,6 +116,14 @@ public class MonitorConfig {
|
||||
needsCalibration = _needsCalibration;
|
||||
}
|
||||
|
||||
public boolean isAcceptSelfSignedCertificates() {
|
||||
return acceptSelfSignedCertificates;
|
||||
}
|
||||
|
||||
public void setAcceptSelfSignedCertificates(boolean _acceptSelfSignedCertificates) {
|
||||
acceptSelfSignedCertificates = _acceptSelfSignedCertificates;
|
||||
}
|
||||
|
||||
public String getMqttBrokerUrl() {
|
||||
return mqttBrokerUrl;
|
||||
}
|
||||
|
||||
@@ -36,6 +36,7 @@ public class MonitorConfigSerializer extends AbstractDaoSerializer<MonitorConfig
|
||||
d.put("socket_timeout", _o.getSocketTimeout());
|
||||
d.put("post_samples", _o.isPostSamples());
|
||||
d.put("needs_calibration", _o.isNeedsCalibration());
|
||||
d.put("accept_self_signed_certificates", _o.isAcceptSelfSignedCertificates());
|
||||
d.put("mqtt_broker_url", _o.getMqttBrokerUrl());
|
||||
d.put("mqtt_user_name", _o.getMqttUserName());
|
||||
d.put("mqtt_password", _o.getMqttPassword());
|
||||
@@ -60,6 +61,7 @@ public class MonitorConfigSerializer extends AbstractDaoSerializer<MonitorConfig
|
||||
o.setSocketTimeout(DaoSerializer.getInteger(_d, "socket_timeout"));
|
||||
o.setPostSamples(DaoSerializer.getBoolean(_d, "post_samples"));
|
||||
o.setNeedsCalibration(DaoSerializer.getBoolean(_d, "needs_calibration"));
|
||||
o.setAcceptSelfSignedCertificates(DaoSerializer.getBoolean(_d, "accept_self_signed_certificates"));
|
||||
o.setMqttBrokerUrl(DaoSerializer.getString(_d, "mqtt_broker_url"));
|
||||
o.setMqttUserName(DaoSerializer.getString(_d, "mqtt_user_name"));
|
||||
o.setMqttPassword(DaoSerializer.getString(_d, "mqtt_password"));
|
||||
|
||||
Reference in New Issue
Block a user