[freeboxos] Fix handling of REFRESH command for connectivity channels (#17178)

Fix #17168

Signed-off-by: Laurent Garnier <lg.hc@free.fr>
Signed-off-by: Ciprian Pascu <contact@ciprianpascu.ro>
This commit is contained in:
lolodomo 2024-07-29 13:44:58 +02:00 committed by Ciprian Pascu
parent 08c6eb4c3a
commit 9c5e6c467f
3 changed files with 20 additions and 1 deletions

View File

@ -151,7 +151,7 @@ public abstract class ApiConsumerHandler extends BaseThingHandler implements Api
try {
if (checkBridgeHandler() != null) {
if (command instanceof RefreshType) {
internalPoll();
internalForcePoll();
} else if (!internalHandleCommand(channelUID.getIdWithoutGroup(), command)) {
logger.debug("Unexpected command {} on channel {}", command, channelUID.getId());
}
@ -258,6 +258,10 @@ public abstract class ApiConsumerHandler extends BaseThingHandler implements Api
protected abstract void internalPoll() throws FreeboxException;
protected void internalForcePoll() throws FreeboxException {
internalPoll();
}
private void updateIfActive(String group, String channelId, State state) {
ChannelUID id = new ChannelUID(getThing().getUID(), group, channelId);
if (isLinked(id)) {

View File

@ -85,6 +85,12 @@ public class HostHandler extends ApiConsumerHandler {
pushSubscribed = getManager(WebSocketManager.class).registerListener(host.getMac(), this);
}
@Override
protected void internalForcePoll() throws FreeboxException {
LanHost host = getLanHost();
updateConnectivityChannels(host);
}
protected LanHost getLanHost() throws FreeboxException {
return getManager(LanBrowserManager.class).getHost(getMac()).map(hostIntf -> hostIntf.host())
.orElseThrow(() -> new FreeboxException("Host data not found"));

View File

@ -51,6 +51,15 @@ public class VmHandler extends HostHandler {
}
}
@Override
protected void internalForcePoll() throws FreeboxException {
super.internalForcePoll();
logger.debug("Polling Virtual machine status");
VirtualMachine vm = getManager(VmManager.class).getDevice(getClientId());
updateVmChannels(vm);
}
public void updateVmChannels(VirtualMachine vm) {
boolean running = Status.RUNNING.equals(vm.status());
updateChannelOnOff(VM_STATUS, STATUS, running);