[velux] Do not use new API on Somfy devices (#14225)

* [velux] revert use of new API for Somfy devices
* [velux] fix compare to wrong value

Signed-off-by: Andrew Fiddian-Green <software@whitebear.ch>
This commit is contained in:
Andrew Fiddian-Green 2023-01-29 09:32:33 +00:00 committed by GitHub
parent 01c38df9a5
commit 178d16c4a0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 9 additions and 2 deletions

View File

@ -95,10 +95,18 @@ final class ChannelActuatorPosition extends ChannelHandlerTemplate {
break; break;
} }
final VeluxExistingProducts existingProducts = thisBridgeHandler.existingProducts();
GetProduct bcp = null; GetProduct bcp = null;
switch (channelId) { switch (channelId) {
case CHANNEL_ACTUATOR_POSITION: case CHANNEL_ACTUATOR_POSITION:
case CHANNEL_ACTUATOR_STATE: case CHANNEL_ACTUATOR_STATE:
// apparently Somfy products do not to support new API; so use older API instead
if (existingProducts.get(veluxActuator.getProductBridgeIndex()).isSomfyProduct()) {
bcp = thisBridgeHandler.thisBridge.bridgeAPI().getProduct();
break;
}
// fall through
case CHANNEL_VANE_POSITION: case CHANNEL_VANE_POSITION:
bcp = thisBridgeHandler.thisBridge.bridgeAPI().getProductStatus(); bcp = thisBridgeHandler.thisBridge.bridgeAPI().getProductStatus();
default: default:
@ -118,7 +126,6 @@ final class ChannelActuatorPosition extends ChannelHandlerTemplate {
VeluxProduct newProduct = bcp.getProduct(); VeluxProduct newProduct = bcp.getProduct();
ProductBridgeIndex productBridgeIndex = newProduct.getBridgeProductIndex(); ProductBridgeIndex productBridgeIndex = newProduct.getBridgeProductIndex();
VeluxExistingProducts existingProducts = thisBridgeHandler.existingProducts();
VeluxProduct existingProduct = existingProducts.get(productBridgeIndex); VeluxProduct existingProduct = existingProducts.get(productBridgeIndex);
ProductState productState = newProduct.getProductState(); ProductState productState = newProduct.getProductState();
switch (productState) { switch (productState) {

View File

@ -140,7 +140,7 @@ public class VeluxProductPosition {
} }
public static boolean isUnknownOrValid(int position) { public static boolean isUnknownOrValid(int position) {
return (position == VeluxProductPosition.VPP_UNKNOWN) || isValid(position); return (position == VeluxProductPosition.VPP_VELUX_UNKNOWN) || isValid(position);
} }
/** /**