]> git.basschouten.com Git - openhab-addons.git/blob
2906bf32603ef0908d21be08b5dba0c585c0363c
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2023 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
7  * This program and the accompanying materials are made available under the
8  * terms of the Eclipse Public License 2.0 which is available at
9  * http://www.eclipse.org/legal/epl-2.0
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.binding.chromecast.internal;
14
15 import org.eclipse.jdt.annotation.NonNullByDefault;
16 import org.openhab.core.thing.ThingStatus;
17 import org.slf4j.Logger;
18 import org.slf4j.LoggerFactory;
19
20 import su.litvak.chromecast.api.v2.ChromeCastConnectionEvent;
21 import su.litvak.chromecast.api.v2.ChromeCastConnectionEventListener;
22 import su.litvak.chromecast.api.v2.ChromeCastSpontaneousEvent;
23 import su.litvak.chromecast.api.v2.ChromeCastSpontaneousEventListener;
24 import su.litvak.chromecast.api.v2.MediaStatus;
25 import su.litvak.chromecast.api.v2.Status;
26
27 /**
28  * Responsible for listening to events from the Chromecast.
29  *
30  * @author Jason Holmes - Initial contribution
31  */
32 @NonNullByDefault
33 public class ChromecastEventReceiver implements ChromeCastSpontaneousEventListener, ChromeCastConnectionEventListener {
34     private final Logger logger = LoggerFactory.getLogger(ChromecastEventReceiver.class);
35
36     private final ChromecastScheduler scheduler;
37     private final ChromecastStatusUpdater statusUpdater;
38
39     public ChromecastEventReceiver(ChromecastScheduler scheduler, ChromecastStatusUpdater statusUpdater) {
40         this.scheduler = scheduler;
41         this.statusUpdater = statusUpdater;
42     }
43
44     @Override
45     public void connectionEventReceived(final @NonNullByDefault({}) ChromeCastConnectionEvent event) {
46         if (event.isConnected()) {
47             statusUpdater.updateStatus(ThingStatus.ONLINE);
48             scheduler.scheduleRefresh();
49         } else {
50             scheduler.cancelRefresh();
51             statusUpdater.updateStatus(ThingStatus.OFFLINE);
52             // We might have just had a connection problem, let's try to reconnect.
53             scheduler.scheduleConnect();
54         }
55     }
56
57     @Override
58     public void spontaneousEventReceived(final @NonNullByDefault({}) ChromeCastSpontaneousEvent event) {
59         logger.trace("Received an {} event (class={})", event.getType(), event.getData());
60
61         switch (event.getType()) {
62             case CLOSE:
63                 statusUpdater.updateMediaStatus(null);
64                 break;
65             case MEDIA_STATUS:
66                 statusUpdater.updateMediaStatus(event.getData(MediaStatus.class));
67                 break;
68             case STATUS:
69                 statusUpdater.processStatusUpdate(event.getData(Status.class));
70                 break;
71             case APPEVENT:
72                 logger.debug("Received an 'APPEVENT' event, ignoring");
73                 break;
74             case UNKNOWN:
75                 logger.debug("Received an 'UNKNOWN' event (class={})", event.getType().getDataClass());
76                 break;
77             default:
78                 logger.debug("Unhandled event type: {}", event.getType());
79                 break;
80         }
81     }
82 }