mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
Debugging
Signed-off-by: clinique <gael@lhopital.org>
This commit is contained in:
parent
c399be7a43
commit
ed2a6d5700
@ -22,9 +22,12 @@ import java.util.Optional;
|
|||||||
|
|
||||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||||
import org.openhab.binding.gce.internal.model.M2MMessageParser;
|
import org.openhab.binding.gce.internal.model.M2MMessageParser;
|
||||||
|
import org.openhab.binding.gce.internal.model.StatusFile;
|
||||||
|
import org.openhab.binding.gce.internal.model.StatusFileAccessor;
|
||||||
import org.openhab.core.thing.ThingUID;
|
import org.openhab.core.thing.ThingUID;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The {@link Ipx800DeviceConnector} is responsible for connecting,
|
* The {@link Ipx800DeviceConnector} is responsible for connecting,
|
||||||
@ -44,6 +47,7 @@ public class Ipx800DeviceConnector extends Thread {
|
|||||||
private final String hostname;
|
private final String hostname;
|
||||||
private final int portNumber;
|
private final int portNumber;
|
||||||
private final M2MMessageParser messageParser;
|
private final M2MMessageParser messageParser;
|
||||||
|
private final StatusFileAccessor statusAccessor;
|
||||||
|
|
||||||
private Optional<Socket> socket = Optional.empty();
|
private Optional<Socket> socket = Optional.empty();
|
||||||
private Optional<BufferedReader> input = Optional.empty();
|
private Optional<BufferedReader> input = Optional.empty();
|
||||||
@ -57,6 +61,7 @@ public class Ipx800DeviceConnector extends Thread {
|
|||||||
this.hostname = hostname;
|
this.hostname = hostname;
|
||||||
this.portNumber = portNumber;
|
this.portNumber = portNumber;
|
||||||
this.messageParser = new M2MMessageParser(this, listener);
|
this.messageParser = new M2MMessageParser(this, listener);
|
||||||
|
this.statusAccessor = new StatusFileAccessor(hostname);
|
||||||
setDaemon(true);
|
setDaemon(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -187,4 +192,8 @@ public class Ipx800DeviceConnector extends Thread {
|
|||||||
public M2MMessageParser getParser() {
|
public M2MMessageParser getParser() {
|
||||||
return messageParser;
|
return messageParser;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public StatusFile readStatusFile() throws SAXException, IOException {
|
||||||
|
return statusAccessor.read();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -37,7 +37,6 @@ import org.openhab.binding.gce.internal.config.RelayOutputConfiguration;
|
|||||||
import org.openhab.binding.gce.internal.model.PortData;
|
import org.openhab.binding.gce.internal.model.PortData;
|
||||||
import org.openhab.binding.gce.internal.model.PortDefinition;
|
import org.openhab.binding.gce.internal.model.PortDefinition;
|
||||||
import org.openhab.binding.gce.internal.model.StatusFile;
|
import org.openhab.binding.gce.internal.model.StatusFile;
|
||||||
import org.openhab.binding.gce.internal.model.StatusFileAccessor;
|
|
||||||
import org.openhab.core.config.core.Configuration;
|
import org.openhab.core.config.core.Configuration;
|
||||||
import org.openhab.core.library.CoreItemFactory;
|
import org.openhab.core.library.CoreItemFactory;
|
||||||
import org.openhab.core.library.types.DecimalType;
|
import org.openhab.core.library.types.DecimalType;
|
||||||
@ -61,7 +60,6 @@ import org.openhab.core.types.State;
|
|||||||
import org.openhab.core.types.UnDefType;
|
import org.openhab.core.types.UnDefType;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.w3c.dom.Node;
|
|
||||||
import org.xml.sax.SAXException;
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -76,13 +74,11 @@ public class Ipx800v3Handler extends BaseThingHandler implements Ipx800EventList
|
|||||||
private static final double ANALOG_SAMPLING = 0.000050354;
|
private static final double ANALOG_SAMPLING = 0.000050354;
|
||||||
|
|
||||||
private final Logger logger = LoggerFactory.getLogger(Ipx800v3Handler.class);
|
private final Logger logger = LoggerFactory.getLogger(Ipx800v3Handler.class);
|
||||||
|
|
||||||
private Optional<Ipx800DeviceConnector> connector = Optional.empty();
|
|
||||||
private Optional<ScheduledFuture<?>> refreshJob = Optional.empty();
|
|
||||||
private Optional<StatusFileAccessor> statusConnector = Optional.empty();
|
|
||||||
|
|
||||||
private final Map<String, PortData> portDatas = new HashMap<>();
|
private final Map<String, PortData> portDatas = new HashMap<>();
|
||||||
|
|
||||||
|
private @Nullable Ipx800DeviceConnector deviceConnector;
|
||||||
|
private Optional<ScheduledFuture<?>> refreshJob = Optional.empty();
|
||||||
|
|
||||||
private class LongPressEvaluator implements Runnable {
|
private class LongPressEvaluator implements Runnable {
|
||||||
private final Instant referenceTime;
|
private final Instant referenceTime;
|
||||||
private final String port;
|
private final String port;
|
||||||
@ -114,9 +110,7 @@ public class Ipx800v3Handler extends BaseThingHandler implements Ipx800EventList
|
|||||||
|
|
||||||
Ipx800Configuration config = getConfigAs(Ipx800Configuration.class);
|
Ipx800Configuration config = getConfigAs(Ipx800Configuration.class);
|
||||||
|
|
||||||
statusConnector = Optional.of(new StatusFileAccessor(config.hostname));
|
deviceConnector = new Ipx800DeviceConnector(config.hostname, config.portNumber, getThing().getUID(), this);
|
||||||
connector = Optional
|
|
||||||
.of(new Ipx800DeviceConnector(config.hostname, config.portNumber, getThing().getUID(), this));
|
|
||||||
|
|
||||||
updateStatus(ThingStatus.UNKNOWN);
|
updateStatus(ThingStatus.UNKNOWN);
|
||||||
|
|
||||||
@ -125,32 +119,42 @@ public class Ipx800v3Handler extends BaseThingHandler implements Ipx800EventList
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void readStatusFile() {
|
private void readStatusFile() {
|
||||||
|
if (deviceConnector instanceof Ipx800DeviceConnector connector) {
|
||||||
StatusFile status = null;
|
StatusFile status = null;
|
||||||
try {
|
try {
|
||||||
status = statusConnector.get().read();
|
status = connector.readStatusFile();
|
||||||
for (PortDefinition portDefinition : PortDefinition.values()) {
|
|
||||||
List<Node> nodes = status.getMatchingNodes(portDefinition.nodeName);
|
|
||||||
nodes.forEach(node -> {
|
|
||||||
String sPortNum = node.getNodeName().replace(portDefinition.nodeName, "");
|
|
||||||
int portNum = Integer.parseInt(sPortNum) + 1;
|
|
||||||
double value = Double.parseDouble(node.getTextContent().replace("dn", "1").replace("up", "0"));
|
|
||||||
dataReceived("%s%d".formatted(portDefinition.portName, portNum), value);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
} catch (SAXException | IOException e) {
|
} catch (SAXException | IOException e) {
|
||||||
logger.warn("Unable to read status file for {}", thing.getUID());
|
logger.warn("Unable to read status file for {}", thing.getUID());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Thread.State.NEW.equals(connector.get().getState())) {
|
if (Thread.State.NEW.equals(connector.getState())) {
|
||||||
setProperties(status);
|
setProperties(status);
|
||||||
updateChannels(status);
|
updateChannels(status);
|
||||||
connector.get().start();
|
connector.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status != null) {
|
||||||
|
for (PortDefinition portDefinition : PortDefinition.values()) {
|
||||||
|
status.getMatchingNodes(portDefinition.nodeName).forEach(node -> {
|
||||||
|
String sPortNum = node.getNodeName().replace(portDefinition.nodeName, "");
|
||||||
|
try {
|
||||||
|
int portNum = Integer.parseInt(sPortNum) + 1;
|
||||||
|
double value = Double
|
||||||
|
.parseDouble(node.getTextContent().replace("dn", "1").replace("up", "0"));
|
||||||
|
dataReceived("%s%d".formatted(portDefinition.portName, portNum), value);
|
||||||
|
} catch (NumberFormatException e) {
|
||||||
|
logger.warn(e.getMessage());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateChannels(@Nullable StatusFile status) {
|
private void updateChannels(@Nullable StatusFile status) {
|
||||||
List<Channel> channels = new ArrayList<>(getThing().getChannels());
|
List<Channel> channels = new ArrayList<>(getThing().getChannels());
|
||||||
PortDefinition.AS_STREAM.forEach(portDefinition -> {
|
PortDefinition.AS_SET.forEach(portDefinition -> {
|
||||||
int nbElements = status != null ? status.getMaxNumberofNodeType(portDefinition) : portDefinition.quantity;
|
int nbElements = status != null ? status.getMaxNumberofNodeType(portDefinition) : portDefinition.quantity;
|
||||||
for (int i = 0; i < nbElements; i++) {
|
for (int i = 0; i < nbElements; i++) {
|
||||||
ChannelUID portChannelUID = createChannels(portDefinition, i, channels);
|
ChannelUID portChannelUID = createChannels(portDefinition, i, channels);
|
||||||
@ -161,7 +165,7 @@ public class Ipx800v3Handler extends BaseThingHandler implements Ipx800EventList
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void setProperties(@Nullable StatusFile status) {
|
private void setProperties(@Nullable StatusFile status) {
|
||||||
Map<String, String> properties = thing.getProperties();
|
Map<String, String> properties = new HashMap<>(thing.getProperties());
|
||||||
properties.put(Thing.PROPERTY_VENDOR, "GCE Electronics");
|
properties.put(Thing.PROPERTY_VENDOR, "GCE Electronics");
|
||||||
if (status != null) {
|
if (status != null) {
|
||||||
properties.put(Thing.PROPERTY_FIRMWARE_VERSION, status.getVersion());
|
properties.put(Thing.PROPERTY_FIRMWARE_VERSION, status.getVersion());
|
||||||
@ -175,14 +179,14 @@ public class Ipx800v3Handler extends BaseThingHandler implements Ipx800EventList
|
|||||||
refreshJob.ifPresent(job -> job.cancel(true));
|
refreshJob.ifPresent(job -> job.cancel(true));
|
||||||
refreshJob = Optional.empty();
|
refreshJob = Optional.empty();
|
||||||
|
|
||||||
connector.ifPresent(Ipx800DeviceConnector::dispose);
|
if (deviceConnector instanceof Ipx800DeviceConnector connector) {
|
||||||
connector = Optional.empty();
|
connector.dispose();
|
||||||
|
connector = null;
|
||||||
|
}
|
||||||
|
|
||||||
portDatas.values().stream().forEach(PortData::dispose);
|
portDatas.values().stream().forEach(PortData::dispose);
|
||||||
portDatas.clear();
|
portDatas.clear();
|
||||||
|
|
||||||
statusConnector = Optional.empty();
|
|
||||||
|
|
||||||
super.dispose();
|
super.dispose();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -357,10 +361,11 @@ public class Ipx800v3Handler extends BaseThingHandler implements Ipx800EventList
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (command instanceof OnOffType onOffCommand && isValidPortId(channelUID)
|
if (command instanceof OnOffType onOffCommand && isValidPortId(channelUID)
|
||||||
&& PortDefinition.fromGroupId(groupId) == PortDefinition.RELAY) {
|
&& PortDefinition.fromGroupId(groupId) == PortDefinition.RELAY
|
||||||
|
&& deviceConnector instanceof Ipx800DeviceConnector connector) {
|
||||||
RelayOutputConfiguration config = channel.getConfiguration().as(RelayOutputConfiguration.class);
|
RelayOutputConfiguration config = channel.getConfiguration().as(RelayOutputConfiguration.class);
|
||||||
String id = channelUID.getIdWithoutGroup();
|
String id = channelUID.getIdWithoutGroup();
|
||||||
connector.ifPresent(p -> p.getParser().setOutput(id, onOffCommand == OnOffType.ON ? 1 : 0, config.pulse));
|
connector.getParser().setOutput(id, onOffCommand == OnOffType.ON ? 1 : 0, config.pulse);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
logger.debug("Can not handle command '{}' on channel '{}'", command, channelUID);
|
logger.debug("Can not handle command '{}' on channel '{}'", command, channelUID);
|
||||||
@ -371,11 +376,15 @@ public class Ipx800v3Handler extends BaseThingHandler implements Ipx800EventList
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void resetCounter(int counter) {
|
public void resetCounter(int counter) {
|
||||||
connector.ifPresent(p -> p.getParser().resetCounter(counter));
|
if (deviceConnector instanceof Ipx800DeviceConnector connector) {
|
||||||
|
connector.getParser().resetCounter(counter);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void reset() {
|
public void reset() {
|
||||||
connector.ifPresent(p -> p.getParser().resetPLC());
|
if (deviceConnector instanceof Ipx800DeviceConnector connector) {
|
||||||
|
connector.getParser().resetPLC();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
*/
|
*/
|
||||||
package org.openhab.binding.gce.internal.model;
|
package org.openhab.binding.gce.internal.model;
|
||||||
|
|
||||||
import java.util.stream.Stream;
|
import java.util.EnumSet;
|
||||||
|
|
||||||
import org.eclipse.jdt.annotation.NonNullByDefault;
|
import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||||
|
|
||||||
@ -41,7 +41,7 @@ public enum PortDefinition {
|
|||||||
this.quantity = quantity;
|
this.quantity = quantity;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final Stream<PortDefinition> AS_STREAM = Stream.of(PortDefinition.values());
|
public static final EnumSet<PortDefinition> AS_SET = EnumSet.allOf(PortDefinition.class);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
@ -53,11 +53,11 @@ public enum PortDefinition {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static PortDefinition fromM2MCommand(String m2mCommand) {
|
public static PortDefinition fromM2MCommand(String m2mCommand) {
|
||||||
return AS_STREAM.filter(v -> m2mCommand.startsWith(v.m2mCommand)).findFirst().get();
|
return AS_SET.stream().filter(v -> m2mCommand.startsWith(v.m2mCommand)).findFirst().get();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static PortDefinition fromPortName(String portName) {
|
public static PortDefinition fromPortName(String portName) {
|
||||||
return AS_STREAM.filter(v -> portName.startsWith(v.portName)).findFirst().get();
|
return AS_SET.stream().filter(v -> portName.startsWith(v.portName)).findFirst().get();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static PortDefinition fromGroupId(String groupId) {
|
public static PortDefinition fromGroupId(String groupId) {
|
||||||
@ -66,7 +66,7 @@ public enum PortDefinition {
|
|||||||
|
|
||||||
public static String asChannelId(String portDefinition) {
|
public static String asChannelId(String portDefinition) {
|
||||||
String portKind = portDefinition.substring(0, 1);
|
String portKind = portDefinition.substring(0, 1);
|
||||||
PortDefinition result = AS_STREAM.filter(v -> v.portName.startsWith(portKind)).findFirst().get();
|
PortDefinition result = AS_SET.stream().filter(v -> v.portName.equals(portKind)).findFirst().get();
|
||||||
return "%s#%s".formatted(result.toString(), portDefinition.substring(1));
|
return "%s#%s".formatted(result.toString(), portDefinition.substring(1));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user