Java 17 features (A-G) (#15516)

- add missing @override
- Java style array syntax
- remove redundant modifiers
- always move String constants to left side in comparisons
- simplify lambda expressions and return statements
- use replace instead of replaceAll w/o regex
- instanceof matching and multiline strings

Signed-off-by: Holger Friedrich <mail@holger-friedrich.de>
This commit is contained in:
Holger Friedrich 2023-09-05 22:30:16 +02:00 committed by GitHub
parent a0dc5c05f2
commit cf10b3e9c7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
486 changed files with 2053 additions and 1955 deletions

View File

@ -14,7 +14,7 @@ package org.openhab.binding.adorne.internal.discovery;
import static org.openhab.binding.adorne.internal.AdorneBindingConstants.*; import static org.openhab.binding.adorne.internal.AdorneBindingConstants.*;
import java.util.Collections; import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable; import org.eclipse.jdt.annotation.Nullable;
@ -52,7 +52,7 @@ public class AdorneDiscoveryService extends AbstractDiscoveryService implements
*/ */
public AdorneDiscoveryService() { public AdorneDiscoveryService() {
// Passing false as last argument to super constructor turns off background discovery // Passing false as last argument to super constructor turns off background discovery
super(Collections.singleton(new ThingTypeUID(BINDING_ID, "-")), DISCOVERY_TIMEOUT_SECONDS, false); super(Set.of(new ThingTypeUID(BINDING_ID, "-")), DISCOVERY_TIMEOUT_SECONDS, false);
// We create the hub controller with default host and port. In the future we could let users create hubs // We create the hub controller with default host and port. In the future we could let users create hubs
// manually with custom host and port settings and then perform discovery here for those hubs. // manually with custom host and port settings and then perform discovery here for those hubs.
@ -76,10 +76,9 @@ public class AdorneDiscoveryService extends AbstractDiscoveryService implements
// Future enhancement: Need a timeout for each future execution to recover from bugs in the hub controller, but // Future enhancement: Need a timeout for each future execution to recover from bugs in the hub controller, but
// Java8 doesn't yet offer that // Java8 doesn't yet offer that
adorneHubController.start().thenCompose(Void -> { adorneHubController.start().thenCompose(Void ->
// We use the hub's MAC address as its unique identifier // We use the hub's MAC address as its unique identifier
return adorneHubController.getMACAddress(); adorneHubController.getMACAddress()).thenCompose(macAddress -> {
}).thenCompose(macAddress -> {
String macAddressNoColon = macAddress.replace(':', '-'); // Colons are not allowed in ThingUIDs String macAddressNoColon = macAddress.replace(':', '-'); // Colons are not allowed in ThingUIDs
bridgeUID[0] = new ThingUID(THING_TYPE_HUB, macAddressNoColon); bridgeUID[0] = new ThingUID(THING_TYPE_HUB, macAddressNoColon);
// We have fully discovered the hub // We have fully discovered the hub

View File

@ -50,10 +50,10 @@ public class AdorneDimmerHandler extends AdorneSwitchHandler {
if (channelUID.getId().equals(CHANNEL_BRIGHTNESS)) { if (channelUID.getId().equals(CHANNEL_BRIGHTNESS)) {
if (command instanceof RefreshType) { if (command instanceof RefreshType) {
refreshBrightness(); refreshBrightness();
} else if (command instanceof PercentType) { } else if (command instanceof PercentType percentCommand) {
// Change the brightness through the hub controller // Change the brightness through the hub controller
AdorneHubController adorneHubController = getAdorneHubController(); AdorneHubController adorneHubController = getAdorneHubController();
int level = ((PercentType) command).intValue(); int level = percentCommand.intValue();
if (level >= 1 && level <= 100) { // Ignore commands outside of the supported 1-100 range if (level >= 1 && level <= 100) { // Ignore commands outside of the supported 1-100 range
adorneHubController.setBrightness(zoneId, level); adorneHubController.setBrightness(zoneId, level);
} else { } else {

View File

@ -86,8 +86,8 @@ public class AdorneHubConnection {
return null; // Eat empty messages return null; // Eat empty messages
} }
logger.debug("Received message {}", msg); logger.debug("Received message {}", msg);
if (msg instanceof JsonObject) { if (msg instanceof JsonObject object) {
msgJsonObject = (JsonObject) msg; msgJsonObject = object;
} }
return msgJsonObject; return msgJsonObject;
} }

View File

@ -81,7 +81,7 @@ final class AhaCollectionScheduleImpl implements AhaCollectionSchedule {
final Elements table = doc.select("table"); final Elements table = doc.select("table");
if (table.size() == 0) { if (table.isEmpty()) {
logger.warn("No result table found."); logger.warn("No result table found.");
return Collections.emptyMap(); return Collections.emptyMap();
} }
@ -91,7 +91,7 @@ final class AhaCollectionScheduleImpl implements AhaCollectionSchedule {
while (rowIt.hasNext()) { while (rowIt.hasNext()) {
final Element currentRow = rowIt.next(); final Element currentRow = rowIt.next();
if (!currentRow.tagName().equals("tr")) { if (!"tr".equals(currentRow.tagName())) {
continue; continue;
} }
// Skip header, empty and download button rows. // Skip header, empty and download button rows.

View File

@ -14,7 +14,6 @@ package org.openhab.binding.airq.internal;
import static org.openhab.binding.airq.internal.AirqBindingConstants.THING_TYPE_AIRQ; import static org.openhab.binding.airq.internal.AirqBindingConstants.THING_TYPE_AIRQ;
import java.util.Collections;
import java.util.Set; import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
@ -38,7 +37,7 @@ import org.osgi.service.component.annotations.Reference;
@Component(configurationPid = "binding.airq", service = ThingHandlerFactory.class) @Component(configurationPid = "binding.airq", service = ThingHandlerFactory.class)
public class AirqHandlerFactory extends BaseThingHandlerFactory { public class AirqHandlerFactory extends BaseThingHandlerFactory {
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Collections.singleton(THING_TYPE_AIRQ); private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(THING_TYPE_AIRQ);
private final HttpClientFactory httpClientFactory; private final HttpClientFactory httpClientFactory;
@Activate @Activate

View File

@ -64,12 +64,12 @@ public enum Pollutant {
new ConcentrationRange(205, 404, TWO_HUNDRED), new ConcentrationRange(405, 504, THREE_HUNDRED), new ConcentrationRange(205, 404, TWO_HUNDRED), new ConcentrationRange(405, 504, THREE_HUNDRED),
new ConcentrationRange(505, 604, FOUR_HUNDRED)); new ConcentrationRange(505, 604, FOUR_HUNDRED));
public static enum SensitiveGroup { public enum SensitiveGroup {
RESPIRATORY, RESPIRATORY,
HEART, HEART,
ELDERLY, ELDERLY,
CHILDREN, CHILDREN,
ASTHMA; ASTHMA
} }
public final Set<SensitiveGroup> sensitiveGroups; public final Set<SensitiveGroup> sensitiveGroups;

View File

@ -22,11 +22,11 @@ import com.google.gson.annotations.SerializedName;
* @author Gaël L'hopital - Initial contribution * @author Gaël L'hopital - Initial contribution
*/ */
public class ResponseRoot { public class ResponseRoot {
public static enum ResponseStatus { public enum ResponseStatus {
@SerializedName("error") @SerializedName("error")
ERROR, ERROR,
@SerializedName("ok") @SerializedName("ok")
OK; OK
} }
protected ResponseStatus status = ResponseStatus.OK; protected ResponseStatus status = ResponseStatus.OK;

View File

@ -28,8 +28,7 @@ public class SensitiveGroupConfiguration {
public @Nullable SensitiveGroup asSensitiveGroup() { public @Nullable SensitiveGroup asSensitiveGroup() {
try { try {
SensitiveGroup value = SensitiveGroup.valueOf(group); return SensitiveGroup.valueOf(group);
return value;
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
return null; return null;
} }

View File

@ -15,7 +15,6 @@ package org.openhab.binding.airquality.internal.discovery;
import static org.openhab.binding.airquality.internal.AirQualityBindingConstants.*; import static org.openhab.binding.airquality.internal.AirQualityBindingConstants.*;
import static org.openhab.binding.airquality.internal.config.AirQualityConfiguration.LOCATION; import static org.openhab.binding.airquality.internal.config.AirQualityConfiguration.LOCATION;
import java.util.Collections;
import java.util.Set; import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
@ -43,7 +42,7 @@ import org.slf4j.LoggerFactory;
@NonNullByDefault @NonNullByDefault
public class AirQualityDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService { public class AirQualityDiscoveryService extends AbstractDiscoveryService implements ThingHandlerService {
private static final int DISCOVER_TIMEOUT_SECONDS = 2; private static final int DISCOVER_TIMEOUT_SECONDS = 2;
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Collections.singleton(THING_TYPE_STATION); private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(THING_TYPE_STATION);
private final Logger logger = LoggerFactory.getLogger(AirQualityDiscoveryService.class); private final Logger logger = LoggerFactory.getLogger(AirQualityDiscoveryService.class);
@ -59,9 +58,8 @@ public class AirQualityDiscoveryService extends AbstractDiscoveryService impleme
@Override @Override
public void setThingHandler(@Nullable ThingHandler handler) { public void setThingHandler(@Nullable ThingHandler handler) {
if (handler instanceof AirQualityBridgeHandler) { if (handler instanceof AirQualityBridgeHandler bridgeHandlerInstance) {
final AirQualityBridgeHandler bridgeHandler = (AirQualityBridgeHandler) handler; this.bridgeHandler = bridgeHandlerInstance;
this.bridgeHandler = bridgeHandler;
this.locationProvider = bridgeHandler.getLocationProvider(); this.locationProvider = bridgeHandler.getLocationProvider();
} }
} }

View File

@ -12,9 +12,6 @@
*/ */
package org.openhab.binding.airvisualnode.internal; package org.openhab.binding.airvisualnode.internal;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
import java.util.Set; import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
@ -51,12 +48,10 @@ public class AirVisualNodeBindingConstants {
.getUID().getId(); .getUID().getId();
// List of all supported Thing UIDs // List of all supported Thing UIDs
public static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Collections public static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(THING_TYPE_AVNODE);
.unmodifiableSet(new HashSet<>(Arrays.asList(THING_TYPE_AVNODE)));
// List of all supported Channel ids // List of all supported Channel ids
public static final Set<String> SUPPORTED_CHANNEL_IDS = Collections public static final Set<String> SUPPORTED_CHANNEL_IDS = Set.of(CHANNEL_CO2, CHANNEL_HUMIDITY, CHANNEL_AQI_US,
.unmodifiableSet(new HashSet<>(Arrays.asList(CHANNEL_CO2, CHANNEL_HUMIDITY, CHANNEL_AQI_US, CHANNEL_PM_25, CHANNEL_PM_25, CHANNEL_PM_10, CHANNEL_PM_01, CHANNEL_TEMP_CELSIUS, CHANNEL_BATTERY_LEVEL,
CHANNEL_PM_10, CHANNEL_PM_01, CHANNEL_TEMP_CELSIUS, CHANNEL_BATTERY_LEVEL, CHANNEL_WIFI_STRENGTH, CHANNEL_WIFI_STRENGTH, CHANNEL_TIMESTAMP, CHANNEL_USED_MEMORY);
CHANNEL_TIMESTAMP, CHANNEL_USED_MEMORY)));
} }

View File

@ -14,7 +14,7 @@ package org.openhab.binding.airvisualnode.internal.discovery;
import java.io.IOException; import java.io.IOException;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import java.util.Collections; import java.util.Set;
import java.util.concurrent.ScheduledFuture; import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import java.util.regex.Matcher; import java.util.regex.Matcher;
@ -55,7 +55,7 @@ public class AirVisualNodeDiscoveryService extends AbstractDiscoveryService {
private @Nullable ScheduledFuture<?> backgroundDiscoveryFuture; private @Nullable ScheduledFuture<?> backgroundDiscoveryFuture;
public AirVisualNodeDiscoveryService() { public AirVisualNodeDiscoveryService() {
super(Collections.singleton(AirVisualNodeBindingConstants.THING_TYPE_AVNODE), 600, true); super(Set.of(AirVisualNodeBindingConstants.THING_TYPE_AVNODE), 600, true);
} }
@Override @Override

View File

@ -49,6 +49,7 @@ public class Measurements implements MeasurementsInterface {
this.vocPpb = vocPpb; this.vocPpb = vocPpb;
} }
@Override
public int getCo2Ppm() { public int getCo2Ppm() {
return co2Ppm; return co2Ppm;
} }
@ -57,6 +58,7 @@ public class Measurements implements MeasurementsInterface {
this.co2Ppm = co2Ppm; this.co2Ppm = co2Ppm;
} }
@Override
public int getHumidityRH() { public int getHumidityRH() {
return humidityRH; return humidityRH;
} }
@ -65,6 +67,7 @@ public class Measurements implements MeasurementsInterface {
this.humidityRH = humidityRH; this.humidityRH = humidityRH;
} }
@Override
public int getPm25AQICN() { public int getPm25AQICN() {
return pm25AQICN; return pm25AQICN;
} }
@ -73,6 +76,7 @@ public class Measurements implements MeasurementsInterface {
this.pm25AQICN = pm25AQICN; this.pm25AQICN = pm25AQICN;
} }
@Override
public int getPm25AQIUS() { public int getPm25AQIUS() {
return pm25AQIUS; return pm25AQIUS;
} }
@ -91,6 +95,7 @@ public class Measurements implements MeasurementsInterface {
return 0; return 0;
} }
@Override
public float getPm25Ugm3() { public float getPm25Ugm3() {
return pm25Ugm3; return pm25Ugm3;
} }
@ -99,6 +104,7 @@ public class Measurements implements MeasurementsInterface {
this.pm25Ugm3 = pm25Ugm3; this.pm25Ugm3 = pm25Ugm3;
} }
@Override
public float getTemperatureC() { public float getTemperatureC() {
return temperatureC; return temperatureC;
} }
@ -107,6 +113,7 @@ public class Measurements implements MeasurementsInterface {
this.temperatureC = temperatureC; this.temperatureC = temperatureC;
} }
@Override
public float getTemperatureF() { public float getTemperatureF() {
return temperatureF; return temperatureF;
} }
@ -115,6 +122,7 @@ public class Measurements implements MeasurementsInterface {
this.temperatureF = temperatureF; this.temperatureF = temperatureF;
} }
@Override
public int getVocPpb() { public int getVocPpb() {
return vocPpb; return vocPpb;
} }

View File

@ -40,6 +40,7 @@ public class NodeData implements NodeDataInterface {
this.status = status; this.status = status;
} }
@Override
public DateAndTime getDateAndTime() { public DateAndTime getDateAndTime() {
return dateAndTime; return dateAndTime;
} }
@ -48,6 +49,7 @@ public class NodeData implements NodeDataInterface {
this.dateAndTime = dateAndTime; this.dateAndTime = dateAndTime;
} }
@Override
public MeasurementsInterface getMeasurements() { public MeasurementsInterface getMeasurements() {
return measurements; return measurements;
} }
@ -56,6 +58,7 @@ public class NodeData implements NodeDataInterface {
this.measurements = measurements; this.measurements = measurements;
} }
@Override
public String getSerialNumber() { public String getSerialNumber() {
return serialNumber; return serialNumber;
} }
@ -64,6 +67,7 @@ public class NodeData implements NodeDataInterface {
this.serialNumber = serialNumber; this.serialNumber = serialNumber;
} }
@Override
public Settings getSettings() { public Settings getSettings() {
return settings; return settings;
} }
@ -72,6 +76,7 @@ public class NodeData implements NodeDataInterface {
this.settings = settings; this.settings = settings;
} }
@Override
public Status getStatus() { public Status getStatus() {
return status; return status;
} }

View File

@ -66,6 +66,7 @@ public class Measurements implements MeasurementsInterface {
this.vocPpb = vocPpb; this.vocPpb = vocPpb;
} }
@Override
public int getCo2Ppm() { public int getCo2Ppm() {
return co2Ppm; return co2Ppm;
} }
@ -74,6 +75,7 @@ public class Measurements implements MeasurementsInterface {
this.co2Ppm = co2Ppm; this.co2Ppm = co2Ppm;
} }
@Override
public int getHumidityRH() { public int getHumidityRH() {
return humidityRH; return humidityRH;
} }
@ -82,6 +84,7 @@ public class Measurements implements MeasurementsInterface {
this.humidityRH = humidityRH; this.humidityRH = humidityRH;
} }
@Override
public int getPm25AQICN() { public int getPm25AQICN() {
return pm25AQICN; return pm25AQICN;
} }
@ -90,6 +93,7 @@ public class Measurements implements MeasurementsInterface {
this.pm25AQICN = pm25AQICN; this.pm25AQICN = pm25AQICN;
} }
@Override
public int getPm25AQIUS() { public int getPm25AQIUS() {
return pm25AQIUS; return pm25AQIUS;
} }
@ -98,6 +102,7 @@ public class Measurements implements MeasurementsInterface {
this.pm25AQIUS = pm25AQIUS; this.pm25AQIUS = pm25AQIUS;
} }
@Override
public float getPm01Ugm3() { public float getPm01Ugm3() {
return pm01Ugm3; return pm01Ugm3;
} }
@ -106,6 +111,7 @@ public class Measurements implements MeasurementsInterface {
this.pm01Ugm3 = pm01Ugm3; this.pm01Ugm3 = pm01Ugm3;
} }
@Override
public float getPm10Ugm3() { public float getPm10Ugm3() {
return pm10Ugm3; return pm10Ugm3;
} }
@ -114,6 +120,7 @@ public class Measurements implements MeasurementsInterface {
this.pm10Ugm3 = pm10Ugm3; this.pm10Ugm3 = pm10Ugm3;
} }
@Override
public float getPm25Ugm3() { public float getPm25Ugm3() {
return pm25Ugm3; return pm25Ugm3;
} }
@ -122,6 +129,7 @@ public class Measurements implements MeasurementsInterface {
this.pm25Ugm3 = pm25Ugm3; this.pm25Ugm3 = pm25Ugm3;
} }
@Override
public float getTemperatureC() { public float getTemperatureC() {
return temperatureC; return temperatureC;
} }
@ -130,6 +138,7 @@ public class Measurements implements MeasurementsInterface {
this.temperatureC = temperatureC; this.temperatureC = temperatureC;
} }
@Override
public float getTemperatureF() { public float getTemperatureF() {
return temperatureF; return temperatureF;
} }
@ -138,6 +147,7 @@ public class Measurements implements MeasurementsInterface {
this.temperatureF = temperatureF; this.temperatureF = temperatureF;
} }
@Override
public int getVocPpb() { public int getVocPpb() {
return vocPpb; return vocPpb;
} }

View File

@ -44,6 +44,7 @@ public class ProNodeData implements NodeDataInterface {
this.status = status; this.status = status;
} }
@Override
public DateAndTime getDateAndTime() { public DateAndTime getDateAndTime() {
return dateAndTime; return dateAndTime;
} }
@ -52,6 +53,7 @@ public class ProNodeData implements NodeDataInterface {
this.dateAndTime = dateAndTime; this.dateAndTime = dateAndTime;
} }
@Override
public MeasurementsInterface getMeasurements() { public MeasurementsInterface getMeasurements() {
return measurements.get(0); return measurements.get(0);
} }
@ -60,6 +62,7 @@ public class ProNodeData implements NodeDataInterface {
this.measurements = measurements; this.measurements = measurements;
} }
@Override
public String getSerialNumber() { public String getSerialNumber() {
return serialNumber; return serialNumber;
} }
@ -68,6 +71,7 @@ public class ProNodeData implements NodeDataInterface {
this.serialNumber = serialNumber; this.serialNumber = serialNumber;
} }
@Override
public Settings getSettings() { public Settings getSettings() {
return settings; return settings;
} }
@ -76,6 +80,7 @@ public class ProNodeData implements NodeDataInterface {
this.settings = settings; this.settings = settings;
} }
@Override
public Status getStatus() { public Status getStatus() {
return status; return status;
} }

View File

