mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
[freeboxos] Get server AirPlay capabilities (#17257)
This will set the related thing properties. No audio sink will be created for the revolution server as it only supports audio and pushing audio media is not yet supported by the API. Signed-off-by: Laurent Garnier <lg.hc@free.fr>
This commit is contained in:
parent
6218fc434a
commit
f4c85a08cd
@ -68,6 +68,8 @@ public class ServerHandler extends ApiConsumerHandler implements FreeDeviceIntf
|
|||||||
|
|
||||||
private long uptime = -1;
|
private long uptime = -1;
|
||||||
|
|
||||||
|
private boolean tryConfigureMediaSink = true;
|
||||||
|
|
||||||
public ServerHandler(Thing thing) {
|
public ServerHandler(Thing thing) {
|
||||||
super(thing);
|
super(thing);
|
||||||
eventChannelUID = new ChannelUID(getThing().getUID(), GROUP_SYS_INFO, BOX_EVENT);
|
eventChannelUID = new ChannelUID(getThing().getUID(), GROUP_SYS_INFO, BOX_EVENT);
|
||||||
@ -147,6 +149,17 @@ public class ServerHandler extends ApiConsumerHandler implements FreeDeviceIntf
|
|||||||
if (anyChannelLinked(GROUP_FILE_SHARING, Set.of(AFP_FILE_STATUS))) {
|
if (anyChannelLinked(GROUP_FILE_SHARING, Set.of(AFP_FILE_STATUS))) {
|
||||||
updateChannelOnOff(GROUP_FILE_SHARING, AFP_FILE_STATUS, getManager(AfpManager.class).getStatus());
|
updateChannelOnOff(GROUP_FILE_SHARING, AFP_FILE_STATUS, getManager(AfpManager.class).getStatus());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (tryConfigureMediaSink) {
|
||||||
|
configureMediaSink();
|
||||||
|
tryConfigureMediaSink = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void internalForcePoll() throws FreeboxException {
|
||||||
|
tryConfigureMediaSink = true;
|
||||||
|
internalPoll();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void fetchSystemConfig() throws FreeboxException {
|
private void fetchSystemConfig() throws FreeboxException {
|
||||||
@ -235,6 +248,7 @@ public class ServerHandler extends ApiConsumerHandler implements FreeDeviceIntf
|
|||||||
case AIRMEDIA_STATUS:
|
case AIRMEDIA_STATUS:
|
||||||
updateChannelOnOff(GROUP_ACTIONS, AIRMEDIA_STATUS,
|
updateChannelOnOff(GROUP_ACTIONS, AIRMEDIA_STATUS,
|
||||||
getManager(AirMediaManager.class).setStatus(enable));
|
getManager(AirMediaManager.class).setStatus(enable));
|
||||||
|
tryConfigureMediaSink = true;
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user