Debugging

Signed-off-by: clinique <gael@lhopital.org>
This commit is contained in:
clinique 2024-12-26 01:02:21 +01:00
parent c399be7a43
commit ed2a6d5700
3 changed files with 61 additions and 43 deletions

View File

@ -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();
}
} }

View File

@ -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

View File

@ -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));
} }
} }