@ -42,8 +42,8 @@ public class BridgeActions implements ThingActions {
@Override @Override
public void setThingHandler(@Nullable ThingHandler handler) { public void setThingHandler(@Nullable ThingHandler handler) {
if (handler instanceof ADBridgeHandler) { if (handler instanceof ADBridgeHandler bridgeHandler) {
this.bridge = (ADBridgeHandler) handler; this.bridge = bridgeHandler;
} }
} }

View File

@ -20,8 +20,8 @@ import java.io.IOException;
import java.nio.charset.Charset; import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.Date; import java.util.Date;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.concurrent.ScheduledFuture; import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -87,7 +87,7 @@ public abstract class ADBridgeHandler extends BaseBridgeHandler {
@Override @Override
public Collection<Class<? extends ThingHandlerService>> getServices() { public Collection<Class<? extends ThingHandlerService>> getServices() {
return Collections.singletonList(BridgeActions.class); return List.of(BridgeActions.class);
} }
public void setDiscoveryService(AlarmDecoderDiscoveryService discoveryService) { public void setDiscoveryService(AlarmDecoderDiscoveryService discoveryService) {

View File

@ -113,13 +113,13 @@ public class KeypadHandler extends ADThingHandler {
IntCommandMap intCommandMap = this.intCommandMap; IntCommandMap intCommandMap = this.intCommandMap;
if (channelUID.getId().equals(CHANNEL_KP_COMMAND)) { if (channelUID.getId().equals(CHANNEL_KP_COMMAND)) {
if (command instanceof StringType) { if (command instanceof StringType commandString) {
String cmd = ((StringType) command).toString(); String cmd = commandString.toString();
handleKeypadCommand(cmd); handleKeypadCommand(cmd);
} }
} else if (channelUID.getId().equals(CHANNEL_KP_INTCOMMAND)) { } else if (channelUID.getId().equals(CHANNEL_KP_INTCOMMAND)) {
if (command instanceof Number) { if (command instanceof Number numberCommand) {
int icmd = ((Number) command).intValue(); int icmd = numberCommand.intValue();
if (intCommandMap != null) { if (intCommandMap != null) {
String cmd = intCommandMap.getCommand(icmd); String cmd = intCommandMap.getCommand(icmd);
if (cmd != null) { if (cmd != null) {

View File

@ -78,8 +78,8 @@ public class VZoneHandler extends ADThingHandler {
@Override @Override
public void handleCommand(ChannelUID channelUID, Command command) { public void handleCommand(ChannelUID channelUID, Command command) {
if (channelUID.getId().equals(CHANNEL_COMMAND)) { if (channelUID.getId().equals(CHANNEL_COMMAND)) {
if (command instanceof StringType) { if (command instanceof StringType stringCommand) {
String cmd = ((StringType) command).toString(); String cmd = stringCommand.toString();
if (CMD_OPEN.equalsIgnoreCase(cmd)) { if (CMD_OPEN.equalsIgnoreCase(cmd)) {
sendCommand(ADCommand.setZone(config.address, ADCommand.ZONE_OPEN)); sendCommand(ADCommand.setZone(config.address, ADCommand.ZONE_OPEN));
setChannelState(OnOffType.OFF); setChannelState(OnOffType.OFF);

View File

@ -46,7 +46,7 @@ public class ZoneHandler extends ADThingHandler {
} }
/** Construct zone id from address and channel */ /** Construct zone id from address and channel */
public static final String zoneID(int address, int channel) { public static String zoneID(int address, int channel) {
return String.format("%d-%d", address, channel); return String.format("%d-%d", address, channel);
} }

View File

@ -40,7 +40,7 @@ public class EXPMessage extends ADMessage {
public EXPMessage(String message) throws IllegalArgumentException { public EXPMessage(String message) throws IllegalArgumentException {
super(message); super(message);
String topLevel[] = message.split(":"); String[] topLevel = message.split(":");
if (topLevel.length != 2) { if (topLevel.length != 2) {
throw new IllegalArgumentException("Multiple colons found in EXP message"); throw new IllegalArgumentException("Multiple colons found in EXP message");
} }

View File

@ -143,8 +143,7 @@ public class KeypadMessage extends ADMessage {
return false; return false;
} else if (this == obj) { } else if (this == obj) {
return true; return true;
} else if (obj instanceof KeypadMessage) { } else if (obj instanceof KeypadMessage other) {
KeypadMessage other = (KeypadMessage) obj;
return this.message.equals(other.message); return this.message.equals(other.message);
} else { } else {
return false; return false;

View File

@ -43,7 +43,7 @@ public class LRRMessage extends ADMessage {
public LRRMessage(String message) throws IllegalArgumentException { public LRRMessage(String message) throws IllegalArgumentException {
super(message); super(message);
String topLevel[] = message.split(":"); String[] topLevel = message.split(":");
if (topLevel.length != 2) { if (topLevel.length != 2) {
throw new IllegalArgumentException("multiple colons in LRR message"); throw new IllegalArgumentException("multiple colons in LRR message");
} }

View File

@ -43,7 +43,7 @@ public class RFXMessage extends ADMessage {
public RFXMessage(String message) throws IllegalArgumentException { public RFXMessage(String message) throws IllegalArgumentException {
super(message); super(message);
String topLevel[] = message.split(":"); String[] topLevel = message.split(":");
if (topLevel.length != 2) { if (topLevel.length != 2) {
throw new IllegalArgumentException("Multiple colons found in RFX message"); throw new IllegalArgumentException("Multiple colons found in RFX message");
} }

View File

@ -38,7 +38,7 @@ public class VersionMessage extends ADMessage {
public VersionMessage(String message) throws IllegalArgumentException { public VersionMessage(String message) throws IllegalArgumentException {
super(message); super(message);
String topLevel[] = message.split(":"); String[] topLevel = message.split(":");
if (topLevel.length != 2) { if (topLevel.length != 2) {
throw new IllegalArgumentException("Multiple colons found in VER message"); throw new IllegalArgumentException("Multiple colons found in VER message");
} }

View File

@ -63,9 +63,9 @@ public class AllPlayBindingProperties {
private int getIntegerProperty(Dictionary<String, Object> properties, String propertyKey, int defaultValue) { private int getIntegerProperty(Dictionary<String, Object> properties, String propertyKey, int defaultValue) {
Object configValue = properties.get(propertyKey); Object configValue = properties.get(propertyKey);
int value = defaultValue; int value = defaultValue;
if (configValue instanceof String) { if (configValue instanceof String stringValue) {
try { try {
value = Integer.parseInt((String) configValue); value = Integer.parseInt(stringValue);
} catch (NumberFormatException e) { } catch (NumberFormatException e) {
logger.warn("Unable to convert value {} for config property {} to integer. Using default value.", logger.warn("Unable to convert value {} for config property {} to integer. Using default value.",
configValue, propertyKey); configValue, propertyKey);

View File

@ -14,7 +14,6 @@ package org.openhab.binding.allplay.internal;
import static org.openhab.binding.allplay.internal.AllPlayBindingConstants.SPEAKER_THING_TYPE; import static org.openhab.binding.allplay.internal.AllPlayBindingConstants.SPEAKER_THING_TYPE;
import java.util.Collections;
import java.util.Dictionary; import java.util.Dictionary;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Map; import java.util.Map;
@ -54,7 +53,7 @@ public class AllPlayHandlerFactory extends BaseThingHandlerFactory {
private final Logger logger = LoggerFactory.getLogger(AllPlayHandlerFactory.class); private final Logger logger = LoggerFactory.getLogger(AllPlayHandlerFactory.class);
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Collections.singleton(SPEAKER_THING_TYPE); private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(SPEAKER_THING_TYPE);
private final Map<String, ServiceRegistration<AudioSink>> audioSinkRegistrations = new ConcurrentHashMap<>(); private final Map<String, ServiceRegistration<AudioSink>> audioSinkRegistrations = new ConcurrentHashMap<>();
private AllPlay allPlay; private AllPlay allPlay;

View File

@ -14,7 +14,6 @@ package org.openhab.binding.allplay.internal.discovery;
import static org.openhab.binding.allplay.internal.AllPlayBindingConstants.SPEAKER_THING_TYPE; import static org.openhab.binding.allplay.internal.AllPlayBindingConstants.SPEAKER_THING_TYPE;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -46,7 +45,7 @@ public class AllPlaySpeakerDiscoveryService extends AbstractDiscoveryService imp
private final Logger logger = LoggerFactory.getLogger(AllPlaySpeakerDiscoveryService.class); private final Logger logger = LoggerFactory.getLogger(AllPlaySpeakerDiscoveryService.class);
private static final int DISCOVERY_TIMEOUT = 30; private static final int DISCOVERY_TIMEOUT = 30;
private static final Set<ThingTypeUID> DISCOVERABLE_THING_TYPES_UIDS = Collections.singleton(SPEAKER_THING_TYPE); private static final Set<ThingTypeUID> DISCOVERABLE_THING_TYPES_UIDS = Set.of(SPEAKER_THING_TYPE);
private AllPlay allPlay; private AllPlay allPlay;
public AllPlaySpeakerDiscoveryService() { public AllPlaySpeakerDiscoveryService() {

View File

@ -343,8 +343,8 @@ public class AllPlayHandler extends BaseThingHandler
* @throws SpeakerException Exception if the volume change failed * @throws SpeakerException Exception if the volume change failed
*/ */
public void handleVolumeCommand(Command command) throws SpeakerException { public void handleVolumeCommand(Command command) throws SpeakerException {
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
speaker.volume().setVolume(convertPercentToAbsoluteVolume((PercentType) command)); speaker.volume().setVolume(convertPercentToAbsoluteVolume(percentCommand));
} else if (command instanceof IncreaseDecreaseType) { } else if (command instanceof IncreaseDecreaseType) {
int stepSize = (command == IncreaseDecreaseType.DECREASE ? -getVolumeStepSize() : getVolumeStepSize()); int stepSize = (command == IncreaseDecreaseType.DECREASE ? -getVolumeStepSize() : getVolumeStepSize());
speaker.volume().adjustVolume(stepSize); speaker.volume().adjustVolume(stepSize);

View File

@ -14,7 +14,6 @@ package org.openhab.binding.amazondashbutton.internal;
import static org.openhab.binding.amazondashbutton.internal.AmazonDashButtonBindingConstants.DASH_BUTTON_THING_TYPE; import static org.openhab.binding.amazondashbutton.internal.AmazonDashButtonBindingConstants.DASH_BUTTON_THING_TYPE;
import java.util.Collections;
import java.util.Set; import java.util.Set;
import org.openhab.binding.amazondashbutton.internal.handler.AmazonDashButtonHandler; import org.openhab.binding.amazondashbutton.internal.handler.AmazonDashButtonHandler;
@ -34,7 +33,7 @@ import org.osgi.service.component.annotations.Component;
@Component(service = ThingHandlerFactory.class, configurationPid = "binding.amazondashbutton") @Component(service = ThingHandlerFactory.class, configurationPid = "binding.amazondashbutton")
public class AmazonDashButtonHandlerFactory extends BaseThingHandlerFactory { public class AmazonDashButtonHandlerFactory extends BaseThingHandlerFactory {
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Collections.singleton(DASH_BUTTON_THING_TYPE); private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(DASH_BUTTON_THING_TYPE);
@Override @Override
public boolean supportsThingType(ThingTypeUID thingTypeUID) { public boolean supportsThingType(ThingTypeUID thingTypeUID) {

View File

@ -15,7 +15,6 @@ package org.openhab.binding.amazondashbutton.internal.discovery;
import static org.openhab.binding.amazondashbutton.internal.AmazonDashButtonBindingConstants.*; import static org.openhab.binding.amazondashbutton.internal.AmazonDashButtonBindingConstants.*;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.Collections;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
@ -108,7 +107,7 @@ public class AmazonDashButtonDiscoveryService extends AbstractDiscoveryService i
private boolean backgroundScanning = false; private boolean backgroundScanning = false;
public AmazonDashButtonDiscoveryService() { public AmazonDashButtonDiscoveryService() {
super(Collections.singleton(DASH_BUTTON_THING_TYPE), DISCOVER_TIMEOUT_SECONDS, false); super(Set.of(DASH_BUTTON_THING_TYPE), DISCOVER_TIMEOUT_SECONDS, false);
} }
@Override @Override

View File

@ -36,9 +36,8 @@ public class PcapUtil {
*/ */
public static Set<PcapNetworkInterfaceWrapper> getAllNetworkInterfaces() { public static Set<PcapNetworkInterfaceWrapper> getAllNetworkInterfaces() {
try { try {
final Set<PcapNetworkInterfaceWrapper> allNetworkInterfaces = Collections.unmodifiableSet(Pcaps return Collections.unmodifiableSet(Pcaps.findAllDevs().stream().map(PcapNetworkInterfaceWrapper.TRANSFORMER)
.findAllDevs().stream().map(PcapNetworkInterfaceWrapper.TRANSFORMER).collect(Collectors.toSet())); .collect(Collectors.toSet()));
return allNetworkInterfaces;
} catch (PcapNativeException e) { } catch (PcapNativeException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
} }

View File

@ -146,10 +146,10 @@ public class AmazonEchoControlHandlerFactory extends BaseThingHandlerFactory {
.getService(serviceReg.getReference()); .getService(serviceReg.getReference());
serviceReg.unregister(); serviceReg.unregister();
if (service != null) { if (service != null) {
if (service instanceof AmazonEchoDiscovery) { if (service instanceof AmazonEchoDiscovery discovery) {
((AmazonEchoDiscovery) service).deactivate(); discovery.deactivate();
} else if (service instanceof SmartHomeDevicesDiscovery) { } else if (service instanceof SmartHomeDevicesDiscovery discovery) {
((SmartHomeDevicesDiscovery) service).deactivate(); discovery.deactivate();
} else { } else {
logger.warn("Found unknown discovery-service instance: {}", service); logger.warn("Found unknown discovery-service instance: {}", service);
} }

View File

@ -49,8 +49,8 @@ public class ChannelHandlerAnnouncement extends ChannelHandler {
public boolean tryHandleCommand(Device device, Connection connection, String channelId, Command command) public boolean tryHandleCommand(Device device, Connection connection, String channelId, Command command)
throws IOException, URISyntaxException { throws IOException, URISyntaxException {
if (channelId.equals(CHANNEL_NAME)) { if (channelId.equals(CHANNEL_NAME)) {
if (command instanceof StringType) { if (command instanceof StringType stringCommand) {
String commandValue = ((StringType) command).toFullString(); String commandValue = stringCommand.toFullString();
String body = commandValue; String body = commandValue;
String title = null; String title = null;
String speak = commandValue; String speak = commandValue;

View File

@ -26,6 +26,7 @@ import org.openhab.binding.amazonechocontrol.internal.jsons.JsonDevices.Device;
*/ */
@NonNullByDefault @NonNullByDefault
public interface IEchoThingHandler extends IAmazonThingHandler { public interface IEchoThingHandler extends IAmazonThingHandler {
@Override
void startAnnouncement(Device device, String speak, String bodyText, @Nullable String title, void startAnnouncement(Device device, String speak, String bodyText, @Nullable String title,
@Nullable Integer volume) throws IOException, URISyntaxException; @Nullable Integer volume) throws IOException, URISyntaxException;
} }

View File

@ -143,8 +143,7 @@ public class SmartHomeDevicesDiscovery extends AbstractDiscoveryService {
String deviceName = null; String deviceName = null;
Map<String, Object> props = new HashMap<>(); Map<String, Object> props = new HashMap<>();
if (smartHomeDevice instanceof SmartHomeDevice) { if (smartHomeDevice instanceof SmartHomeDevice shd) {
SmartHomeDevice shd = (SmartHomeDevice) smartHomeDevice;
logger.trace("Found SmartHome device: {}", shd); logger.trace("Found SmartHome device: {}", shd);
String entityId = shd.entityId; String entityId = shd.entityId;
@ -165,7 +164,7 @@ public class SmartHomeDevicesDiscovery extends AbstractDiscoveryService {
// Connected through skill // Connected through skill
continue; continue;
} }
if (!(smartHomeDeviceDiscoveryMode == 2) && "openHAB".equalsIgnoreCase(shd.manufacturerName)) { if (smartHomeDeviceDiscoveryMode != 2 && "openHAB".equalsIgnoreCase(shd.manufacturerName)) {
// OpenHAB device // OpenHAB device
continue; continue;
} }
@ -203,8 +202,7 @@ public class SmartHomeDevicesDiscovery extends AbstractDiscoveryService {
deviceName = shd.friendlyName; deviceName = shd.friendlyName;
} }
props.put(DEVICE_PROPERTY_ID, id); props.put(DEVICE_PROPERTY_ID, id);
} else if (smartHomeDevice instanceof SmartHomeGroup) { } else if (smartHomeDevice instanceof SmartHomeGroup shg) {
SmartHomeGroup shg = (SmartHomeGroup) smartHomeDevice;
logger.trace("Found SmartHome device: {}", shg); logger.trace("Found SmartHome device: {}", shg);
String id = shg.findId(); String id = shg.findId();

View File

@ -821,8 +821,7 @@ public class AccountHandler extends BaseBridgeHandler implements IWebSocketComma
// create new id map // create new id map
Map<String, SmartHomeBaseDevice> newJsonIdSmartHomeDeviceMapping = new HashMap<>(); Map<String, SmartHomeBaseDevice> newJsonIdSmartHomeDeviceMapping = new HashMap<>();
for (Object smartHomeDevice : smartHomeDevices) { for (Object smartHomeDevice : smartHomeDevices) {
if (smartHomeDevice instanceof SmartHomeBaseDevice) { if (smartHomeDevice instanceof SmartHomeBaseDevice smartHomeBaseDevice) {
SmartHomeBaseDevice smartHomeBaseDevice = (SmartHomeBaseDevice) smartHomeDevice;
String id = smartHomeBaseDevice.findId(); String id = smartHomeBaseDevice.findId();
if (id != null) { if (id != null) {
newJsonIdSmartHomeDeviceMapping.put(id, smartHomeBaseDevice); newJsonIdSmartHomeDeviceMapping.put(id, smartHomeBaseDevice);

View File

@ -293,8 +293,8 @@ public class EchoHandler extends BaseThingHandler implements IEchoThingHandler {
} }
// Notification commands // Notification commands
if (channelId.equals(CHANNEL_NOTIFICATION_VOLUME)) { if (channelId.equals(CHANNEL_NOTIFICATION_VOLUME)) {
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
int volume = ((PercentType) command).intValue(); int volume = percentCommand.intValue();
connection.notificationVolume(device, volume); connection.notificationVolume(device, volume);
this.notificationVolumeLevel = volume; this.notificationVolumeLevel = volume;
waitForUpdate = -1; waitForUpdate = -1;
@ -318,21 +318,18 @@ public class EchoHandler extends BaseThingHandler implements IEchoThingHandler {
// Media progress commands // Media progress commands
Long mediaPosition = null; Long mediaPosition = null;
if (channelId.equals(CHANNEL_MEDIA_PROGRESS)) { if (channelId.equals(CHANNEL_MEDIA_PROGRESS)) {
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
PercentType value = (PercentType) command; int percent = percentCommand.intValue();
int percent = value.intValue();
mediaPosition = Math.round((mediaLengthMs / 1000d) * (percent / 100d)); mediaPosition = Math.round((mediaLengthMs / 1000d) * (percent / 100d));
} }
} }
if (channelId.equals(CHANNEL_MEDIA_PROGRESS_TIME)) { if (channelId.equals(CHANNEL_MEDIA_PROGRESS_TIME)) {
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
DecimalType value = (DecimalType) command; mediaPosition = decimalCommand.longValue();
mediaPosition = value.longValue();
} }
if (command instanceof QuantityType<?>) { if (command instanceof QuantityType<?> quantityCommand) {
QuantityType<?> value = (QuantityType<?>) command;
@Nullable @Nullable
QuantityType<?> seconds = value.toUnit(Units.SECOND); QuantityType<?> seconds = quantityCommand.toUnit(Units.SECOND);
if (seconds != null) { if (seconds != null) {
mediaPosition = seconds.longValue(); mediaPosition = seconds.longValue();
} }
@ -353,9 +350,8 @@ public class EchoHandler extends BaseThingHandler implements IEchoThingHandler {
// Volume commands // Volume commands
if (channelId.equals(CHANNEL_VOLUME)) { if (channelId.equals(CHANNEL_VOLUME)) {
Integer volume = null; Integer volume = null;
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
PercentType value = (PercentType) command; volume = percentCommand.intValue();
volume = value.intValue();
} else if (command == OnOffType.OFF) { } else if (command == OnOffType.OFF) {
volume = 0; volume = 0;
} else if (command == OnOffType.ON) { } else if (command == OnOffType.ON) {
@ -393,8 +389,7 @@ public class EchoHandler extends BaseThingHandler implements IEchoThingHandler {
// shuffle command // shuffle command
if (channelId.equals(CHANNEL_SHUFFLE)) { if (channelId.equals(CHANNEL_SHUFFLE)) {
if (command instanceof OnOffType) { if (command instanceof OnOffType value) {
OnOffType value = (OnOffType) command;
connection.command(device, "{\"type\":\"ShuffleCommand\",\"shuffle\":\"" connection.command(device, "{\"type\":\"ShuffleCommand\",\"shuffle\":\""
+ (value == OnOffType.ON ? "true" : "false") + "\"}"); + (value == OnOffType.ON ? "true" : "false") + "\"}");
@ -429,8 +424,8 @@ public class EchoHandler extends BaseThingHandler implements IEchoThingHandler {
// bluetooth commands // bluetooth commands
if (channelId.equals(CHANNEL_BLUETOOTH_MAC)) { if (channelId.equals(CHANNEL_BLUETOOTH_MAC)) {
needBluetoothRefresh = true; needBluetoothRefresh = true;
if (command instanceof StringType) { if (command instanceof StringType stringCommand) {
String address = ((StringType) command).toFullString(); String address = stringCommand.toFullString();
if (!address.isEmpty()) { if (!address.isEmpty()) {
waitForUpdate = 4000; waitForUpdate = 4000;
} }
@ -566,9 +561,8 @@ public class EchoHandler extends BaseThingHandler implements IEchoThingHandler {
} }
} }
if (channelId.equals(CHANNEL_TEXT_TO_SPEECH_VOLUME)) { if (channelId.equals(CHANNEL_TEXT_TO_SPEECH_VOLUME)) {
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
PercentType value = (PercentType) command; textToSpeechVolume = percentCommand.intValue();
textToSpeechVolume = value.intValue();
} else if (command == OnOffType.OFF) { } else if (command == OnOffType.OFF) {
textToSpeechVolume = 0; textToSpeechVolume = 0;
} else if (command == OnOffType.ON) { } else if (command == OnOffType.ON) {
@ -680,8 +674,7 @@ public class EchoHandler extends BaseThingHandler implements IEchoThingHandler {
if (command instanceof RefreshType) { if (command instanceof RefreshType) {
this.lastKnownEqualizer = null; this.lastKnownEqualizer = null;
} }
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
DecimalType value = (DecimalType) command;
if (this.lastKnownEqualizer == null) { if (this.lastKnownEqualizer == null) {
updateEqualizerState(); updateEqualizerState();
} }
@ -689,13 +682,13 @@ public class EchoHandler extends BaseThingHandler implements IEchoThingHandler {
if (lastKnownEqualizer != null) { if (lastKnownEqualizer != null) {
JsonEqualizer newEqualizerSetting = lastKnownEqualizer.createClone(); JsonEqualizer newEqualizerSetting = lastKnownEqualizer.createClone();
if (channelId.equals(CHANNEL_EQUALIZER_BASS)) { if (channelId.equals(CHANNEL_EQUALIZER_BASS)) {
newEqualizerSetting.bass = value.intValue(); newEqualizerSetting.bass = decimalCommand.intValue();
} }
if (channelId.equals(CHANNEL_EQUALIZER_MIDRANGE)) { if (channelId.equals(CHANNEL_EQUALIZER_MIDRANGE)) {
newEqualizerSetting.mid = value.intValue(); newEqualizerSetting.mid = decimalCommand.intValue();
} }
if (channelId.equals(CHANNEL_EQUALIZER_TREBLE)) { if (channelId.equals(CHANNEL_EQUALIZER_TREBLE)) {
newEqualizerSetting.treble = value.intValue(); newEqualizerSetting.treble = decimalCommand.intValue();
} }
try { try {
connection.setEqualizer(device, newEqualizerSetting); connection.setEqualizer(device, newEqualizerSetting);

View File

@ -191,8 +191,8 @@ public class SmartHomeDeviceHandler extends BaseThingHandler {
boolean stateFound = false; boolean stateFound = false;
Map<String, List<JsonObject>> mapInterfaceToStates = new HashMap<>(); Map<String, List<JsonObject>> mapInterfaceToStates = new HashMap<>();
SmartHomeDevice firstDevice = null; SmartHomeDevice firstDevice = null;
for (SmartHomeDevice shd : getSupportedSmartHomeDevices(smartHomeBaseDevice, allDevices)) { for (SmartHomeDevice smartHomeDevice : getSupportedSmartHomeDevices(smartHomeBaseDevice, allDevices)) {
String applianceId = shd.applianceId; String applianceId = smartHomeDevice.applianceId;
if (applianceId == null) { if (applianceId == null) {
continue; continue;
} }
@ -210,7 +210,7 @@ public class SmartHomeDeviceHandler extends BaseThingHandler {
} }
} }
if (firstDevice == null) { if (firstDevice == null) {
firstDevice = shd; firstDevice = smartHomeDevice;
} }
for (JsonElement stateElement : states) { for (JsonElement stateElement : states) {
String stateJson = stateElement.getAsString(); String stateJson = stateElement.getAsString();
@ -240,9 +240,9 @@ public class SmartHomeDeviceHandler extends BaseThingHandler {
} }
} }
if (result.needSingleUpdate && smartHomeBaseDevice instanceof SmartHomeDevice && accountHandler != null) { if (result.needSingleUpdate && smartHomeBaseDevice instanceof SmartHomeDevice smartHomeDevice
SmartHomeDevice shd = (SmartHomeDevice) smartHomeBaseDevice; && accountHandler != null) {
accountHandler.forceDelayedSmartHomeStateUpdate(shd.findId()); accountHandler.forceDelayedSmartHomeStateUpdate(smartHomeDevice.findId());
} }
} }
@ -257,8 +257,8 @@ public class SmartHomeDeviceHandler extends BaseThingHandler {
Bridge bridge = getBridge(); Bridge bridge = getBridge();
if (bridge != null) { if (bridge != null) {
BridgeHandler bridgeHandler = bridge.getHandler(); BridgeHandler bridgeHandler = bridge.getHandler();
if (bridgeHandler instanceof AccountHandler) { if (bridgeHandler instanceof AccountHandler accountHandler) {
return (AccountHandler) bridgeHandler; return accountHandler;
} }
} }
@ -297,17 +297,17 @@ public class SmartHomeDeviceHandler extends BaseThingHandler {
if (handlerBase == null || !handlerBase.hasChannel(channelId)) { if (handlerBase == null || !handlerBase.hasChannel(channelId)) {
continue; continue;
} }
for (SmartHomeDevice shd : devices) { for (SmartHomeDevice smartHomeDevice : devices) {
String entityId = shd.entityId; String entityId = smartHomeDevice.entityId;
if (entityId == null) { if (entityId == null) {
continue; continue;
} }
accountHandler.forceDelayedSmartHomeStateUpdate(getId()); // block updates accountHandler.forceDelayedSmartHomeStateUpdate(getId()); // block updates
if (handlerBase.handleCommand(connection, shd, entityId, shd.getCapabilities(), channelUID.getId(), if (handlerBase.handleCommand(connection, smartHomeDevice, entityId,
command)) { smartHomeDevice.getCapabilities(), channelUID.getId(), command)) {
accountHandler.forceDelayedSmartHomeStateUpdate(getId()); // force update again to restart accountHandler.forceDelayedSmartHomeStateUpdate(getId()); // force update again to restart
// update timer // update timer
logger.debug("Command {} sent to {}", command, shd.findId()); logger.debug("Command {} sent to {}", command, smartHomeDevice.findId());
} }
} }
} }
@ -318,9 +318,8 @@ public class SmartHomeDeviceHandler extends BaseThingHandler {
private static void getCapabilities(Map<String, List<SmartHomeCapability>> result, AccountHandler accountHandler, private static void getCapabilities(Map<String, List<SmartHomeCapability>> result, AccountHandler accountHandler,
SmartHomeBaseDevice device) { SmartHomeBaseDevice device) {
if (device instanceof SmartHomeDevice) { if (device instanceof SmartHomeDevice smartHomeDevice) {
SmartHomeDevice shd = (SmartHomeDevice) device; for (SmartHomeCapability capability : smartHomeDevice.getCapabilities()) {
for (SmartHomeCapability capability : shd.getCapabilities()) {
String interfaceName = capability.interfaceName; String interfaceName = capability.interfaceName;
if (interfaceName != null) { if (interfaceName != null) {
Objects.requireNonNull(result.computeIfAbsent(interfaceName, name -> new ArrayList<>())) Objects.requireNonNull(result.computeIfAbsent(interfaceName, name -> new ArrayList<>()))
@ -329,9 +328,9 @@ public class SmartHomeDeviceHandler extends BaseThingHandler {
} }
} }
if (device instanceof SmartHomeGroup) { if (device instanceof SmartHomeGroup) {
for (SmartHomeDevice shd : getSupportedSmartHomeDevices(device, for (SmartHomeDevice smartHomeDevice : getSupportedSmartHomeDevices(device,
accountHandler.getLastKnownSmartHomeDevices())) { accountHandler.getLastKnownSmartHomeDevices())) {
getCapabilities(result, accountHandler, shd); getCapabilities(result, accountHandler, smartHomeDevice);
} }
} }
} }
@ -342,29 +341,28 @@ public class SmartHomeDeviceHandler extends BaseThingHandler {
return Collections.emptySet(); return Collections.emptySet();
} }
Set<SmartHomeDevice> result = new HashSet<>(); Set<SmartHomeDevice> result = new HashSet<>();
if (baseDevice instanceof SmartHomeDevice) { if (baseDevice instanceof SmartHomeDevice smartHomeDevice) {
SmartHomeDevice shd = (SmartHomeDevice) baseDevice; if (smartHomeDevice.getCapabilities().stream().map(capability -> capability.interfaceName)
if (shd.getCapabilities().stream().map(capability -> capability.interfaceName)
.anyMatch(SUPPORTED_INTERFACES::contains)) { .anyMatch(SUPPORTED_INTERFACES::contains)) {
result.add(shd); result.add(smartHomeDevice);
} }
} else { } else {
SmartHomeGroup shg = (SmartHomeGroup) baseDevice; SmartHomeGroup smartHomeGroup = (SmartHomeGroup) baseDevice;
for (SmartHomeBaseDevice device : allDevices) { for (SmartHomeBaseDevice device : allDevices) {
if (device instanceof SmartHomeDevice) { if (device instanceof SmartHomeDevice smartHomeDevice) {
SmartHomeDevice shd = (SmartHomeDevice) device; JsonSmartHomeTags.JsonSmartHomeTag tags = smartHomeDevice.tags;
JsonSmartHomeTags.JsonSmartHomeTag tags = shd.tags;
if (tags != null) { if (tags != null) {
JsonSmartHomeGroupIdentity.SmartHomeGroupIdentity tagNameToValueSetMap = tags.tagNameToValueSetMap; JsonSmartHomeGroupIdentity.SmartHomeGroupIdentity tagNameToValueSetMap = tags.tagNameToValueSetMap;
JsonSmartHomeGroupIdentifiers.SmartHomeGroupIdentifier applianceGroupIdentifier = shg.applianceGroupIdentifier; JsonSmartHomeGroupIdentifiers.SmartHomeGroupIdentifier applianceGroupIdentifier = smartHomeGroup.applianceGroupIdentifier;
if (tagNameToValueSetMap != null) { if (tagNameToValueSetMap != null) {
List<String> groupIdentity = Objects.requireNonNullElse(tagNameToValueSetMap.groupIdentity, List<String> groupIdentity = Objects.requireNonNullElse(tagNameToValueSetMap.groupIdentity,
List.of()); List.of());
if (applianceGroupIdentifier != null && applianceGroupIdentifier.value != null if (applianceGroupIdentifier != null && applianceGroupIdentifier.value != null
&& groupIdentity.contains(applianceGroupIdentifier.value)) { && groupIdentity.contains(applianceGroupIdentifier.value)) {
if (shd.getCapabilities().stream().map(capability -> capability.interfaceName) if (smartHomeDevice.getCapabilities().stream()
.map(capability -> capability.interfaceName)
.anyMatch(SUPPORTED_INTERFACES::contains)) { .anyMatch(SUPPORTED_INTERFACES::contains)) {
result.add(shd); result.add(smartHomeDevice);
} }
} }
} }

View File

@ -55,12 +55,11 @@ public class DynamicStateDescriptionSmartHome implements DynamicStateDescription
return null; return null;
} }
ThingHandler handler = thing.getHandler(); ThingHandler handler = thing.getHandler();
if (!(handler instanceof SmartHomeDeviceHandler)) { if (handler instanceof SmartHomeDeviceHandler smartHomeHandler) {
return null;
}
SmartHomeDeviceHandler smartHomeHandler = (SmartHomeDeviceHandler) handler;
return smartHomeHandler; return smartHomeHandler;
} }
return null;
}
@Override @Override
public @Nullable StateDescription getStateDescription(Channel channel, public @Nullable StateDescription getStateDescription(Channel channel,

View File

@ -263,11 +263,10 @@ public class AmbientWeatherEventListener {
private void handleError(String event, Object... args) { private void handleError(String event, Object... args) {
String reason = "Unknown"; String reason = "Unknown";
if (args.length > 0) { if (args.length > 0) {
if (args[0] instanceof String) { if (args[0] instanceof String stringArg) {
reason = (String) args[0]; reason = stringArg;
} else if (args[0] instanceof Exception) { } else if (args[0] instanceof Exception exception) {
reason = String.format("Exception=%s Message=%s", args[0].getClass(), reason = String.format("Exception=%s Message=%s", args[0].getClass(), exception.getMessage());
((Exception) args[0]).getMessage());
} }
} }
logger.debug("Listener: Received socket event: {}, Reason: {}", event, reason); logger.debug("Listener: Received socket event: {}, Reason: {}", event, reason);

View File

@ -39,7 +39,7 @@ public enum StreamCommand {
@Override @Override
public String toString() { public String toString() {
return String.valueOf(value); return value;
} }
public static StreamCommand fromValue(String value) { public static StreamCommand fromValue(String value) {

View File

@ -109,8 +109,8 @@ public class AmpliPiGroupHandler extends BaseThingHandler implements AmpliPiStat
} }
break; break;
case AmpliPiBindingConstants.CHANNEL_VOLUME: case AmpliPiBindingConstants.CHANNEL_VOLUME:
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
update.setVolDelta(AmpliPiUtils.percentTypeToVolume((PercentType) command)); update.setVolDelta(AmpliPiUtils.percentTypeToVolume(percentCommand));
} else if (command instanceof IncreaseDecreaseType) { } else if (command instanceof IncreaseDecreaseType) {
if (groupState != null) { if (groupState != null) {
if (IncreaseDecreaseType.INCREASE.equals(command)) { if (IncreaseDecreaseType.INCREASE.equals(command)) {
@ -125,14 +125,13 @@ public class AmpliPiGroupHandler extends BaseThingHandler implements AmpliPiStat
} }
break; break;
case AmpliPiBindingConstants.CHANNEL_SOURCE: case AmpliPiBindingConstants.CHANNEL_SOURCE:
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
update.setSourceId(((DecimalType) command).intValue()); update.setSourceId(decimalCommand.intValue());
} }
break; break;
} }
if (bridgeHandler != null) { if (bridgeHandler != null) {
String url = bridgeHandler.getUrl() + "/api/groups/" + getId(thing); String url = bridgeHandler.getUrl() + "/api/groups/" + getId(thing);
;
StringContentProvider contentProvider = new StringContentProvider(gson.toJson(update)); StringContentProvider contentProvider = new StringContentProvider(gson.toJson(update));
try { try {
ContentResponse response = httpClient.newRequest(url).method(HttpMethod.PATCH) ContentResponse response = httpClient.newRequest(url).method(HttpMethod.PATCH)

View File

@ -99,12 +99,11 @@ public class AmpliPiHandler extends BaseBridgeHandler {
if (CHANNEL_PRESET.equals(channelUID.getId())) { if (CHANNEL_PRESET.equals(channelUID.getId())) {
if (command instanceof RefreshType) { if (command instanceof RefreshType) {
updateState(channelUID, UnDefType.NULL); updateState(channelUID, UnDefType.NULL);
} else if (command instanceof DecimalType) { } else if (command instanceof DecimalType decimalCommand) {
DecimalType preset = (DecimalType) command;
try { try {
ContentResponse response = this.httpClient ContentResponse response = this.httpClient
.newRequest(url + "/api/presets/" + preset.intValue() + "/load").method(HttpMethod.POST) .newRequest(url + "/api/presets/" + decimalCommand.intValue() + "/load")
.timeout(REQUEST_TIMEOUT, TimeUnit.MILLISECONDS).send(); .method(HttpMethod.POST).timeout(REQUEST_TIMEOUT, TimeUnit.MILLISECONDS).send();
if (response.getStatus() != HttpStatus.OK_200) { if (response.getStatus() != HttpStatus.OK_200) {
logger.error("AmpliPi API returned HTTP status {}.", response.getStatus()); logger.error("AmpliPi API returned HTTP status {}.", response.getStatus());
logger.debug("Content: {}", response.getContentAsString()); logger.debug("Content: {}", response.getContentAsString());
@ -115,11 +114,10 @@ public class AmpliPiHandler extends BaseBridgeHandler {
} }
} }
} else if (channelUID.getId().startsWith(CHANNEL_INPUT)) { } else if (channelUID.getId().startsWith(CHANNEL_INPUT)) {
if (command instanceof StringType) { if (command instanceof StringType stringCommand) {
StringType input = (StringType) command;
int source = Integer.valueOf(channelUID.getId().substring(CHANNEL_INPUT.length())) - 1; int source = Integer.valueOf(channelUID.getId().substring(CHANNEL_INPUT.length())) - 1;
SourceUpdate update = new SourceUpdate(); SourceUpdate update = new SourceUpdate();
update.setInput(input.toString()); update.setInput(stringCommand.toString());
try { try {
StringContentProvider contentProvider = new StringContentProvider(gson.toJson(update)); StringContentProvider contentProvider = new StringContentProvider(gson.toJson(update));
ContentResponse response = this.httpClient.newRequest(url + "/api/sources/" + source) ContentResponse response = this.httpClient.newRequest(url + "/api/sources/" + source)

View File

@ -109,8 +109,8 @@ public class AmpliPiZoneHandler extends BaseThingHandler implements AmpliPiStatu
} }
break; break;
case AmpliPiBindingConstants.CHANNEL_VOLUME: case AmpliPiBindingConstants.CHANNEL_VOLUME:
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
update.setVol(AmpliPiUtils.percentTypeToVolume((PercentType) command)); update.setVol(AmpliPiUtils.percentTypeToVolume(percentCommand));
} else if (command instanceof IncreaseDecreaseType) { } else if (command instanceof IncreaseDecreaseType) {
if (zoneState != null) { if (zoneState != null) {
if (IncreaseDecreaseType.INCREASE.equals(command)) { if (IncreaseDecreaseType.INCREASE.equals(command)) {
@ -125,8 +125,8 @@ public class AmpliPiZoneHandler extends BaseThingHandler implements AmpliPiStatu
} }
break; break;
case AmpliPiBindingConstants.CHANNEL_SOURCE: case AmpliPiBindingConstants.CHANNEL_SOURCE:
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
update.setSourceId(((DecimalType) command).intValue()); update.setSourceId(decimalCommand.intValue());
} }
break; break;
} }

View File

@ -65,7 +65,7 @@ public class InputStateOptionProvider extends BaseDynamicStateDescriptionProvide
} }
private @Nullable String getLabel(Stream stream) { private @Nullable String getLabel(Stream stream) {
if (stream.getType().equals("internetradio")) { if ("internetradio".equals(stream.getType())) {
return stream.getName(); return stream.getName();
} else { } else {
return stream.getType().substring(0, 1).toUpperCase() + stream.getType().substring(1); return stream.getType().substring(0, 1).toUpperCase() + stream.getType().substring(1);

View File

@ -54,10 +54,9 @@ public class AmpliPiMDNSDiscoveryParticipant implements MDNSDiscoveryParticipant
public @Nullable DiscoveryResult createResult(ServiceInfo service) { public @Nullable DiscoveryResult createResult(ServiceInfo service) {
ThingUID uid = getThingUID(service); ThingUID uid = getThingUID(service);
if (uid != null) { if (uid != null) {
DiscoveryResult result = DiscoveryResultBuilder.create(uid).withLabel("AmpliPi Controller") return DiscoveryResultBuilder.create(uid).withLabel("AmpliPi Controller")
.withProperty(AmpliPiBindingConstants.CFG_PARAM_HOSTNAME, getIpAddress(service).getHostAddress()) .withProperty(AmpliPiBindingConstants.CFG_PARAM_HOSTNAME, getIpAddress(service).getHostAddress())
.withRepresentationProperty(AmpliPiBindingConstants.CFG_PARAM_HOSTNAME).build(); .withRepresentationProperty(AmpliPiBindingConstants.CFG_PARAM_HOSTNAME).build();
return result;
} else { } else {
return null; return null;
} }
@ -68,7 +67,7 @@ public class AmpliPiMDNSDiscoveryParticipant implements MDNSDiscoveryParticipant
if (service.getName().equals(AMPLIPI_API)) { if (service.getName().equals(AMPLIPI_API)) {
InetAddress ip = getIpAddress(service); InetAddress ip = getIpAddress(service);
if (ip != null) { if (ip != null) {
String id = ip.toString().substring(1).replaceAll("\\.", ""); String id = ip.toString().substring(1).replace(".", "");
return new ThingUID(AmpliPiBindingConstants.THING_TYPE_CONTROLLER, id); return new ThingUID(AmpliPiBindingConstants.THING_TYPE_CONTROLLER, id);
} }
} }

View File

@ -246,13 +246,13 @@ public class AndroidDebugBridgeDevice {
AndroidDebugBridgeDeviceReadException, TimeoutException, ExecutionException { AndroidDebugBridgeDeviceReadException, TimeoutException, ExecutionException {
if (isAtLeastVersion(12)) { if (isAtLeastVersion(12)) {
String devicesResp = runAdbShell("getprop", "debug.tracing.screen_state"); String devicesResp = runAdbShell("getprop", "debug.tracing.screen_state");
return devicesResp.replace("\n", "").equals("2"); return "2".equals(devicesResp.replace("\n", ""));
} }
String devicesResp = runAdbShell("dumpsys", "power", "|", "grep", "'Display Power'"); String devicesResp = runAdbShell("dumpsys", "power", "|", "grep", "'Display Power'");
if (devicesResp.contains("=")) { if (devicesResp.contains("=")) {
try { try {
var state = devicesResp.split("=")[1].trim(); var state = devicesResp.split("=")[1].trim();
return state.equals("ON"); return "ON".equals(state);
} catch (NumberFormatException e) { } catch (NumberFormatException e) {
logger.debug("Unable to parse device screen state: {}", e.getMessage()); logger.debug("Unable to parse device screen state: {}", e.getMessage());
} }

View File

@ -161,7 +161,7 @@ public class AndroidDebugBridgeDiscoveryService extends AbstractDiscoveryService
String brand, String macAddress) { String brand, String macAddress) {
String friendlyName = String.format("%s (%s)", model, ip); String friendlyName = String.format("%s (%s)", model, ip);
thingDiscovered( thingDiscovered(
DiscoveryResultBuilder.create(new ThingUID(THING_TYPE_ANDROID_DEVICE, macAddress.replaceAll(":", ""))) // DiscoveryResultBuilder.create(new ThingUID(THING_TYPE_ANDROID_DEVICE, macAddress.replace(":", ""))) //
.withProperties(Map.of( // .withProperties(Map.of( //
PARAMETER_IP, ip, // PARAMETER_IP, ip, //
PARAMETER_PORT, port, // PARAMETER_PORT, port, //

View File

@ -104,7 +104,7 @@ public class AndroidTVMDNSDiscoveryParticipant implements MDNSDiscoveryParticipa
public @Nullable ThingUID getThingUID(ServiceInfo service) { public @Nullable ThingUID getThingUID(ServiceInfo service) {
String macAddress = service.getPropertyString(MDNS_PROPERTY_MAC_ADDRESS); String macAddress = service.getPropertyString(MDNS_PROPERTY_MAC_ADDRESS);
if (macAddress != null && !macAddress.isBlank()) { if (macAddress != null && !macAddress.isBlank()) {
return new ThingUID(THING_TYPE_ANDROID_DEVICE, macAddress.replaceAll(":", "").toLowerCase()); return new ThingUID(THING_TYPE_ANDROID_DEVICE, macAddress.replace(":", "").toLowerCase());
} }
return null; return null;
} }

View File

@ -104,7 +104,7 @@ public class FireTVStickMDNSDiscoveryParticipant implements MDNSDiscoveryPartici
public @Nullable ThingUID getThingUID(ServiceInfo service) { public @Nullable ThingUID getThingUID(ServiceInfo service) {
String macAddress = service.getPropertyString(MDNS_PROPERTY_MAC_ADDRESS); String macAddress = service.getPropertyString(MDNS_PROPERTY_MAC_ADDRESS);
if (macAddress != null && !macAddress.isBlank()) { if (macAddress != null && !macAddress.isBlank()) {
return new ThingUID(THING_TYPE_ANDROID_DEVICE, macAddress.replaceAll(":", "").toLowerCase()); return new ThingUID(THING_TYPE_ANDROID_DEVICE, macAddress.replace(":", "").toLowerCase());
} }
return null; return null;
} }

View File

@ -135,8 +135,8 @@ public class AnelStateUpdaterTest implements IAnelTestStatus, IAnelConstants {
private void assertTemperature(@Nullable State state, double value) { private void assertTemperature(@Nullable State state, double value) {
assertThat(state, isA(QuantityType.class)); assertThat(state, isA(QuantityType.class));
if (state instanceof QuantityType<?>) { if (state instanceof QuantityType<?> temperature) {
assertThat(((QuantityType<?>) state).doubleValue(), closeTo(value, 0.0001d)); assertThat(temperature.doubleValue(), closeTo(value, 0.0001d));
} }
} }
} }

View File

@ -144,7 +144,7 @@ public class AnelUdpConnectorTest {
// toggle state of switch 1 // toggle state of switch 1
final String auth = AnelAuthentication.getUserPasswordString(USER, PASSWORD, AuthMethod.of(status)); final String auth = AnelAuthentication.getUserPasswordString(USER, PASSWORD, AuthMethod.of(status));
final String command = "Sw_" + (switch1state ? "off" : "on") + String.valueOf(switchNr) + auth; final String command = "Sw_" + (switch1state ? "off" : "on") + switchNr + auth;
final String status2 = sendAndReceiveSingle(command); final String status2 = sendAndReceiveSingle(command);
// assert new state of switch 1 // assert new state of switch 1

View File

@ -22,26 +22,40 @@ import org.eclipse.jdt.annotation.NonNullByDefault;
@NonNullByDefault @NonNullByDefault
public interface IAnelTestStatus { public interface IAnelTestStatus {
String STATUS_INVALID_NAME = "NET-PwrCtrl:NET-CONTROL :192.168.6.63:255.255.255.0:192.168.6.1:0.4.163.21.4.71:" String STATUS_INVALID_NAME = """
+ "Nr. 1,0:Nr. 2,1:Nr: 3,1:Nr. 4,0:Nr. 5,0:Nr. 6,0:Nr. 7,0:Nr. 8,0:248:80:NET-PWRCTRL_04.6:H:xor:"; NET-PwrCtrl:NET-CONTROL :192.168.6.63:255.255.255.0:192.168.6.1:0.4.163.21.4.71:\
String STATUS_HUT_V61_POW = "NET-PwrCtrl:NET-CONTROL :192.168.178.148:255.255.255.0:192.168.178.1:0.4.163.10.9.107:" Nr. 1,0:Nr. 2,1:Nr: 3,1:Nr. 4,0:Nr. 5,0:Nr. 6,0:Nr. 7,0:Nr. 8,0:248:80:NET-PWRCTRL_04.6:H:xor:\
+ "Nr. 1,1:Nr. 2,1:Nr. 3,1:Nr. 4,0:Nr. 5,0:Nr. 6,0:Nr. 7,1:Nr. 8,1:0:80:" """;
+ "IO-1,0,0:IO-2,0,0:IO-3,0,0:IO-4,0,0:IO-5,0,0:IO-6,0,0:IO-7,0,0:IO-8,0,0:27.7°C:NET-PWRCTRL_06.1:h:" String STATUS_HUT_V61_POW = """
+ "p:225.9:0.0004:50.056:0.04:0.00:0.0:1.0000:xor:"; NET-PwrCtrl:NET-CONTROL :192.168.178.148:255.255.255.0:192.168.178.1:0.4.163.10.9.107:\
String STATUS_HUT_V61_SENSOR = "NET-PwrCtrl:NET-CONTROL :192.168.178.148:255.255.255.0:192.168.178.1:0.4.163.10.9.107:" Nr. 1,1:Nr. 2,1:Nr. 3,1:Nr. 4,0:Nr. 5,0:Nr. 6,0:Nr. 7,1:Nr. 8,1:0:80:\
+ "Nr. 1,1:Nr. 2,1:Nr. 3,1:Nr. 4,0:Nr. 5,0:Nr. 6,0:Nr. 7,1:Nr. 8,1:0:80:" IO-1,0,0:IO-2,0,0:IO-3,0,0:IO-4,0,0:IO-5,0,0:IO-6,0,0:IO-7,0,0:IO-8,0,0:27.7°C:NET-PWRCTRL_06.1:h:\
+ "IO-1,0,0:IO-2,0,0:IO-3,0,0:IO-4,0,0:IO-5,0,0:IO-6,0,0:IO-7,0,0:IO-8,0,0:27.7°C:NET-PWRCTRL_06.1:h:" p:225.9:0.0004:50.056:0.04:0.00:0.0:1.0000:xor:\
+ "n:s:20.61:40.7:7.0:xor:"; """;
String STATUS_HUT_V61_POW_SENSOR = "NET-PwrCtrl:NET-CONTROL :192.168.178.148:255.255.255.0:192.168.178.1:0.4.163.10.9.107:" String STATUS_HUT_V61_SENSOR = """
+ "Nr. 1,1:Nr. 2,1:Nr. 3,1:Nr. 4,0:Nr. 5,0:Nr. 6,0:Nr. 7,1:Nr. 8,1:0:80:" NET-PwrCtrl:NET-CONTROL :192.168.178.148:255.255.255.0:192.168.178.1:0.4.163.10.9.107:\
+ "IO-1,0,0:IO-2,0,0:IO-3,0,0:IO-4,0,0:IO-5,0,0:IO-6,0,0:IO-7,0,0:IO-8,0,0:27.7°C:NET-PWRCTRL_06.1:h:" Nr. 1,1:Nr. 2,1:Nr. 3,1:Nr. 4,0:Nr. 5,0:Nr. 6,0:Nr. 7,1:Nr. 8,1:0:80:\
+ "p:225.9:0.0004:50.056:0.04:0.00:0.0:1.0000:s:20.61:40.7:7.0:xor"; IO-1,0,0:IO-2,0,0:IO-3,0,0:IO-4,0,0:IO-5,0,0:IO-6,0,0:IO-7,0,0:IO-8,0,0:27.7°C:NET-PWRCTRL_06.1:h:\
String STATUS_HUT_V5 = "NET-PwrCtrl:ANEL1 :192.168.0.244:255.255.255.0:192.168.0.1:0.5.163.14.7.91:" n:s:20.61:40.7:7.0:xor:\
+ "hoch,0:links hoch,0:runter,0:rechts run,0:runter,0:hoch,0:links runt,0:rechts hoc,0:0:80:" """;
+ "WHN_UP,1,1:LI_DOWN,1,1:RE_DOWN,1,1:LI_UP,1,1:RE_UP,1,1:DOWN,1,1:DOWN,1,1:UP,1,1:27.3°C:NET-PWRCTRL_05.0"; String STATUS_HUT_V61_POW_SENSOR = """
String STATUS_HUT_V65 = "NET-PwrCtrl:NET-CONTROL :192.168.0.64:255.255.255.0:192.168.6.1:0.5.163.17.9.116:" NET-PwrCtrl:NET-CONTROL :192.168.178.148:255.255.255.0:192.168.178.1:0.4.163.10.9.107:\
+ "Nr.1,0:Nr.2,1:Nr.3,0:Nr.4,1:Nr.5,0:Nr.6,1:Nr.7,0:Nr.8,1:248:80:" Nr. 1,1:Nr. 2,1:Nr. 3,1:Nr. 4,0:Nr. 5,0:Nr. 6,0:Nr. 7,1:Nr. 8,1:0:80:\
+ "IO-1,0,0:IO-2,0,0:IO-3,0,0:IO-4,0,0:IO-5,1,0:IO-6,1,0:IO-7,1,0:IO-8,1,0:27.0<EFBFBD>C:NET-PWRCTRL_06.5:h:n:xor:"; IO-1,0,0:IO-2,0,0:IO-3,0,0:IO-4,0,0:IO-5,0,0:IO-6,0,0:IO-7,0,0:IO-8,0,0:27.7°C:NET-PWRCTRL_06.1:h:\
String STATUS_HOME_V46 = "NET-PwrCtrl:NET-CONTROL :192.168.0.63:255.255.255.0:192.168.6.1:0.5.163.21.4.71:" p:225.9:0.0004:50.056:0.04:0.00:0.0:1.0000:s:20.61:40.7:7.0:xor\
+ "Nr. 1,1:Nr. 2,0:Nr. 3,1:Nr. 4,0:Nr. 5,1:Nr. 6,0:Nr. 7,1:Nr. 8,0:248:80:NET-PWRCTRL_04.6:H:xor:"; """;
String STATUS_HUT_V5 = """
NET-PwrCtrl:ANEL1 :192.168.0.244:255.255.255.0:192.168.0.1:0.5.163.14.7.91:\
hoch,0:links hoch,0:runter,0:rechts run,0:runter,0:hoch,0:links runt,0:rechts hoc,0:0:80:\
WHN_UP,1,1:LI_DOWN,1,1:RE_DOWN,1,1:LI_UP,1,1:RE_UP,1,1:DOWN,1,1:DOWN,1,1:UP,1,1:27.3°C:NET-PWRCTRL_05.0\
""";
String STATUS_HUT_V65 = """
NET-PwrCtrl:NET-CONTROL :192.168.0.64:255.255.255.0:192.168.6.1:0.5.163.17.9.116:\
Nr.1,0:Nr.2,1:Nr.3,0:Nr.4,1:Nr.5,0:Nr.6,1:Nr.7,0:Nr.8,1:248:80:\
IO-1,0,0:IO-2,0,0:IO-3,0,0:IO-4,0,0:IO-5,1,0:IO-6,1,0:IO-7,1,0:IO-8,1,0:27.0<EFBFBD>C:NET-PWRCTRL_06.5:h:n:xor:\
""";
String STATUS_HOME_V46 = """
NET-PwrCtrl:NET-CONTROL :192.168.0.63:255.255.255.0:192.168.6.1:0.5.163.21.4.71:\
Nr. 1,1:Nr. 2,0:Nr. 3,1:Nr. 4,0:Nr. 5,1:Nr. 6,0:Nr. 7,1:Nr. 8,0:248:80:NET-PWRCTRL_04.6:H:xor:\
""";
} }

View File

@ -116,7 +116,7 @@ public class AnthemHandler extends BaseThingHandler {
@Override @Override
public void handleCommand(ChannelUID channelUID, Command command) { public void handleCommand(ChannelUID channelUID, Command command) {
logger.trace("Command {} received for channel {}", command, channelUID.getId().toString()); logger.trace("Command {} received for channel {}", command, channelUID.getId());
String groupId = channelUID.getGroupId(); String groupId = channelUID.getGroupId();
if (groupId == null) { if (groupId == null) {
return; return;
@ -166,8 +166,8 @@ public class AnthemHandler extends BaseThingHandler {
} }
break; break;
case CHANNEL_VOLUME_DB: case CHANNEL_VOLUME_DB:
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
sendCommand(AnthemCommand.volume(zone, ((DecimalType) command).intValue())); sendCommand(AnthemCommand.volume(zone, decimalCommand.intValue()));
} }
break; break;
case CHANNEL_MUTE: case CHANNEL_MUTE:
@ -180,8 +180,8 @@ public class AnthemHandler extends BaseThingHandler {
} }
break; break;
case CHANNEL_ACTIVE_INPUT: case CHANNEL_ACTIVE_INPUT:
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
sendCommand(AnthemCommand.activeInput(zone, ((DecimalType) command).intValue())); sendCommand(AnthemCommand.activeInput(zone, decimalCommand.intValue()));
} }
break; break;
default: default:

View File

@ -52,8 +52,8 @@ public class AstroActions implements ThingActions {
@Override @Override
public void setThingHandler(@Nullable ThingHandler handler) { public void setThingHandler(@Nullable ThingHandler handler) {
if (handler instanceof AstroThingHandler) { if (handler instanceof AstroThingHandler thingHandler) {
this.handler = (AstroThingHandler) handler; this.handler = thingHandler;
} }
} }
@ -115,10 +115,9 @@ public class AstroActions implements ThingActions {
try { try {
AstroThingHandler theHandler = this.handler; AstroThingHandler theHandler = this.handler;
if (theHandler != null) { if (theHandler != null) {
if (theHandler instanceof SunHandler) { if (theHandler instanceof SunHandler sunHandler) {
SunHandler handler = (SunHandler) theHandler;
SunPhaseName phase = SunPhaseName.valueOf(phaseName.toUpperCase()); SunPhaseName phase = SunPhaseName.valueOf(phaseName.toUpperCase());
return handler.getEventTime(phase, date != null ? date : ZonedDateTime.now(), return sunHandler.getEventTime(phase, date != null ? date : ZonedDateTime.now(),
moment == null || AstroBindingConstants.EVENT_START.equalsIgnoreCase(moment)); moment == null || AstroBindingConstants.EVENT_START.equalsIgnoreCase(moment));
} else { } else {
logger.info("Astro Action service ThingHandler is not a SunHandler!"); logger.info("Astro Action service ThingHandler is not a SunHandler!");

View File

@ -490,8 +490,7 @@ public class MoonCalc {
double m1 = 134.9634114 + 477198.8676313 * t + .008997 * t * t + t * t * t / 69699 - t * t * t * t / 14712000; double m1 = 134.9634114 + 477198.8676313 * t + .008997 * t * t + t * t * t / 69699 - t * t * t * t / 14712000;
double f = 93.27209929999999 + 483202.0175273 * t - .0034029 * t * t - t * t * t / 3526000 double f = 93.27209929999999 + 483202.0175273 * t - .0034029 * t * t - t * t * t / 3526000
+ t * t * t * t / 863310000; + t * t * t * t / 863310000;
double sr = 385000.56 + getCoefficient(d, m, m1, f) / 1000; return 385000.56 + getCoefficient(d, m, m1, f) / 1000;
return sr;
} }
private double[] calcMoon(double t) { private double[] calcMoon(double t) {
@ -540,7 +539,7 @@ public class MoonCalc {
private double SINALT(double moonJd, int hour, double lambda, double cphi, double sphi) { private double SINALT(double moonJd, int hour, double lambda, double cphi, double sphi) {
double jdo = moonJd + hour / 24.0; double jdo = moonJd + hour / 24.0;
double t = (jdo - 51544.5) / 36525.0; double t = (jdo - 51544.5) / 36525.0;
double decra[] = calcMoon(t); double[] decra = calcMoon(t);
double tau = 15.0 * (LMST(jdo, lambda) - decra[1]); double tau = 15.0 * (LMST(jdo, lambda) - decra[1]);
return sphi * SN(decra[0]) + cphi * CS(decra[0]) * CS(tau); return sphi * SN(decra[0]) + cphi * CS(decra[0]) * CS(tau);
} }
@ -688,12 +687,12 @@ public class MoonCalc {
double moonLon = mod2Pi(n2 + Math.atan2(Math.sin(l3 - n2) * Math.cos(i), Math.cos(l3 - n2))); double moonLon = mod2Pi(n2 + Math.atan2(Math.sin(l3 - n2) * Math.cos(i), Math.cos(l3 - n2)));
double moonLat = Math.asin(Math.sin(l3 - n2) * Math.sin(i)); double moonLat = Math.asin(Math.sin(l3 - n2) * Math.sin(i));
double raDec[] = ecl2Equ(moonLat, moonLon, julianDate); double[] raDec = ecl2Equ(moonLat, moonLon, julianDate);
double distance = (1 - 0.00301401) / (1 + 0.054900 * Math.cos(mMoon2 + ec)) * 384401; double distance = (1 - 0.00301401) / (1 + 0.054900 * Math.cos(mMoon2 + ec)) * 384401;
double raDecTopo[] = geoEqu2TopoEqu(raDec, distance, lat, lmst); double[] raDecTopo = geoEqu2TopoEqu(raDec, distance, lat, lmst);
double azAlt[] = equ2AzAlt(raDecTopo[0], raDecTopo[1], lat, lmst); double[] azAlt = equ2AzAlt(raDecTopo[0], raDecTopo[1], lat, lmst);
Position position = moon.getPosition(); Position position = moon.getPosition();
position.setAzimuth(azAlt[0] * SunCalc.RAD2DEG); position.setAzimuth(azAlt[0] * SunCalc.RAD2DEG);

View File

@ -22,7 +22,6 @@ import java.time.ZonedDateTime;
import java.util.Arrays; import java.util.Arrays;
import java.util.Calendar; import java.util.Calendar;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.Date; import java.util.Date;
import java.util.HashSet; import java.util.HashSet;
import java.util.Iterator; import java.util.Iterator;
@ -366,6 +365,6 @@ public abstract class AstroThingHandler extends BaseThingHandler {
@Override @Override
public Collection<Class<? extends ThingHandlerService>> getServices() { public Collection<Class<? extends ThingHandlerService>> getServices() {
return Collections.singletonList(AstroActions.class); return List.of(AstroActions.class);
} }
} }

View File

@ -12,7 +12,6 @@
*/ */
package org.openhab.binding.astro.internal.job; package org.openhab.binding.astro.internal.job;
import static java.util.Collections.singletonList;
import static java.util.stream.Collectors.toList; import static java.util.stream.Collectors.toList;
import static org.openhab.binding.astro.internal.AstroBindingConstants.*; import static org.openhab.binding.astro.internal.AstroBindingConstants.*;
import static org.openhab.binding.astro.internal.util.DateTimeUtils.*; import static org.openhab.binding.astro.internal.util.DateTimeUtils.*;
@ -72,7 +71,7 @@ public interface Job extends SchedulerRunnable, Runnable {
*/ */
static void scheduleEvent(String thingUID, AstroThingHandler astroHandler, Calendar eventAt, String event, static void scheduleEvent(String thingUID, AstroThingHandler astroHandler, Calendar eventAt, String event,
String channelId, boolean configAlreadyApplied) { String channelId, boolean configAlreadyApplied) {
scheduleEvent(thingUID, astroHandler, eventAt, singletonList(event), channelId, configAlreadyApplied); scheduleEvent(thingUID, astroHandler, eventAt, List.of(event), channelId, configAlreadyApplied);
} }
/** /**

View File

@ -53,9 +53,8 @@ public final class SunPhaseJob extends AbstractJob {
Channel phaseNameChannel = astroHandler.getThing().getChannel(CHANNEL_ID_SUN_PHASE_NAME); Channel phaseNameChannel = astroHandler.getThing().getChannel(CHANNEL_ID_SUN_PHASE_NAME);
if (phaseNameChannel != null) { if (phaseNameChannel != null) {
Planet planet = astroHandler.getPlanet(); Planet planet = astroHandler.getPlanet();
if (planet != null && planet instanceof Sun) { if (planet instanceof Sun theSun) {
final Sun typedSun = (Sun) planet; theSun.getPhase().setName(sunPhaseName);
typedSun.getPhase().setName(sunPhaseName);
astroHandler.publishChannelIfLinked(phaseNameChannel.getUID()); astroHandler.publishChannelIfLinked(phaseNameChannel.getUID());
} }
} else { } else {

View File

@ -23,5 +23,5 @@ import org.eclipse.jdt.annotation.NonNullByDefault;
public enum EclipseKind { public enum EclipseKind {
PARTIAL, PARTIAL,
TOTAL, TOTAL,
RING; RING
} }

View File

@ -22,5 +22,5 @@ import org.eclipse.jdt.annotation.NonNullByDefault;
@NonNullByDefault @NonNullByDefault
public enum EclipseType { public enum EclipseType {
SUN, SUN,
MOON; MOON
} }

View File

@ -57,10 +57,9 @@ public class PropertyUtils {
Object value = getPropertyValue(channelUID, instance); Object value = getPropertyValue(channelUID, instance);
if (value == null) { if (value == null) {
return UnDefType.UNDEF; return UnDefType.UNDEF;
} else if (value instanceof State) { } else if (value instanceof State state) {
return (State) value; return state;
} else if (value instanceof Calendar) { } else if (value instanceof Calendar cal) {
Calendar cal = (Calendar) value;
GregorianCalendar gregorianCal = (GregorianCalendar) DateTimeUtils.applyConfig(cal, config); GregorianCalendar gregorianCal = (GregorianCalendar) DateTimeUtils.applyConfig(cal, config);
cal.setTimeZone(TimeZone.getTimeZone(zoneId)); cal.setTimeZone(TimeZone.getTimeZone(zoneId));
ZonedDateTime zoned = gregorianCal.toZonedDateTime().withFixedOffsetZone(); ZonedDateTime zoned = gregorianCal.toZonedDateTime().withFixedOffsetZone();

View File

@ -14,7 +14,6 @@ package org.openhab.binding.atlona.internal;
import static org.openhab.binding.atlona.internal.AtlonaBindingConstants.*; import static org.openhab.binding.atlona.internal.AtlonaBindingConstants.*;
import java.util.Collections;
import java.util.Set; import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
@ -69,7 +68,7 @@ public class AtlonaHandlerFactory extends BaseThingHandlerFactory {
ThingTypeUID thingTypeUID = thing.getThingTypeUID(); ThingTypeUID thingTypeUID = thing.getThingTypeUID();
if (thingTypeUID.equals(THING_TYPE_PRO3_44M)) { if (thingTypeUID.equals(THING_TYPE_PRO3_44M)) {
return new AtlonaPro3Handler(thing, new AtlonaPro3Capabilities(5, 3, Collections.singleton(5), true)); return new AtlonaPro3Handler(thing, new AtlonaPro3Capabilities(5, 3, Set.of(5), true));
} }
if (thingTypeUID.equals(THING_TYPE_PRO3_66M)) { if (thingTypeUID.equals(THING_TYPE_PRO3_66M)) {

View File

@ -197,17 +197,17 @@ public class AtlonaDiscovery extends AbstractDiscoveryService {
String name = msg.substring(0, idx); String name = msg.substring(0, idx);
if ("Host".equalsIgnoreCase(name)) { if ("Host".equalsIgnoreCase(name)) {
host = msg.substring(idx + 1).trim().replaceAll("\"", ""); host = msg.substring(idx + 1).trim().replace("\"", "");
int sep = host.indexOf('_'); int sep = host.indexOf('_');
if (sep >= 0) { if (sep >= 0) {
host = host.substring(sep + 1); host = host.substring(sep + 1);
} }
} else if ("Model".equalsIgnoreCase(name)) { } else if ("Model".equalsIgnoreCase(name)) {
model = msg.substring(idx + 1).trim().replaceAll("\"", ""); model = msg.substring(idx + 1).trim().replace("\"", "");
} else if ("Manufacturer".equalsIgnoreCase(name)) { } else if ("Manufacturer".equalsIgnoreCase(name)) {
manufacturer = msg.substring(idx + 1).trim().replaceAll("\"", ""); manufacturer = msg.substring(idx + 1).trim().replace("\"", "");
} else if ("From".equalsIgnoreCase(name)) { } else if ("From".equalsIgnoreCase(name)) {
from = msg.substring(idx + 1).trim().replaceAll("\"", ""); from = msg.substring(idx + 1).trim().replace("\"", "");
int sep = from.indexOf(':'); int sep = from.indexOf(':');
if (sep >= 0) { if (sep >= 0) {
from = from.substring(0, sep); from = from.substring(0, sep);

View File

@ -349,23 +349,23 @@ public class SocketChannelSession implements SocketSession {
final Object response = responses.poll(1, TimeUnit.SECONDS); final Object response = responses.poll(1, TimeUnit.SECONDS);
if (response != null) { if (response != null) {
if (response instanceof String) { if (response instanceof String stringResponse) {
try { try {
logger.debug("Dispatching response: {}", response); logger.debug("Dispatching response: {}", response);
final SocketSessionListener[] listeners = SocketChannelSession.this.listeners final SocketSessionListener[] listeners = SocketChannelSession.this.listeners
.toArray(new SocketSessionListener[0]); .toArray(new SocketSessionListener[0]);
for (SocketSessionListener listener : listeners) { for (SocketSessionListener listener : listeners) {
listener.responseReceived((String) response); listener.responseReceived(stringResponse);
} }
} catch (Exception e) { } catch (Exception e) {
logger.warn("Exception occurred processing the response '{}': ", response, e); logger.warn("Exception occurred processing the response '{}': ", response, e);
} }
} else if (response instanceof Exception) { } else if (response instanceof Exception exceptionResponse) {
logger.debug("Dispatching exception: {}", response); logger.debug("Dispatching exception: {}", response);
final SocketSessionListener[] listeners = SocketChannelSession.this.listeners final SocketSessionListener[] listeners = SocketChannelSession.this.listeners
.toArray(new SocketSessionListener[0]); .toArray(new SocketSessionListener[0]);
for (SocketSessionListener listener : listeners) { for (SocketSessionListener listener : listeners) {
listener.responseException((Exception) response); listener.responseException(exceptionResponse);
} }
} else { } else {
logger.warn("Unknown response class: {}", response); logger.warn("Unknown response class: {}", response);

View File

@ -133,8 +133,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
if ((m = GROUP_PRIMARY_PATTERN.matcher(group)).matches()) { if ((m = GROUP_PRIMARY_PATTERN.matcher(group)).matches()) {
switch (id) { switch (id) {
case AtlonaPro3Constants.CHANNEL_POWER: case AtlonaPro3Constants.CHANNEL_POWER:
if (command instanceof OnOffType) { if (command instanceof OnOffType onOffCommand) {
final boolean makeOn = ((OnOffType) command) == OnOffType.ON; final boolean makeOn = onOffCommand == OnOffType.ON;
atlonaHandler.setPower(makeOn); atlonaHandler.setPower(makeOn);
} else { } else {
logger.debug("Received a POWER channel command with a non OnOffType: {}", command); logger.debug("Received a POWER channel command with a non OnOffType: {}", command);
@ -143,8 +143,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
break; break;
case AtlonaPro3Constants.CHANNEL_PANELLOCK: case AtlonaPro3Constants.CHANNEL_PANELLOCK:
if (command instanceof OnOffType) { if (command instanceof OnOffType onOffCommand) {
final boolean makeOn = ((OnOffType) command) == OnOffType.ON; final boolean makeOn = onOffCommand == OnOffType.ON;
atlonaHandler.setPanelLock(makeOn); atlonaHandler.setPanelLock(makeOn);
} else { } else {
logger.debug("Received a PANELLOCK channel command with a non OnOffType: {}", command); logger.debug("Received a PANELLOCK channel command with a non OnOffType: {}", command);
@ -152,8 +152,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
break; break;
case AtlonaPro3Constants.CHANNEL_IRENABLE: case AtlonaPro3Constants.CHANNEL_IRENABLE:
if (command instanceof OnOffType) { if (command instanceof OnOffType onOffCommand) {
final boolean makeOn = ((OnOffType) command) == OnOffType.ON; final boolean makeOn = onOffCommand == OnOffType.ON;
atlonaHandler.setIrOn(makeOn); atlonaHandler.setIrOn(makeOn);
} else { } else {
logger.debug("Received an IRLOCK channel command with a non OnOffType: {}", command); logger.debug("Received an IRLOCK channel command with a non OnOffType: {}", command);
@ -232,8 +232,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
switch (id) { switch (id) {
case AtlonaPro3Constants.CHANNEL_PORTOUTPUT: case AtlonaPro3Constants.CHANNEL_PORTOUTPUT:
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
final int inpNbr = ((DecimalType) command).intValue(); final int inpNbr = decimalCommand.intValue();
atlonaHandler.setPortSwitch(inpNbr, portNbr); atlonaHandler.setPortSwitch(inpNbr, portNbr);
} else { } else {
logger.debug("Received a PORTOUTPUT channel command with a non DecimalType: {}", logger.debug("Received a PORTOUTPUT channel command with a non DecimalType: {}",
@ -243,8 +243,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
break; break;
case AtlonaPro3Constants.CHANNEL_PORTPOWER: case AtlonaPro3Constants.CHANNEL_PORTPOWER:
if (command instanceof OnOffType) { if (command instanceof OnOffType onOffCommand) {
final boolean makeOn = ((OnOffType) command) == OnOffType.ON; final boolean makeOn = onOffCommand == OnOffType.ON;
atlonaHandler.setPortPower(portNbr, makeOn); atlonaHandler.setPortPower(portNbr, makeOn);
} else { } else {
logger.debug("Received a PORTPOWER channel command with a non OnOffType: {}", command); logger.debug("Received a PORTPOWER channel command with a non OnOffType: {}", command);
@ -265,8 +265,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
switch (id) { switch (id) {
case AtlonaPro3Constants.CHANNEL_PORTMIRROR: case AtlonaPro3Constants.CHANNEL_PORTMIRROR:
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
final int outPortNbr = ((DecimalType) command).intValue(); final int outPortNbr = decimalCommand.intValue();
if (outPortNbr <= 0) { if (outPortNbr <= 0) {
atlonaHandler.removePortMirror(hdmiPortNbr); atlonaHandler.removePortMirror(hdmiPortNbr);
} else { } else {
@ -285,8 +285,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
.getCallback(); .getCallback();
final State state = callback.getState(AtlonaPro3Constants.CHANNEL_PORTMIRROR); final State state = callback.getState(AtlonaPro3Constants.CHANNEL_PORTMIRROR);
int outPortNbr = 1; int outPortNbr = 1;
if (state != null && state instanceof DecimalType) { if (state instanceof DecimalType decimalCommand) {
outPortNbr = ((DecimalType) state).intValue(); outPortNbr = decimalCommand.intValue();
} }
atlonaHandler.setPortMirror(hdmiPortNbr, outPortNbr); atlonaHandler.setPortMirror(hdmiPortNbr, outPortNbr);
} else { } else {
@ -313,8 +313,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
switch (id) { switch (id) {
case AtlonaPro3Constants.CHANNEL_VOLUME_MUTE: case AtlonaPro3Constants.CHANNEL_VOLUME_MUTE:
if (command instanceof OnOffType) { if (command instanceof OnOffType onOffCommand) {
atlonaHandler.setVolumeMute(portNbr, ((OnOffType) command) == OnOffType.ON); atlonaHandler.setVolumeMute(portNbr, onOffCommand == OnOffType.ON);
} else { } else {
logger.debug("Received a VOLUME MUTE channel command with a non OnOffType: {}", logger.debug("Received a VOLUME MUTE channel command with a non OnOffType: {}",
command); command);
@ -322,8 +322,8 @@ public class AtlonaPro3Handler extends AtlonaHandler<AtlonaPro3Capabilities> {
break; break;
case AtlonaPro3Constants.CHANNEL_VOLUME: case AtlonaPro3Constants.CHANNEL_VOLUME:
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
final int level = ((DecimalType) command).intValue(); final int level = decimalCommand.intValue();
atlonaHandler.setVolume(portNbr, level); atlonaHandler.setVolume(portNbr, level);
} else { } else {
logger.debug("Received a VOLUME channel command with a non DecimalType: {}", command); logger.debug("Received a VOLUME channel command with a non DecimalType: {}", command);

View File

@ -1253,10 +1253,10 @@ class AtlonaPro3PortocolHandler {
*/ */
String getResponse() throws Exception { String getResponse() throws Exception {
final Object lastResponse = responses.poll(5, TimeUnit.SECONDS); final Object lastResponse = responses.poll(5, TimeUnit.SECONDS);
if (lastResponse instanceof String) { if (lastResponse instanceof String stringResponse) {
return (String) lastResponse; return stringResponse;
} else if (lastResponse instanceof Exception) { } else if (lastResponse instanceof Exception exceptionResponse) {
throw (Exception) lastResponse; throw exceptionResponse;
} else if (lastResponse == null) { } else if (lastResponse == null) {
throw new Exception("Didn't receive response in time"); throw new Exception("Didn't receive response in time");
} else { } else {

View File

@ -86,7 +86,7 @@ public class AutelisDiscoveryParticipant implements UpnpDiscoveryParticipant {
device.getDetails().getModelDetails().getModelNumber()); device.getDetails().getModelDetails().getModelNumber());
if (device.getDetails().getManufacturerDetails().getManufacturer().toLowerCase().startsWith(MANUFACTURER)) { if (device.getDetails().getManufacturerDetails().getManufacturer().toLowerCase().startsWith(MANUFACTURER)) {
logger.debug("Autelis Pool Control Found at {}", device.getDetails().getBaseURL()); logger.debug("Autelis Pool Control Found at {}", device.getDetails().getBaseURL());
String id = device.getIdentity().getUdn().getIdentifierString().replaceAll(":", "").toUpperCase(); String id = device.getIdentity().getUdn().getIdentifierString().replace(":", "").toUpperCase();
if (device.getDetails().getModelDetails().getModelNumber().toLowerCase().startsWith(MODEL_PENTAIR)) { if (device.getDetails().getModelDetails().getModelNumber().toLowerCase().startsWith(MODEL_PENTAIR)) {
return new ThingUID(AutelisBindingConstants.PENTAIR_THING_TYPE_UID, id); return new ThingUID(AutelisBindingConstants.PENTAIR_THING_TYPE_UID, id);
} }

View File

@ -14,7 +14,6 @@ package org.openhab.binding.automower.internal.bridge;
import static org.openhab.binding.automower.internal.AutomowerBindingConstants.THING_TYPE_BRIDGE; import static org.openhab.binding.automower.internal.AutomowerBindingConstants.THING_TYPE_BRIDGE;
import java.util.Collections;
import java.util.Optional; import java.util.Optional;
import java.util.Set; import java.util.Set;
import java.util.concurrent.ScheduledFuture; import java.util.concurrent.ScheduledFuture;
@ -49,7 +48,7 @@ public class AutomowerBridgeHandler extends BaseBridgeHandler {
private static final String HUSQVARNA_API_TOKEN_URL = "https://api.authentication.husqvarnagroup.dev/v1/oauth2/token"; private static final String HUSQVARNA_API_TOKEN_URL = "https://api.authentication.husqvarnagroup.dev/v1/oauth2/token";
public static final Set<ThingTypeUID> SUPPORTED_THING_TYPES = Collections.singleton(THING_TYPE_BRIDGE); public static final Set<ThingTypeUID> SUPPORTED_THING_TYPES = Set.of(THING_TYPE_BRIDGE);
private static final long DEFAULT_POLLING_INTERVAL_S = TimeUnit.HOURS.toSeconds(1); private static final long DEFAULT_POLLING_INTERVAL_S = TimeUnit.HOURS.toSeconds(1);
private final OAuthFactory oAuthFactory; private final OAuthFactory oAuthFactory;

View File

@ -14,10 +14,10 @@ package org.openhab.binding.automower.internal.discovery;
import static org.openhab.binding.automower.internal.AutomowerBindingConstants.THING_TYPE_AUTOMOWER; import static org.openhab.binding.automower.internal.AutomowerBindingConstants.THING_TYPE_AUTOMOWER;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Optional; import java.util.Optional;
import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.openhab.binding.automower.internal.AutomowerBindingConstants; import org.openhab.binding.automower.internal.AutomowerBindingConstants;
@ -42,7 +42,7 @@ public class AutomowerDiscoveryService extends AbstractDiscoveryService {
private final AutomowerBridgeHandler bridgeHandler; private final AutomowerBridgeHandler bridgeHandler;
public AutomowerDiscoveryService(AutomowerBridgeHandler bridgeHandler) { public AutomowerDiscoveryService(AutomowerBridgeHandler bridgeHandler) {
super(Collections.singleton(THING_TYPE_AUTOMOWER), 10, false); super(Set.of(THING_TYPE_AUTOMOWER), 10, false);
this.bridgeHandler = bridgeHandler; this.bridgeHandler = bridgeHandler;
} }

View File

@ -18,7 +18,6 @@ import java.time.Instant;
import java.time.ZonedDateTime; import java.time.ZonedDateTime;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.Map; import java.util.Map;
import java.util.Optional; import java.util.Optional;
import java.util.Set; import java.util.Set;
@ -73,7 +72,7 @@ import com.google.gson.Gson;
*/ */
@NonNullByDefault @NonNullByDefault
public class AutomowerHandler extends BaseThingHandler { public class AutomowerHandler extends BaseThingHandler {
public static final Set<ThingTypeUID> SUPPORTED_THING_TYPES = Collections.singleton(THING_TYPE_AUTOMOWER); public static final Set<ThingTypeUID> SUPPORTED_THING_TYPES = Set.of(THING_TYPE_AUTOMOWER);
private static final String NO_ID = "NO_ID"; private static final String NO_ID = "NO_ID";
private static final long DEFAULT_COMMAND_DURATION_MIN = 60; private static final long DEFAULT_COMMAND_DURATION_MIN = 60;
private static final long DEFAULT_POLLING_INTERVAL_S = TimeUnit.MINUTES.toSeconds(10); private static final long DEFAULT_POLLING_INTERVAL_S = TimeUnit.MINUTES.toSeconds(10);
@ -120,8 +119,8 @@ public class AutomowerHandler extends BaseThingHandler {
} }
private Optional<Integer> getCommandValue(Type type) { private Optional<Integer> getCommandValue(Type type) {
if (type instanceof DecimalType) { if (type instanceof DecimalType command) {
return Optional.of(((DecimalType) type).intValue()); return Optional.of(command.intValue());
} }
return Optional.empty(); return Optional.empty();
} }
@ -132,7 +131,7 @@ public class AutomowerHandler extends BaseThingHandler {
@Override @Override
public Collection<Class<? extends ThingHandlerService>> getServices() { public Collection<Class<? extends ThingHandlerService>> getServices() {
return Collections.singleton(AutomowerActions.class); return Set.of(AutomowerActions.class);
} }
@Override @Override
@ -163,8 +162,7 @@ public class AutomowerHandler extends BaseThingHandler {
Bridge bridge = getBridge(); Bridge bridge = getBridge();
if (bridge != null) { if (bridge != null) {
ThingHandler handler = bridge.getHandler(); ThingHandler handler = bridge.getHandler();
if (handler instanceof AutomowerBridgeHandler) { if (handler instanceof AutomowerBridgeHandler bridgeHandler) {
AutomowerBridgeHandler bridgeHandler = (AutomowerBridgeHandler) handler;
return bridgeHandler.getAutomowerBridge(); return bridgeHandler.getAutomowerBridge();
} }
} }

View File

@ -87,8 +87,8 @@ public class AVMFritzDiscoveryService extends AbstractDiscoveryService
@Override @Override
public void setThingHandler(@NonNullByDefault({}) ThingHandler handler) { public void setThingHandler(@NonNullByDefault({}) ThingHandler handler) {
if (handler instanceof AVMFritzBaseBridgeHandler) { if (handler instanceof AVMFritzBaseBridgeHandler baseBridgeHandler) {
bridgeHandler = (AVMFritzBaseBridgeHandler) handler; bridgeHandler = baseBridgeHandler;
} }
} }
@ -128,9 +128,9 @@ public class AVMFritzDiscoveryService extends AbstractDiscoveryService
properties.put(PRODUCT_NAME, device.getProductName()); properties.put(PRODUCT_NAME, device.getProductName());
properties.put(PROPERTY_SERIAL_NUMBER, device.getIdentifier()); properties.put(PROPERTY_SERIAL_NUMBER, device.getIdentifier());
properties.put(PROPERTY_FIRMWARE_VERSION, device.getFirmwareVersion()); properties.put(PROPERTY_FIRMWARE_VERSION, device.getFirmwareVersion());
if (device instanceof GroupModel && ((GroupModel) device).getGroupinfo() != null) { if (device instanceof GroupModel model && model.getGroupinfo() != null) {
properties.put(PROPERTY_MASTER, ((GroupModel) device).getGroupinfo().getMasterdeviceid()); properties.put(PROPERTY_MASTER, model.getGroupinfo().getMasterdeviceid());
properties.put(PROPERTY_MEMBERS, ((GroupModel) device).getGroupinfo().getMembers()); properties.put(PROPERTY_MEMBERS, model.getGroupinfo().getMembers());
} }
DiscoveryResult discoveryResult = DiscoveryResultBuilder.create(thingUID).withProperties(properties) DiscoveryResult discoveryResult = DiscoveryResultBuilder.create(thingUID).withProperties(properties)

View File

@ -17,9 +17,9 @@ import static org.openhab.binding.avmfritz.internal.dto.DeviceModel.ETSUnitInfoM
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set;
import java.util.concurrent.CopyOnWriteArrayList; import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.ScheduledFuture; import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -172,21 +172,21 @@ public abstract class AVMFritzBaseBridgeHandler extends BaseBridgeHandler {
@Override @Override
public void childHandlerInitialized(ThingHandler childHandler, Thing childThing) { public void childHandlerInitialized(ThingHandler childHandler, Thing childThing) {
if (childHandler instanceof FritzAhaStatusListener) { if (childHandler instanceof FritzAhaStatusListener listener) {
registerStatusListener((FritzAhaStatusListener) childHandler); registerStatusListener(listener);
} }
} }
@Override @Override
public void childHandlerDisposed(ThingHandler childHandler, Thing childThing) { public void childHandlerDisposed(ThingHandler childHandler, Thing childThing) {
if (childHandler instanceof FritzAhaStatusListener) { if (childHandler instanceof FritzAhaStatusListener listener) {
unregisterStatusListener((FritzAhaStatusListener) childHandler); unregisterStatusListener(listener);
} }
} }
@Override @Override
public Collection<Class<? extends ThingHandlerService>> getServices() { public Collection<Class<? extends ThingHandlerService>> getServices() {
return Collections.singleton(AVMFritzDiscoveryService.class); return Set.of(AVMFritzDiscoveryService.class);
} }
public boolean registerStatusListener(FritzAhaStatusListener listener) { public boolean registerStatusListener(FritzAhaStatusListener listener) {
@ -327,7 +327,7 @@ public abstract class AVMFritzBaseBridgeHandler extends BaseBridgeHandler {
} else if (device.isSwitchableOutlet()) { } else if (device.isSwitchableOutlet()) {
return GROUP_SWITCH; return GROUP_SWITCH;
} }
} else if (device instanceof DeviceModel && device.isHANFUNUnit()) { } else if (device instanceof DeviceModel deviceModel && device.isHANFUNUnit()) {
if (device.isHANFUNBlinds()) { if (device.isHANFUNBlinds()) {
return DEVICE_HAN_FUN_BLINDS; return DEVICE_HAN_FUN_BLINDS;
} else if (device.isColorLight()) { } else if (device.isColorLight()) {
@ -335,8 +335,7 @@ public abstract class AVMFritzBaseBridgeHandler extends BaseBridgeHandler {
} else if (device.isDimmableLight()) { } else if (device.isDimmableLight()) {
return DEVICE_HAN_FUN_DIMMABLE_BULB; return DEVICE_HAN_FUN_DIMMABLE_BULB;
} }
List<String> interfaces = Arrays List<String> interfaces = Arrays.asList(deviceModel.getEtsiunitinfo().getInterfaces().split(","));
.asList(((DeviceModel) device).getEtsiunitinfo().getInterfaces().split(","));
if (interfaces.contains(HAN_FUN_INTERFACE_ALERT)) { if (interfaces.contains(HAN_FUN_INTERFACE_ALERT)) {
return DEVICE_HAN_FUN_CONTACT; return DEVICE_HAN_FUN_CONTACT;
} else if (interfaces.contains(HAN_FUN_INTERFACE_SIMPLE_BUTTON)) { } else if (interfaces.contains(HAN_FUN_INTERFACE_SIMPLE_BUTTON)) {

View File

@ -187,8 +187,7 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
if (device.isHeatingThermostat()) { if (device.isHeatingThermostat()) {
updateHeatingThermostat(device.getHkr()); updateHeatingThermostat(device.getHkr());
} }
if (device instanceof DeviceModel) { if (device instanceof DeviceModel deviceModel) {
DeviceModel deviceModel = (DeviceModel) device;
if (deviceModel.isTemperatureSensor()) { if (deviceModel.isTemperatureSensor()) {
updateTemperatureSensor(deviceModel.getTemperature()); updateTemperatureSensor(deviceModel.getTemperature());
} }
@ -497,13 +496,12 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
case CHANNEL_COLOR: case CHANNEL_COLOR:
case CHANNEL_BRIGHTNESS: case CHANNEL_BRIGHTNESS:
BigDecimal brightness = null; BigDecimal brightness = null;
if (command instanceof HSBType) { if (command instanceof HSBType hsbCommand) {
HSBType hsbType = (HSBType) command; brightness = hsbCommand.getBrightness().toBigDecimal();
brightness = hsbType.getBrightness().toBigDecimal(); fritzBox.setUnmappedHueAndSaturation(ain, hsbCommand.getHue().intValue(),
fritzBox.setUnmappedHueAndSaturation(ain, hsbType.getHue().intValue(), ColorControlModel.fromPercent(hsbCommand.getSaturation()), 0);
ColorControlModel.fromPercent(hsbType.getSaturation()), 0); } else if (command instanceof PercentType brightnessPercent) {
} else if (command instanceof PercentType) { brightness = brightnessPercent.toBigDecimal();
brightness = ((PercentType) command).toBigDecimal();
} else if (command instanceof OnOffType) { } else if (command instanceof OnOffType) {
fritzBox.setSwitch(ain, OnOffType.ON.equals(command)); fritzBox.setSwitch(ain, OnOffType.ON.equals(command));
} else if (command instanceof IncreaseDecreaseType) { } else if (command instanceof IncreaseDecreaseType) {
@ -525,8 +523,8 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
break; break;
case CHANNEL_COLORTEMPERATURE: case CHANNEL_COLORTEMPERATURE:
BigDecimal colorTemperaturePct = null; BigDecimal colorTemperaturePct = null;
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
colorTemperaturePct = ((PercentType) command).toBigDecimal(); colorTemperaturePct = percentCommand.toBigDecimal();
} }
if (colorTemperaturePct != null) { if (colorTemperaturePct != null) {
int pct = colorTemperaturePct.intValue(); int pct = colorTemperaturePct.intValue();
@ -540,13 +538,13 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
break; break;
case CHANNEL_COLORTEMPERATURE_ABS: case CHANNEL_COLORTEMPERATURE_ABS:
BigDecimal colorTemperature = null; BigDecimal colorTemperature = null;
if (command instanceof QuantityType) { if (command instanceof QuantityType quantityCommand) {
QuantityType<?> convertedCommand = ((QuantityType<?>) command).toInvertibleUnit(Units.KELVIN); QuantityType<?> convertedCommand = quantityCommand.toInvertibleUnit(Units.KELVIN);
if (convertedCommand != null) { if (convertedCommand != null) {
colorTemperature = convertedCommand.toBigDecimal(); colorTemperature = convertedCommand.toBigDecimal();
} }
} else if (command instanceof DecimalType) { } else if (command instanceof DecimalType decimalCommand) {
colorTemperature = ((DecimalType) command).toBigDecimal(); colorTemperature = decimalCommand.toBigDecimal();
} }
if (colorTemperature != null) { if (colorTemperature != null) {
fritzBox.setColorTemperature(ain, colorTemperature.intValue(), 0); fritzBox.setColorTemperature(ain, colorTemperature.intValue(), 0);
@ -554,9 +552,9 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
break; break;
case CHANNEL_SETTEMP: case CHANNEL_SETTEMP:
BigDecimal temperature = null; BigDecimal temperature = null;
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
temperature = normalizeCelsius(((DecimalType) command).toBigDecimal()); temperature = normalizeCelsius(decimalCommand.toBigDecimal());
} else if (command instanceof QuantityType) { } else if (command instanceof QuantityType quantityCommand) {
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
QuantityType<Temperature> convertedCommand = ((QuantityType<Temperature>) command) QuantityType<Temperature> convertedCommand = ((QuantityType<Temperature>) command)
.toUnit(SIUnits.CELSIUS); .toUnit(SIUnits.CELSIUS);
@ -564,7 +562,7 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
temperature = normalizeCelsius(convertedCommand.toBigDecimal()); temperature = normalizeCelsius(convertedCommand.toBigDecimal());
} else { } else {
logger.warn("Unable to convert unit from '{}' to '{}'. Skipping command.", logger.warn("Unable to convert unit from '{}' to '{}'. Skipping command.",
((QuantityType<?>) command).getUnit(), SIUnits.CELSIUS); quantityCommand.getUnit(), SIUnits.CELSIUS);
} }
} else if (command instanceof IncreaseDecreaseType) { } else if (command instanceof IncreaseDecreaseType) {
temperature = currentDevice.getHkr().getTsoll(); temperature = currentDevice.getHkr().getTsoll();
@ -615,22 +613,20 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
} }
break; break;
case CHANNEL_ROLLERSHUTTER: case CHANNEL_ROLLERSHUTTER:
if (command instanceof StopMoveType) { if (command instanceof StopMoveType rollershutterCommand) {
StopMoveType rollershutterCommand = (StopMoveType) command;
if (StopMoveType.STOP.equals(rollershutterCommand)) { if (StopMoveType.STOP.equals(rollershutterCommand)) {
fritzBox.setBlind(ain, BlindCommand.STOP); fritzBox.setBlind(ain, BlindCommand.STOP);
} else { } else {
logger.debug("Received unknown rollershutter StopMove command MOVE"); logger.debug("Received unknown rollershutter StopMove command MOVE");
} }
} else if (command instanceof UpDownType) { } else if (command instanceof UpDownType rollershutterCommand) {
UpDownType rollershutterCommand = (UpDownType) command;
if (UpDownType.UP.equals(rollershutterCommand)) { if (UpDownType.UP.equals(rollershutterCommand)) {
fritzBox.setBlind(ain, BlindCommand.OPEN); fritzBox.setBlind(ain, BlindCommand.OPEN);
} else { } else {
fritzBox.setBlind(ain, BlindCommand.CLOSE); fritzBox.setBlind(ain, BlindCommand.CLOSE);
} }
} else if (command instanceof PercentType) { } else if (command instanceof PercentType percentCommand) {
BigDecimal levelPercentage = ((PercentType) command).toBigDecimal(); BigDecimal levelPercentage = percentCommand.toBigDecimal();
fritzBox.setLevelPercentage(ain, levelPercentage); fritzBox.setLevelPercentage(ain, levelPercentage);
} else { } else {
logger.debug("Received unknown rollershutter command type '{}'", command.toString()); logger.debug("Received unknown rollershutter command type '{}'", command.toString());
@ -686,8 +682,8 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
Bridge bridge = getBridge(); Bridge bridge = getBridge();
if (bridge != null) { if (bridge != null) {
BridgeHandler handler = bridge.getHandler(); BridgeHandler handler = bridge.getHandler();
if (handler instanceof AVMFritzBaseBridgeHandler) { if (handler instanceof AVMFritzBaseBridgeHandler bridgeHandler) {
return ((AVMFritzBaseBridgeHandler) handler).getWebInterface(); return bridgeHandler.getWebInterface();
} }
} }
return null; return null;
@ -700,8 +696,8 @@ public abstract class AVMFritzBaseThingHandler extends BaseThingHandler implemen
Bridge bridge = getBridge(); Bridge bridge = getBridge();
if (bridge != null) { if (bridge != null) {
BridgeHandler handler = bridge.getHandler(); BridgeHandler handler = bridge.getHandler();
if (handler instanceof AVMFritzBaseBridgeHandler) { if (handler instanceof AVMFritzBaseBridgeHandler bridgeHandler) {
((AVMFritzBaseBridgeHandler) handler).handleRefreshCommand(); bridgeHandler.handleRefreshCommand();
} }
} }
} }

View File

@ -78,8 +78,7 @@ public class AVMFritzButtonHandler extends DeviceHandler {
if (thing.getUID().equals(thingUID)) { if (thing.getUID().equals(thingUID)) {
super.onDeviceUpdated(thingUID, device); super.onDeviceUpdated(thingUID, device);
if (device instanceof DeviceModel) { if (device instanceof DeviceModel deviceModel) {
DeviceModel deviceModel = (DeviceModel) device;
if (deviceModel.isHANFUNButton()) { if (deviceModel.isHANFUNButton()) {
updateHANFUNButton(deviceModel.getButtons()); updateHANFUNButton(deviceModel.getButtons());
} }

View File

@ -13,7 +13,7 @@
package org.openhab.binding.avmfritz.internal.handler; package org.openhab.binding.avmfritz.internal.handler;
import java.util.Collection; import java.util.Collection;
import java.util.Collections; import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.openhab.binding.avmfritz.internal.actions.AVMFritzHeatingActions; import org.openhab.binding.avmfritz.internal.actions.AVMFritzHeatingActions;
@ -30,7 +30,7 @@ public interface AVMFritzHeatingActionsHandler extends ThingHandler {
@Override @Override
default Collection<Class<? extends ThingHandlerService>> getServices() { default Collection<Class<? extends ThingHandlerService>> getServices() {
return Collections.singleton(AVMFritzHeatingActions.class); return Set.of(AVMFritzHeatingActions.class);
} }
/** /**

View File

@ -35,8 +35,7 @@ public class GroupHandler extends AVMFritzBaseThingHandler {
@Override @Override
protected void updateProperties(AVMFritzBaseModel device, Map<String, String> editProperties) { protected void updateProperties(AVMFritzBaseModel device, Map<String, String> editProperties) {
if (device instanceof GroupModel) { if (device instanceof GroupModel groupModel) {
GroupModel groupModel = (GroupModel) device;
if (groupModel.getGroupinfo() != null) { if (groupModel.getGroupinfo() != null) {
editProperties.put(PROPERTY_MASTER, groupModel.getGroupinfo().getMasterdeviceid()); editProperties.put(PROPERTY_MASTER, groupModel.getGroupinfo().getMasterdeviceid());
editProperties.put(PROPERTY_MEMBERS, groupModel.getGroupinfo().getMembers()); editProperties.put(PROPERTY_MEMBERS, groupModel.getGroupinfo().getMembers());

View File

@ -45,72 +45,74 @@ public class AVMFritzDeviceListModelTest {
public void setUp() throws JAXBException, XMLStreamException { public void setUp() throws JAXBException, XMLStreamException {
//@formatter:off //@formatter:off
final String xml = final String xml =
"<devicelist version=\"1\">" """
+ "<group identifier=\"F0:A3:7F-900\" id=\"20000\" functionbitmask=\"6784\" fwversion=\"1.0\" manufacturer=\"AVM\" productname=\"\"><present>1</present><name>Schlafzimmer</name><switch><state>1</state><mode>manuell</mode><lock>0</lock><devicelock>0</devicelock></switch><powermeter><voltage>230051</voltage><power>0</power><energy>2087</energy></powermeter><groupinfo><masterdeviceid>17</masterdeviceid><members>17,18</members></groupinfo></group>" <devicelist version="1">\
+ "<group identifier=\"F0:A3:7F-901\" id=\"20001\" functionbitmask=\"4160\" fwversion=\"1.0\" manufacturer=\"AVM\" productname=\"\"><present>1</present><name>Schlafzimmer</name><temperature><celsius>220</celsius><offset>-10</offset></temperature><hkr><tist>44</tist><tsoll>42</tsoll><absenk>28</absenk><komfort>42</komfort><lock>1</lock><devicelock>1</devicelock><errorcode>0</errorcode><windowopenactiv>0</windowopenactiv><windowopenactiveendtime>0</windowopenactiveendtime><boostactive>0</boostactive><boostactiveendtime>0</boostactiveendtime><batterylow>0</batterylow><battery>100</battery><nextchange><endperiod>1484341200</endperiod><tchange>28</tchange></nextchange></hkr><groupinfo><masterdeviceid>0</masterdeviceid><members>20,21,22</members></groupinfo></group>" <group identifier="F0:A3:7F-900" id="20000" functionbitmask="6784" fwversion="1.0" manufacturer="AVM" productname=""><present>1</present><name>Schlafzimmer</name><switch><state>1</state><mode>manuell</mode><lock>0</lock><devicelock>0</devicelock></switch><powermeter><voltage>230051</voltage><power>0</power><energy>2087</energy></powermeter><groupinfo><masterdeviceid>17</masterdeviceid><members>17,18</members></groupinfo></group>\
+ "<device identifier=\"08761 0000434\" id=\"17\" functionbitmask=\"35712\" fwversion=\"03.83\" manufacturer=\"AVM\" productname=\"FRITZ!DECT 200\"><present>1</present><name>FRITZ!DECT 200 #1</name><switch><state>1</state><mode>manuell</mode><lock>0</lock><devicelock>0</devicelock></switch><powermeter><voltage>230051</voltage><power>0</power><energy>2087</energy></powermeter><temperature><celsius>255</celsius><offset>0</offset></temperature></device>" <group identifier="F0:A3:7F-901" id="20001" functionbitmask="4160" fwversion="1.0" manufacturer="AVM" productname=""><present>1</present><name>Schlafzimmer</name><temperature><celsius>220</celsius><offset>-10</offset></temperature><hkr><tist>44</tist><tsoll>42</tsoll><absenk>28</absenk><komfort>42</komfort><lock>1</lock><devicelock>1</devicelock><errorcode>0</errorcode><windowopenactiv>0</windowopenactiv><windowopenactiveendtime>0</windowopenactiveendtime><boostactive>0</boostactive><boostactiveendtime>0</boostactiveendtime><batterylow>0</batterylow><battery>100</battery><nextchange><endperiod>1484341200</endperiod><tchange>28</tchange></nextchange></hkr><groupinfo><masterdeviceid>0</masterdeviceid><members>20,21,22</members></groupinfo></group>\
+ "<device identifier=\"08761 0000438\" id=\"18\" functionbitmask=\"35712\" fwversion=\"03.83\" manufacturer=\"AVM\" productname=\"FRITZ!DECT 210\"><present>1</present><name>FRITZ!DECT 210 #8</name><switch><state>1</state><mode>manuell</mode><lock>0</lock><devicelock>0</devicelock></switch><powermeter><voltage>230051</voltage><power>0</power><energy>2087</energy></powermeter><temperature><celsius>255</celsius><offset>0</offset></temperature></device>" <device identifier="08761 0000434" id="17" functionbitmask="35712" fwversion="03.83" manufacturer="AVM" productname="FRITZ!DECT 200"><present>1</present><name>FRITZ!DECT 200 #1</name><switch><state>1</state><mode>manuell</mode><lock>0</lock><devicelock>0</devicelock></switch><powermeter><voltage>230051</voltage><power>0</power><energy>2087</energy></powermeter><temperature><celsius>255</celsius><offset>0</offset></temperature></device>\
+ "<device identifier=\"08761 0000437\" id=\"20\" functionbitmask=\"320\" fwversion=\"03.50\" manufacturer=\"AVM\" productname=\"FRITZ!DECT 300\"><present>0</present><name>FRITZ!DECT 300 #1</name><temperature><celsius>220</celsius><offset>-10</offset></temperature><hkr><tist>44</tist><tsoll>42</tsoll><absenk>28</absenk><komfort>42</komfort><lock>1</lock><devicelock>1</devicelock><errorcode>0</errorcode><windowopenactiv>0</windowopenactiv><windowopenactiveendtime>0</windowopenactiveendtime><boostactive>0</boostactive><boostactiveendtime>0</boostactiveendtime><batterylow>0</batterylow><battery>100</battery><nextchange><endperiod>1484341200</endperiod><tchange>28</tchange></nextchange></hkr></device>" <device identifier="08761 0000438" id="18" functionbitmask="35712" fwversion="03.83" manufacturer="AVM" productname="FRITZ!DECT 210"><present>1</present><name>FRITZ!DECT 210 #8</name><switch><state>1</state><mode>manuell</mode><lock>0</lock><devicelock>0</devicelock></switch><powermeter><voltage>230051</voltage><power>0</power><energy>2087</energy></powermeter><temperature><celsius>255</celsius><offset>0</offset></temperature></device>\
+ "<device identifier=\"08761 0000436\" id=\"21\" functionbitmask=\"320\" fwversion=\"03.50\" manufacturer=\"AVM\" productname=\"FRITZ!DECT 301\"><present>0</present><name>FRITZ!DECT 301 #1</name><temperature><celsius>220</celsius><offset>-10</offset></temperature><hkr><tist>44</tist><tsoll>42</tsoll><absenk>28</absenk><komfort>42</komfort><lock>1</lock><devicelock>1</devicelock><errorcode>0</errorcode><windowopenactiv>0</windowopenactiv><windowopenactiveendtime>0</windowopenactiveendtime><boostactive>0</boostactive><boostactiveendtime>0</boostactiveendtime><batterylow>0</batterylow><battery>100</battery><nextchange><endperiod>1484341200</endperiod><tchange>28</tchange></nextchange></hkr></device>" <device identifier="08761 0000437" id="20" functionbitmask="320" fwversion="03.50" manufacturer="AVM" productname="FRITZ!DECT 300"><present>0</present><name>FRITZ!DECT 300 #1</name><temperature><celsius>220</celsius><offset>-10</offset></temperature><hkr><tist>44</tist><tsoll>42</tsoll><absenk>28</absenk><komfort>42</komfort><lock>1</lock><devicelock>1</devicelock><errorcode>0</errorcode><windowopenactiv>0</windowopenactiv><windowopenactiveendtime>0</windowopenactiveendtime><boostactive>0</boostactive><boostactiveendtime>0</boostactiveendtime><batterylow>0</batterylow><battery>100</battery><nextchange><endperiod>1484341200</endperiod><tchange>28</tchange></nextchange></hkr></device>\
+ "<device identifier=\"08761 0000435\" id=\"22\" functionbitmask=\"320\" fwversion=\"03.50\" manufacturer=\"AVM\" productname=\"Comet DECT\"><present>0</present><name>Comet DECT #1</name><temperature><celsius>220</celsius><offset>-10</offset></temperature><hkr><tist>44</tist><tsoll>42</tsoll><absenk>28</absenk><komfort>42</komfort><lock>1</lock><devicelock>1</devicelock><errorcode>0</errorcode><windowopenactiv>0</windowopenactiv><windowopenactiveendtime>0</windowopenactiveendtime><boostactive>0</boostactive><boostactiveendtime>0</boostactiveendtime><batterylow>0</batterylow><battery>100</battery><nextchange><endperiod>1484341200</endperiod><tchange>28</tchange></nextchange></hkr></device>" <device identifier="08761 0000436" id="21" functionbitmask="320" fwversion="03.50" manufacturer="AVM" productname="FRITZ!DECT 301"><present>0</present><name>FRITZ!DECT 301 #1</name><temperature><celsius>220</celsius><offset>-10</offset></temperature><hkr><tist>44</tist><tsoll>42</tsoll><absenk>28</absenk><komfort>42</komfort><lock>1</lock><devicelock>1</devicelock><errorcode>0</errorcode><windowopenactiv>0</windowopenactiv><windowopenactiveendtime>0</windowopenactiveendtime><boostactive>0</boostactive><boostactiveendtime>0</boostactiveendtime><batterylow>0</batterylow><battery>100</battery><nextchange><endperiod>1484341200</endperiod><tchange>28</tchange></nextchange></hkr></device>\
+ "<device identifier=\"5C:49:79:F0:A3:84\" id=\"30\" functionbitmask=\"640\" fwversion=\"06.92\" manufacturer=\"AVM\" productname=\"FRITZ!Powerline 546E\"><present>1</present><name>FRITZ!Powerline 546E #1</name><switch><state>0</state><mode>manuell</mode><lock>0</lock><devicelock>1</devicelock></switch><powermeter><voltage>230051</voltage><power>0</power><energy>2087</energy></powermeter></device>" <device identifier="08761 0000435" id="22" functionbitmask="320" fwversion="03.50" manufacturer="AVM" productname="Comet DECT"><present>0</present><name>Comet DECT #1</name><temperature><celsius>220</celsius><offset>-10</offset></temperature><hkr><tist>44</tist><tsoll>42</tsoll><absenk>28</absenk><komfort>42</komfort><lock>1</lock><devicelock>1</devicelock><errorcode>0</errorcode><windowopenactiv>0</windowopenactiv><windowopenactiveendtime>0</windowopenactiveendtime><boostactive>0</boostactive><boostactiveendtime>0</boostactiveendtime><batterylow>0</batterylow><battery>100</battery><nextchange><endperiod>1484341200</endperiod><tchange>28</tchange></nextchange></hkr></device>\
+ "<device identifier=\"08761 0000439\" id=\"40\" functionbitmask=\"1280\" fwversion=\"03.86\" manufacturer=\"AVM\" productname=\"FRITZ!DECT Repeater 100\"><present>1</present><name>FRITZ!DECT Repeater 100 #5</name><temperature><celsius>230</celsius><offset>0</offset></temperature></device>" <device identifier="5C:49:79:F0:A3:84" id="30" functionbitmask="640" fwversion="06.92" manufacturer="AVM" productname="FRITZ!Powerline 546E"><present>1</present><name>FRITZ!Powerline 546E #1</name><switch><state>0</state><mode>manuell</mode><lock>0</lock><devicelock>1</devicelock></switch><powermeter><voltage>230051</voltage><power>0</power><energy>2087</energy></powermeter></device>\
+ "<device identifier=\"11934 0059978-1\" id=\"2000\" functionbitmask=\"8208\" fwversion=\"0.0\" manufacturer=\"0x0feb\" productname=\"HAN-FUN\"><present>0</present><name>HAN-FUN #2: Unit #2</name><etsiunitinfo><etsideviceid>406</etsideviceid><unittype>514</unittype><interfaces>256</interfaces></etsiunitinfo><alert><state>1</state></alert></device>" <device identifier="08761 0000439" id="40" functionbitmask="1280" fwversion="03.86" manufacturer="AVM" productname="FRITZ!DECT Repeater 100"><present>1</present><name>FRITZ!DECT Repeater 100 #5</name><temperature><celsius>230</celsius><offset>0</offset></temperature></device>\
+ "<device identifier=\"11934 0059979-1\" id=\"2001\" functionbitmask=\"8200\" fwversion=\"0.0\" manufacturer=\"0x0feb\" productname=\"HAN-FUN\"><present>0</present><name>HAN-FUN #2: Unit #2</name><etsiunitinfo><etsideviceid>412</etsideviceid><unittype>273</unittype><interfaces>772</interfaces></etsiunitinfo><button><lastpressedtimestamp>1529590797</lastpressedtimestamp></button></device>" <device identifier="11934 0059978-1" id="2000" functionbitmask="8208" fwversion="0.0" manufacturer="0x0feb" productname="HAN-FUN"><present>0</present><name>HAN-FUN #2: Unit #2</name><etsiunitinfo><etsideviceid>406</etsideviceid><unittype>514</unittype><interfaces>256</interfaces></etsiunitinfo><alert><state>1</state></alert></device>\
+ "<device identifier=\"13096 0007307\" id=\"29\" functionbitmask=\"32\" fwversion=\"04.90\" manufacturer=\"AVM\" productname=\"FRITZ!DECT 400\"><present>1</present><name>FRITZ!DECT 400 #14</name><battery>100</battery><batterylow>0</batterylow><button identifier=\"13096 0007307-0\" id=\"5000\"><name>FRITZ!DECT 400 #14: kurz</name><lastpressedtimestamp>1549195586</lastpressedtimestamp></button><button identifier=\"13096 0007307-9\" id=\"5001\"><name>FRITZ!DECT 400 #14: lang</name><lastpressedtimestamp>1549195595</lastpressedtimestamp></button></device>" <device identifier="11934 0059979-1" id="2001" functionbitmask="8200" fwversion="0.0" manufacturer="0x0feb" productname="HAN-FUN"><present>0</present><name>HAN-FUN #2: Unit #2</name><etsiunitinfo><etsideviceid>412</etsideviceid><unittype>273</unittype><interfaces>772</interfaces></etsiunitinfo><button><lastpressedtimestamp>1529590797</lastpressedtimestamp></button></device>\
+ "<device identifier=\"13096 0007308\" id=\"30\" functionbitmask=\"1048864\" fwversion=\"05.10\" manufacturer=\"AVM\" productname=\"FRITZ!DECT 440\"><present>1</present><name>FRITZ!DECT 440 #15</name><temperature><celsius>230</celsius><offset>0</offset></temperature><humidity><rel_humidity>43</rel_humidity></humidity><battery>100</battery><batterylow>0</batterylow><button identifier=\"13096 0007308-1\" id=\"5000\"><name>FRITZ!DECT 440 #15: Oben rechts</name><lastpressedtimestamp>1549195586</lastpressedtimestamp></button><button identifier=\"13096 0007308-3\" id=\"5001\"><name>FRITZ!DECT 440 #15: Unten rechts</name><lastpressedtimestamp>1549195595</lastpressedtimestamp></button><button identifier=\"13096 0007308-5\" id=\"5002\"><name>FRITZ!DECT 440 #15: Unten links</name><lastpressedtimestamp>1549195586</lastpressedtimestamp></button><button identifier=\"13096 0007308-7\" id=\"5003\"><name>FRITZ!DECT 440 #15: Oben links</name><lastpressedtimestamp>1549195595</lastpressedtimestamp></button></device>" <device identifier="13096 0007307" id="29" functionbitmask="32" fwversion="04.90" manufacturer="AVM" productname="FRITZ!DECT 400"><present>1</present><name>FRITZ!DECT 400 #14</name><battery>100</battery><batterylow>0</batterylow><button identifier="13096 0007307-0" id="5000"><name>FRITZ!DECT 400 #14: kurz</name><lastpressedtimestamp>1549195586</lastpressedtimestamp></button><button identifier="13096 0007307-9" id="5001"><name>FRITZ!DECT 400 #14: lang</name><lastpressedtimestamp>1549195595</lastpressedtimestamp></button></device>\
+ "<device identifier=\"14276 0503450-1\" id=\"2000\" functionbitmask=\"335888\" fwversion=\"0.0\" manufacturer=\"0x37c4\" productname=\"Rollotron 1213\"><present>1</present><txbusy>0</txbusy><name>Rollotron 1213 #1</name><blind><endpositionsset>1</endpositionsset><mode>manuell</mode></blind><levelcontrol><level>26</level><levelpercentage>10</levelpercentage></levelcontrol><etsiunitinfo><etsideviceid>406</etsideviceid><unittype>281</unittype><interfaces>256,513,516,517</interfaces></etsiunitinfo><alert><state>0</state><lastalertchgtimestamp></lastalertchgtimestamp></alert></device>" <device identifier="13096 0007308" id="30" functionbitmask="1048864" fwversion="05.10" manufacturer="AVM" productname="FRITZ!DECT 440"><present>1</present><name>FRITZ!DECT 440 #15</name><temperature><celsius>230</celsius><offset>0</offset></temperature><humidity><rel_humidity>43</rel_humidity></humidity><battery>100</battery><batterylow>0</batterylow><button identifier="13096 0007308-1" id="5000"><name>FRITZ!DECT 440 #15: Oben rechts</name><lastpressedtimestamp>1549195586</lastpressedtimestamp></button><button identifier="13096 0007308-3" id="5001"><name>FRITZ!DECT 440 #15: Unten rechts</name><lastpressedtimestamp>1549195595</lastpressedtimestamp></button><button identifier="13096 0007308-5" id="5002"><name>FRITZ!DECT 440 #15: Unten links</name><lastpressedtimestamp>1549195586</lastpressedtimestamp></button><button identifier="13096 0007308-7" id="5003"><name>FRITZ!DECT 440 #15: Oben links</name><lastpressedtimestamp>1549195595</lastpressedtimestamp></button></device>\
+ "<device identifier=\"11324 0824499-1\" id=\"2002\" functionbitmask=\"40960\" fwversion=\"0.0\" manufacturer=\"0x2c3c\" productname=\"HAN-FUN\">\n" <device identifier="14276 0503450-1" id="2000" functionbitmask="335888" fwversion="0.0" manufacturer="0x37c4" productname="Rollotron 1213"><present>1</present><txbusy>0</txbusy><name>Rollotron 1213 #1</name><blind><endpositionsset>1</endpositionsset><mode>manuell</mode></blind><levelcontrol><level>26</level><levelpercentage>10</levelpercentage></levelcontrol><etsiunitinfo><etsideviceid>406</etsideviceid><unittype>281</unittype><interfaces>256,513,516,517</interfaces></etsiunitinfo><alert><state>0</state><lastalertchgtimestamp></lastalertchgtimestamp></alert></device>\
+ " <present>1</present>\n" <device identifier="11324 0824499-1" id="2002" functionbitmask="40960" fwversion="0.0" manufacturer="0x2c3c" productname="HAN-FUN">
+ " <txbusy>0</txbusy>\n" <present>1</present>
+ " <name>Steckdose innen</name>\n" <txbusy>0</txbusy>
+ " <simpleonoff>\n" <name>Steckdose innen</name>
+ " <state>0</state>\n" <simpleonoff>
+ " </simpleonoff>\n" <state>0</state>
+ " <etsiunitinfo>\n" </simpleonoff>
+ " <etsideviceid>408</etsideviceid>\n" <etsiunitinfo>
+ " <unittype>263</unittype>\n" <etsideviceid>408</etsideviceid>
+ " <interfaces>512,768</interfaces>\n" <unittype>263</unittype>
+ " </etsiunitinfo>\n" <interfaces>512,768</interfaces>
+ "</device>" </etsiunitinfo>
+ "<device identifier=\"11324 0584796-1\" id=\"2001\" functionbitmask=\"40960\" fwversion=\"0.0\" manufacturer=\"0x2c3c\" productname=\"HAN-FUN\">\n" </device>\
+ " <present>1</present>\n" <device identifier="11324 0584796-1" id="2001" functionbitmask="40960" fwversion="0.0" manufacturer="0x2c3c" productname="HAN-FUN">
+ " <txbusy>0</txbusy>\n" <present>1</present>
+ " <name>Steckdose außen</name>\n" <txbusy>0</txbusy>
+ " <simpleonoff>\n" <name>Steckdose außen</name>
+ " <state>0</state>\n" <simpleonoff>
+ " </simpleonoff>\n" <state>0</state>
+ " <etsiunitinfo>\n" </simpleonoff>
+ " <etsideviceid>407</etsideviceid>\n" <etsiunitinfo>
+ " <unittype>262</unittype>\n" <etsideviceid>407</etsideviceid>
+ " <interfaces>512</interfaces>\n" <unittype>262</unittype>
+ " </etsiunitinfo>\n" <interfaces>512</interfaces>
+ "</device>" </etsiunitinfo>
+ "<device identifier=\"12701 0027533-1\" id=\"2002\" functionbitmask=\"237572\" fwversion=\"0.0\" manufacturer=\"0x319d\" productname=\"HAN-FUN\">\n" </device>\
+ " <present>0</present>\n" <device identifier="12701 0027533-1" id="2002" functionbitmask="237572" fwversion="0.0" manufacturer="0x319d" productname="HAN-FUN">
+ " <txbusy>0</txbusy>\n" <present>0</present>
+ " <name>SmartHome LED-Lampe #1</name>\n" <txbusy>0</txbusy>
+ " <simpleonoff>\n" <name>SmartHome LED-Lampe #1</name>
+ " <state>0</state>\n" <simpleonoff>
+ " </simpleonoff>\n" <state>0</state>
+ " <levelcontrol>\n" </simpleonoff>
+ " <level>26</level>\n" <levelcontrol>
+ " <levelpercentage>10</levelpercentage>\n" <level>26</level>
+ " </levelcontrol>\n" <levelpercentage>10</levelpercentage>
+ " <colorcontrol supported_modes=\"0\" current_mode=\"\" fullcolorsupport=\"0\" mapped=\"0\">\n" </levelcontrol>
+ " <hue>254</hue>\n" <colorcontrol supported_modes="0" current_mode="" fullcolorsupport="0" mapped="0">
+ " <saturation>100</saturation>\n" <hue>254</hue>
+ " <unmapped_hue></unmapped_hue>\n" <saturation>100</saturation>
+ " <unmapped_saturation></unmapped_saturation>\n" <unmapped_hue></unmapped_hue>
+ " <temperature>2700</temperature>\n" <unmapped_saturation></unmapped_saturation>
+ " </colorcontrol>\n" <temperature>2700</temperature>
+ " <etsiunitinfo>\n" </colorcontrol>
+ " <etsideviceid>407</etsideviceid>\n" <etsiunitinfo>
+ " <unittype>278</unittype>\n" <etsideviceid>407</etsideviceid>
+ " <interfaces>512,514,513</interfaces>\n" <unittype>278</unittype>
+ " </etsiunitinfo>\n" <interfaces>512,514,513</interfaces>
+ "</device>" + </etsiunitinfo>
"</devicelist>"; </device>\
</devicelist>\
""";
//@formatter:on //@formatter:on
XMLStreamReader xsr = JAXBUtils.XMLINPUTFACTORY.createXMLStreamReader(new StringReader(xml)); XMLStreamReader xsr = JAXBUtils.XMLINPUTFACTORY.createXMLStreamReader(new StringReader(xml));
Unmarshaller u = JAXBUtils.JAXBCONTEXT_DEVICES.createUnmarshaller(); Unmarshaller u = JAXBUtils.JAXBCONTEXT_DEVICES.createUnmarshaller();

View File

@ -44,10 +44,12 @@ public class AVMFritzTemplateListModelTest {
public void setUp() throws JAXBException, XMLStreamException { public void setUp() throws JAXBException, XMLStreamException {
//@formatter:off //@formatter:off
String xml = String xml =
"<templatelist version=\"1\">" + """
"<template identifier=\"tmpXXXXX-39DC738C5\" id=\"30103\" functionbitmask=\"6784\" applymask=\"64\"><name>Test template #1</name><devices><device identifier=\"YY:5D:AA-900\" /><device identifier=\"XX:5D:AA-900\" /></devices><applymask><relay_automatic /></applymask></template>" + <templatelist version="1">\
"<template identifier=\"tmpXXXXX-39722FC0F\" id=\"30003\" functionbitmask=\"6784\" applymask=\"64\"><name>Test template #2</name><devices><device identifier=\"YY:5D:AA-900\" /></devices><applymask><relay_automatic /></applymask></template>" + <template identifier="tmpXXXXX-39DC738C5" id="30103" functionbitmask="6784" applymask="64"><name>Test template #1</name><devices><device identifier="YY:5D:AA-900" /><device identifier="XX:5D:AA-900" /></devices><applymask><relay_automatic /></applymask></template>\
"</templatelist>"; <template identifier="tmpXXXXX-39722FC0F" id="30003" functionbitmask="6784" applymask="64"><name>Test template #2</name><devices><device identifier="YY:5D:AA-900" /></devices><applymask><relay_automatic /></applymask></template>\
</templatelist>\
""";
//@formatter:on //@formatter:on
XMLStreamReader xsr = JAXBUtils.XMLINPUTFACTORY.createXMLStreamReader(new StringReader(xml)); XMLStreamReader xsr = JAXBUtils.XMLINPUTFACTORY.createXMLStreamReader(new StringReader(xml));
Unmarshaller u = JAXBUtils.JAXBCONTEXT_TEMPLATES.createUnmarshaller(); Unmarshaller u = JAXBUtils.JAXBCONTEXT_TEMPLATES.createUnmarshaller();

View File

@ -27,6 +27,7 @@ public class AwattarBestpriceConfiguration {
public int length; public int length;
public boolean consecutive; public boolean consecutive;
@Override
public String toString() { public String toString() {
return String.format("{ s: %d, d: %d, l: %d, c: %b )", rangeStart, rangeDuration, length, consecutive); return String.format("{ s: %d, d: %d, l: %d, c: %b )", rangeStart, rangeDuration, length, consecutive);
} }

View File

@ -66,11 +66,13 @@ public class AwattarConsecutiveBestPriceResult extends AwattarBestPriceResult {
return priceSum; return priceSum;
} }
@Override
public String toString() { public String toString() {
return String.format("{%s, %s, %.2f}", formatDate(getStart(), zoneId), formatDate(getEnd(), zoneId), return String.format("{%s, %s, %.2f}", formatDate(getStart(), zoneId), formatDate(getEnd(), zoneId),
priceSum / length); priceSum / length);
} }
@Override
public String getHours() { public String getHours() {
return hours; return hours;
} }

View File

@ -52,6 +52,7 @@ public class AwattarNonConsecutiveBestPriceResult extends AwattarBestPriceResult
return members.stream().anyMatch(x -> x.contains(Instant.now().toEpochMilli())); return members.stream().anyMatch(x -> x.contains(Instant.now().toEpochMilli()));
} }
@Override
public String toString() { public String toString() {
return String.format("NonConsecutiveBestpriceResult with %s", members.toString()); return String.format("NonConsecutiveBestpriceResult with %s", members.toString());
} }
@ -67,6 +68,7 @@ public class AwattarNonConsecutiveBestPriceResult extends AwattarBestPriceResult
} }
} }
@Override
public String getHours() { public String getHours() {
boolean second = false; boolean second = false;
sort(); sort();

View File

@ -50,6 +50,7 @@ public class AwattarPrice implements Comparable<AwattarPrice> {
return price; return price;
} }
@Override
public String toString() { public String toString() {
return String.format("(%1$tF %1$tR - %2$tR: %3$.3f)", startTimestamp, endTimestamp, getPrice()); return String.format("(%1$tF %1$tR - %2$tR: %3$.3f)", startTimestamp, endTimestamp, getPrice());
} }

View File

@ -40,9 +40,7 @@ public class AwattarUtil {
int offset = min % mod; int offset = min % mod;
offset = offset == 0 ? mod : offset; offset = offset == 0 ? mod : offset;
dt = dt.plusMinutes(offset); dt = dt.plusMinutes(offset);
long result = dt.toInstant().toEpochMilli() - now; return dt.toInstant().toEpochMilli() - now;
return result;
} }
public static ZonedDateTime getCalendarForHour(int hour, ZoneId zone) { public static ZonedDateTime getCalendarForHour(int hour, ZoneId zone) {

View File

@ -97,6 +97,7 @@ public class AwattarPriceHandler extends BaseThingHandler {
updateStatus(ThingStatus.UNKNOWN); updateStatus(ThingStatus.UNKNOWN);
} }
@Override
public void dispose() { public void dispose() {
ScheduledFuture<?> localRefresher = thingRefresher; ScheduledFuture<?> localRefresher = thingRefresher;
if (localRefresher != null) { if (localRefresher != null) {

View File

@ -22,5 +22,5 @@ import org.eclipse.jdt.annotation.NonNullByDefault;
@NonNullByDefault @NonNullByDefault
public enum Switch { public enum Switch {
ON, ON,
OFF; OFF
} }

View File

@ -187,8 +187,8 @@ public class BigAssFanHandler extends BaseThingHandler {
logger.debug("Handling fan speed command for {}: {}", thing.getUID(), command); logger.debug("Handling fan speed command for {}: {}", thing.getUID(), command);
// <mac;FAN;SPD;SET;0..7> // <mac;FAN;SPD;SET;0..7>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
sendCommand(macAddress, ";FAN;SPD;SET;".concat(BigAssFanConverter.percentToSpeed((PercentType) command))); sendCommand(macAddress, ";FAN;SPD;SET;".concat(BigAssFanConverter.percentToSpeed(percentCommand)));
} }
} }
@ -238,52 +238,48 @@ public class BigAssFanHandler extends BaseThingHandler {
private void handleFanLearnSpeedMin(Command command) { private void handleFanLearnSpeedMin(Command command) {
logger.debug("Handling fan learn speed minimum command {}", command); logger.debug("Handling fan learn speed minimum command {}", command);
// <mac;FAN;SPD;SET;MIN;0..7> // <mac;FAN;SPD;SET;MIN;0..7>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
// Send min speed set command // Send min speed set command
sendCommand(macAddress, sendCommand(macAddress, ";LEARN;MINSPEED;SET;".concat(BigAssFanConverter.percentToSpeed(percentCommand)));
";LEARN;MINSPEED;SET;".concat(BigAssFanConverter.percentToSpeed((PercentType) command))); fanStateMap.put(CHANNEL_FAN_LEARN_MINSPEED, percentCommand);
fanStateMap.put(CHANNEL_FAN_LEARN_MINSPEED, (PercentType) command);
// Don't let max be less than min // Don't let max be less than min
adjustMaxSpeed((PercentType) command, CHANNEL_FAN_LEARN_MAXSPEED, ";LEARN;MAXSPEED;"); adjustMaxSpeed(percentCommand, CHANNEL_FAN_LEARN_MAXSPEED, ";LEARN;MAXSPEED;");
} }
} }
private void handleFanLearnSpeedMax(Command command) { private void handleFanLearnSpeedMax(Command command) {
logger.debug("Handling fan learn speed maximum command {}", command); logger.debug("Handling fan learn speed maximum command {}", command);
// <mac;FAN;SPD;SET;MAX;0..7> // <mac;FAN;SPD;SET;MAX;0..7>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
// Send max speed set command // Send max speed set command
sendCommand(macAddress, sendCommand(macAddress, ";LEARN;MAXSPEED;SET;;".concat(BigAssFanConverter.percentToSpeed(percentCommand)));
";LEARN;MAXSPEED;SET;;".concat(BigAssFanConverter.percentToSpeed((PercentType) command))); fanStateMap.put(CHANNEL_FAN_LEARN_MAXSPEED, percentCommand);
fanStateMap.put(CHANNEL_FAN_LEARN_MAXSPEED, (PercentType) command);
// Don't let min be greater than max // Don't let min be greater than max
adjustMinSpeed((PercentType) command, CHANNEL_FAN_LEARN_MINSPEED, ";LEARN;MINSPEED;"); adjustMinSpeed(percentCommand, CHANNEL_FAN_LEARN_MINSPEED, ";LEARN;MINSPEED;");
} }
} }
private void handleFanSpeedMin(Command command) { private void handleFanSpeedMin(Command command) {
logger.debug("Handling fan speed minimum command {}", command); logger.debug("Handling fan speed minimum command {}", command);
// <mac;FAN;SPD;SET;MIN;0..7> // <mac;FAN;SPD;SET;MIN;0..7>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
// Send min speed set command // Send min speed set command
sendCommand(macAddress, sendCommand(macAddress, ";FAN;SPD;SET;MIN;".concat(BigAssFanConverter.percentToSpeed(percentCommand)));
";FAN;SPD;SET;MIN;".concat(BigAssFanConverter.percentToSpeed((PercentType) command))); fanStateMap.put(CHANNEL_FAN_SPEED_MIN, percentCommand);
fanStateMap.put(CHANNEL_FAN_SPEED_MIN, (PercentType) command);
// Don't let max be less than min // Don't let max be less than min
adjustMaxSpeed((PercentType) command, CHANNEL_FAN_SPEED_MAX, ";FAN;SPD;SET;MAX;"); adjustMaxSpeed(percentCommand, CHANNEL_FAN_SPEED_MAX, ";FAN;SPD;SET;MAX;");
} }
} }
private void handleFanSpeedMax(Command command) { private void handleFanSpeedMax(Command command) {
logger.debug("Handling fan speed maximum command {}", command); logger.debug("Handling fan speed maximum command {}", command);
// <mac;FAN;SPD;SET;MAX;0..7> // <mac;FAN;SPD;SET;MAX;0..7>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
// Send max speed set command // Send max speed set command
sendCommand(macAddress, sendCommand(macAddress, ";FAN;SPD;SET;MAX;".concat(BigAssFanConverter.percentToSpeed(percentCommand)));
";FAN;SPD;SET;MAX;".concat(BigAssFanConverter.percentToSpeed((PercentType) command))); fanStateMap.put(CHANNEL_FAN_SPEED_MAX, percentCommand);
fanStateMap.put(CHANNEL_FAN_SPEED_MAX, (PercentType) command);
// Don't let min be greater than max // Don't let min be greater than max
adjustMinSpeed((PercentType) command, CHANNEL_FAN_SPEED_MIN, ";FAN;SPD;SET;MIN;"); adjustMinSpeed(percentCommand, CHANNEL_FAN_SPEED_MIN, ";FAN;SPD;SET;MIN;");
} }
} }
@ -364,9 +360,8 @@ public class BigAssFanHandler extends BaseThingHandler {
logger.debug("Handling light level command {}", command); logger.debug("Handling light level command {}", command);
// <mac;LIGHT;LEVEL;SET;0..16> // <mac;LIGHT;LEVEL;SET;0..16>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
sendCommand(macAddress, sendCommand(macAddress, ";LIGHT;LEVEL;SET;".concat(BigAssFanConverter.percentToLevel(percentCommand)));
";LIGHT;LEVEL;SET;".concat(BigAssFanConverter.percentToLevel((PercentType) command)));
} }
} }
@ -378,9 +373,9 @@ public class BigAssFanHandler extends BaseThingHandler {
logger.debug("Handling light hue command {}", command); logger.debug("Handling light hue command {}", command);
// <mac;LIGHT;COLOR;TEMP;SET;2200..5000> // <mac;LIGHT;COLOR;TEMP;SET;2200..5000>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
sendCommand(macAddress, sendCommand(macAddress,
";LIGHT;COLOR;TEMP;VALUE;SET;".concat(BigAssFanConverter.percentToHue((PercentType) command))); ";LIGHT;COLOR;TEMP;VALUE;SET;".concat(BigAssFanConverter.percentToHue(percentCommand)));
} }
} }
@ -426,12 +421,11 @@ public class BigAssFanHandler extends BaseThingHandler {
logger.debug("Handling light level minimum command {}", command); logger.debug("Handling light level minimum command {}", command);
// <mac;LIGHT;LEVEL;MIN;0-16> // <mac;LIGHT;LEVEL;MIN;0-16>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
// Send min light level set command // Send min light level set command
sendCommand(macAddress, sendCommand(macAddress, ";LIGHT;LEVEL;MIN;".concat(BigAssFanConverter.percentToLevel(percentCommand)));
";LIGHT;LEVEL;MIN;".concat(BigAssFanConverter.percentToLevel((PercentType) command)));
// Don't let max be less than min // Don't let max be less than min
adjustMaxLevel((PercentType) command); adjustMaxLevel(percentCommand);
} }
} }
@ -443,12 +437,11 @@ public class BigAssFanHandler extends BaseThingHandler {
logger.debug("Handling light level maximum command {}", command); logger.debug("Handling light level maximum command {}", command);
// <mac;LIGHT;LEVEL;MAX;0-16> // <mac;LIGHT;LEVEL;MAX;0-16>
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
// Send max light level set command // Send max light level set command
sendCommand(macAddress, sendCommand(macAddress, ";LIGHT;LEVEL;MAX;".concat(BigAssFanConverter.percentToLevel(percentCommand)));
";LIGHT;LEVEL;MAX;".concat(BigAssFanConverter.percentToLevel((PercentType) command)));
// Don't let min be greater than max // Don't let min be greater than max
adjustMinLevel((PercentType) command); adjustMinLevel(percentCommand);
} }
} }

View File

@ -12,7 +12,6 @@
*/ */
package org.openhab.binding.bluetooth.am43.internal; package org.openhab.binding.bluetooth.am43.internal;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -42,7 +41,7 @@ public class AM43DiscoveryParticipant implements BluetoothDiscoveryParticipant {
@Override @Override
public Set<ThingTypeUID> getSupportedThingTypeUIDs() { public Set<ThingTypeUID> getSupportedThingTypeUIDs() {
return Collections.singleton(AM43BindingConstants.THING_TYPE_AM43); return Set.of(AM43BindingConstants.THING_TYPE_AM43);
} }
@Override @Override

View File

@ -235,27 +235,28 @@ public class AM43Handler extends ConnectedBluetoothHandler implements ResponseLi
} }
switch (channelUID.getId()) { switch (channelUID.getId()) {
case AM43BindingConstants.CHANNEL_ID_POSITION: case AM43BindingConstants.CHANNEL_ID_POSITION:
if (command instanceof PercentType) { if (command instanceof PercentType percentCommand) {
MotorSettings settings = motorSettings; MotorSettings settings = motorSettings;
if (settings == null) { if (settings == null) {
logger.warn("Cannot set position before settings have been received."); logger.warn("Cannot set position before settings have been received.");
return; return;
} }
if (!settings.isTopLimitSet() || !settings.isBottomLimitSet()) { if (!settings.isTopLimitSet() || !settings.isBottomLimitSet()) {
logger.warn("Cannot set position of blinds. Top or bottom limits have not been set. " logger.warn("""
+ "Please configure manually."); Cannot set position of blinds. Top or bottom limits have not been set. \
Please configure manually.\
""");
return; return;
} }
PercentType percent = (PercentType) command; int value = percentCommand.intValue();
int value = percent.intValue();
if (getAM43Config().invertPosition) { if (getAM43Config().invertPosition) {
value = 100 - value; value = 100 - value;
} }
submitCommand(new SetPositionCommand(value)); submitCommand(new SetPositionCommand(value));
return; return;
} }
if (command instanceof StopMoveType) { if (command instanceof StopMoveType stopMoveCommand) {
switch ((StopMoveType) command) { switch (stopMoveCommand) {
case STOP: case STOP:
submitCommand(new ControlCommand(ControlAction.STOP)); submitCommand(new ControlCommand(ControlAction.STOP));
return; return;
@ -264,8 +265,8 @@ public class AM43Handler extends ConnectedBluetoothHandler implements ResponseLi
return; return;
} }
} }
if (command instanceof UpDownType) { if (command instanceof UpDownType upDownCommand) {
switch ((UpDownType) command) { switch (upDownCommand) {
case UP: case UP:
submitCommand(new ControlCommand(ControlAction.OPEN)); submitCommand(new ControlCommand(ControlAction.OPEN));
return; return;
@ -276,11 +277,10 @@ public class AM43Handler extends ConnectedBluetoothHandler implements ResponseLi
} }
return; return;
case AM43BindingConstants.CHANNEL_ID_SPEED: case AM43BindingConstants.CHANNEL_ID_SPEED:
if (command instanceof DecimalType) { if (command instanceof DecimalType decimalCommand) {
MotorSettings settings = motorSettings; MotorSettings settings = motorSettings;
if (settings != null) { if (settings != null) {
DecimalType speedType = (DecimalType) command; settings.setSpeed(decimalCommand.intValue());
settings.setSpeed(speedType.intValue());
submitCommand(new SetSettingsCommand(settings)); submitCommand(new SetSettingsCommand(settings));
} else { } else {
logger.warn("Cannot set Speed before setting have been received"); logger.warn("Cannot set Speed before setting have been received");

View File

@ -12,7 +12,6 @@
*/ */
package org.openhab.binding.bluetooth.am43.internal; package org.openhab.binding.bluetooth.am43.internal;
import java.util.Collections;
import java.util.Set; import java.util.Set;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
@ -33,8 +32,7 @@ import org.osgi.service.component.annotations.Component;
@Component(service = ThingHandlerFactory.class, configurationPid = "binding.am43") @Component(service = ThingHandlerFactory.class, configurationPid = "binding.am43")
public class AM43HandlerFactory extends BaseThingHandlerFactory { public class AM43HandlerFactory extends BaseThingHandlerFactory {
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Collections private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set.of(AM43BindingConstants.THING_TYPE_AM43);
.singleton(AM43BindingConstants.THING_TYPE_AM43);
@Override @Override
public boolean supportsThingType(ThingTypeUID thingTypeUID) { public boolean supportsThingType(ThingTypeUID thingTypeUID) {

View File

@ -35,6 +35,7 @@ public class BlueGigaBluetoothCharacteristic extends BluetoothCharacteristic {
super(null, handle); super(null, handle);
} }
@Override
public void setProperties(int properties) { public void setProperties(int properties) {
this.properties = properties; this.properties = properties;
} }

View File

@ -356,33 +356,33 @@ public class BlueGigaBluetoothDevice extends BaseBluetoothDevice implements Blue
@Override @Override
public void bluegigaEventReceived(BlueGigaResponse event) { public void bluegigaEventReceived(BlueGigaResponse event) {
if (event instanceof BlueGigaScanResponseEvent) { if (event instanceof BlueGigaScanResponseEvent responseEvent) {
handleScanEvent((BlueGigaScanResponseEvent) event); handleScanEvent(responseEvent);
} }
else if (event instanceof BlueGigaGroupFoundEvent) { else if (event instanceof BlueGigaGroupFoundEvent foundEvent) {
handleGroupFoundEvent((BlueGigaGroupFoundEvent) event); handleGroupFoundEvent(foundEvent);
} }
else if (event instanceof BlueGigaFindInformationFoundEvent) { else if (event instanceof BlueGigaFindInformationFoundEvent foundEvent) {
// A Characteristic has been discovered // A Characteristic has been discovered
handleFindInformationFoundEvent((BlueGigaFindInformationFoundEvent) event); handleFindInformationFoundEvent(foundEvent);
} }
else if (event instanceof BlueGigaProcedureCompletedEvent) { else if (event instanceof BlueGigaProcedureCompletedEvent completedEvent) {
handleProcedureCompletedEvent((BlueGigaProcedureCompletedEvent) event); handleProcedureCompletedEvent(completedEvent);
} }
else if (event instanceof BlueGigaConnectionStatusEvent) { else if (event instanceof BlueGigaConnectionStatusEvent statusEvent) {
handleConnectionStatusEvent((BlueGigaConnectionStatusEvent) event); handleConnectionStatusEvent(statusEvent);
} }
else if (event instanceof BlueGigaDisconnectedEvent) { else if (event instanceof BlueGigaDisconnectedEvent disconnectedEvent) {
handleDisconnectedEvent((BlueGigaDisconnectedEvent) event); handleDisconnectedEvent(disconnectedEvent);
} }
else if (event instanceof BlueGigaAttributeValueEvent) { else if (event instanceof BlueGigaAttributeValueEvent valueEvent) {
handleAttributeValueEvent((BlueGigaAttributeValueEvent) event); handleAttributeValueEvent(valueEvent);
} }
} }

View File

@ -779,9 +779,8 @@ public class BlueGigaBridgeHandler extends AbstractBluetoothBridgeHandler<BlueGi
@Override @Override
public void bluegigaEventReceived(@Nullable BlueGigaResponse event) { public void bluegigaEventReceived(@Nullable BlueGigaResponse event) {
if (event instanceof BlueGigaScanResponseEvent) { if (event instanceof BlueGigaScanResponseEvent scanEvent) {
if (initComplete) { if (initComplete) {
BlueGigaScanResponseEvent scanEvent = (BlueGigaScanResponseEvent) event;
// We use the scan event to add any devices we hear to the devices list // We use the scan event to add any devices we hear to the devices list
// The device gets created, and then manages itself for discovery etc. // The device gets created, and then manages itself for discovery etc.
@ -795,13 +794,11 @@ public class BlueGigaBridgeHandler extends AbstractBluetoothBridgeHandler<BlueGi
return; return;
} }
if (event instanceof BlueGigaConnectionStatusEvent) { if (event instanceof BlueGigaConnectionStatusEvent connectionEvent) {
BlueGigaConnectionStatusEvent connectionEvent = (BlueGigaConnectionStatusEvent) event;
connections.put(connectionEvent.getConnection(), new BluetoothAddress(connectionEvent.getAddress())); connections.put(connectionEvent.getConnection(), new BluetoothAddress(connectionEvent.getAddress()));
} }
if (event instanceof BlueGigaDisconnectedEvent) { if (event instanceof BlueGigaDisconnectedEvent disconnectedEvent) {
BlueGigaDisconnectedEvent disconnectedEvent = (BlueGigaDisconnectedEvent) event;
connections.remove(disconnectedEvent.getConnection()); connections.remove(disconnectedEvent.getConnection());
} }
} }

View File

@ -35,11 +35,11 @@ public class BlueGigaConfiguration extends BaseBluetoothBridgeHandlerConfigurati
@Override @Override
public String toString() { public String toString() {
return String.format( return String.format("""
"[discovery=%b, port=%s, passiveScanIdleTime=%d, passiveScanInterval=%d, passiveScanWindow=%d" [discovery=%b, port=%s, passiveScanIdleTime=%d, passiveScanInterval=%d, passiveScanWindow=%d\
+ ", activeScanInterval=%d, activeScanWindow=%d, connIntervalMin=%d, connIntervalMax=%d" , activeScanInterval=%d, activeScanWindow=%d, connIntervalMin=%d, connIntervalMax=%d\
+ ", connLatency=%d, connTimeout=%d]", , connLatency=%d, connTimeout=%d]\
backgroundDiscovery, port, passiveScanIdleTime, passiveScanInterval, passiveScanWindow, """, backgroundDiscovery, port, passiveScanIdleTime, passiveScanInterval, passiveScanWindow,
activeScanInterval, activeScanWindow, connIntervalMin, connIntervalMax, connLatency, connTimeout); activeScanInterval, activeScanWindow, connIntervalMin, connIntervalMax, connLatency, connTimeout);
} }
} }

View File

@ -194,8 +194,7 @@ class BlueGigaResponsePackets {
try { try {
ctor = bleClass.getConstructor(int[].class); ctor = bleClass.getConstructor(int[].class);
BlueGigaResponse bleFrame = (BlueGigaResponse) ctor.newInstance(data); return (BlueGigaResponse) ctor.newInstance(data);
return bleFrame;
} catch (NoSuchMethodException | SecurityException | InstantiationException | IllegalAccessException } catch (NoSuchMethodException | SecurityException | InstantiationException | IllegalAccessException
| IllegalArgumentException | InvocationTargetException e) { | IllegalArgumentException | InvocationTargetException e) {
logger.debug("Error instantiating BLE class", e); logger.debug("Error instantiating BLE class", e);

View File

@ -260,8 +260,10 @@ public class BlueGigaSerialHandler {
private void checkIfAlive() { private void checkIfAlive() {
if (!isAlive()) { if (!isAlive()) {
throw new IllegalStateException("Bluegiga handler is dead. Most likely because of IO errors. " throw new IllegalStateException("""
+ "Re-initialization of the BlueGigaSerialHandler is required."); Bluegiga handler is dead. Most likely because of IO errors. \
Re-initialization of the BlueGigaSerialHandler is required.\
""");
} }
} }

View File

@ -154,7 +154,7 @@ public class BlueGigaTransactionManager implements BlueGigaSerialEventListener {
private void sendNextTransactionIfNoOngoing() { private void sendNextTransactionIfNoOngoing() {
synchronized (this) { synchronized (this) {
logger.trace("Send next transaction if no ongoing"); logger.trace("Send next transaction if no ongoing");
if (!ongoingTransactionId.isPresent()) { if (ongoingTransactionId.isEmpty()) {
sendNextFrame(); sendNextFrame();
} }
} }
@ -243,9 +243,8 @@ public class BlueGigaTransactionManager implements BlueGigaSerialEventListener {
logger.trace("Expected frame: {}, received frame: {}", expected.getSimpleName(), bleResponse); logger.trace("Expected frame: {}, received frame: {}", expected.getSimpleName(), bleResponse);
if (bleCommand instanceof BlueGigaDeviceCommand && bleResponse instanceof BlueGigaDeviceResponse) { if (bleCommand instanceof BlueGigaDeviceCommand devCommand
BlueGigaDeviceCommand devCommand = (BlueGigaDeviceCommand) bleCommand; && bleResponse instanceof BlueGigaDeviceResponse devResponse) {
BlueGigaDeviceResponse devResponse = (BlueGigaDeviceResponse) bleResponse;
logger.trace("Expected connection id: {}, received connection id: {}", devCommand.getConnection(), logger.trace("Expected connection id: {}, received connection id: {}", devCommand.getConnection(),
devResponse.getConnection()); devResponse.getConnection());

View File

@ -12,7 +12,6 @@
*/ */
package org.openhab.binding.bluetooth.bluegiga.internal.factory; package org.openhab.binding.bluetooth.bluegiga.internal.factory;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Map; import java.util.Map;
@ -48,8 +47,8 @@ import org.osgi.service.component.annotations.Reference;
@Component(service = ThingHandlerFactory.class, configurationPid = "binding.bluegiga") @Component(service = ThingHandlerFactory.class, configurationPid = "binding.bluegiga")
public class BlueGigaHandlerFactory extends BaseThingHandlerFactory { public class BlueGigaHandlerFactory extends BaseThingHandlerFactory {
private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Collections private static final Set<ThingTypeUID> SUPPORTED_THING_TYPES_UIDS = Set
.singleton(BlueGigaAdapterConstants.THING_TYPE_BLUEGIGA); .of(BlueGigaAdapterConstants.THING_TYPE_BLUEGIGA);
private final Map<ThingUID, ServiceRegistration<?>> serviceRegs = new HashMap<>(); private final Map<ThingUID, ServiceRegistration<?>> serviceRegs = new HashMap<>();
@ -90,8 +89,8 @@ public class BlueGigaHandlerFactory extends BaseThingHandlerFactory {
@Override @Override
protected synchronized void removeHandler(ThingHandler thingHandler) { protected synchronized void removeHandler(ThingHandler thingHandler) {
if (thingHandler instanceof BluetoothAdapter) { if (thingHandler instanceof BluetoothAdapter bluetoothAdapter) {
UID uid = ((BluetoothAdapter) thingHandler).getUID(); UID uid = bluetoothAdapter.getUID();
ServiceRegistration<?> serviceReg = this.serviceRegs.remove(uid); ServiceRegistration<?> serviceReg = this.serviceRegs.remove(uid);
if (serviceReg != null) { if (serviceReg != null) {
serviceReg.unregister(); serviceReg.unregister();

View File

@ -194,8 +194,7 @@ public class BlueZBridgeHandler extends AbstractBluetoothBridgeHandler<BlueZBlue
@Override @Override
protected BlueZBluetoothDevice createDevice(BluetoothAddress address) { protected BlueZBluetoothDevice createDevice(BluetoothAddress address) {
logger.debug("createDevice {}", address); logger.debug("createDevice {}", address);
BlueZBluetoothDevice device = new BlueZBluetoothDevice(this, address); return new BlueZBluetoothDevice(this, address);
return device;
} }
@Override @Override

Some files were not shown because too many files have changed in this diff Show More