[homeconnect] Returns an empty list of options for an unsupported program (#10694)
* [homeconnect] Returns an empty list of options for an unsupported program Fix #10689 Signed-off-by: Laurent Garnier <lg.hc@free.fr> * Review comment: List.of Signed-off-by: Laurent Garnier <lg.hc@free.fr>
This commit is contained in:
parent
266b4d81a4
commit
c68d920387
|
@ -12,13 +12,9 @@
|
||||||
*/
|
*/
|
||||||
package org.openhab.binding.homeconnect.internal.client;
|
package org.openhab.binding.homeconnect.internal.client;
|
||||||
|
|
||||||
import static java.util.Arrays.asList;
|
|
||||||
import static java.util.Collections.singletonList;
|
import static java.util.Collections.singletonList;
|
||||||
import static org.openhab.binding.homeconnect.internal.HomeConnectBindingConstants.*;
|
import static org.openhab.binding.homeconnect.internal.HomeConnectBindingConstants.*;
|
||||||
import static org.openhab.binding.homeconnect.internal.client.HttpHelper.formatJsonBody;
|
import static org.openhab.binding.homeconnect.internal.client.HttpHelper.*;
|
||||||
import static org.openhab.binding.homeconnect.internal.client.HttpHelper.getAuthorizationHeader;
|
|
||||||
import static org.openhab.binding.homeconnect.internal.client.HttpHelper.parseString;
|
|
||||||
import static org.openhab.binding.homeconnect.internal.client.HttpHelper.sendRequest;
|
|
||||||
|
|
||||||
import java.time.ZonedDateTime;
|
import java.time.ZonedDateTime;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -633,12 +629,21 @@ public class HomeConnectApiClient {
|
||||||
Request request = createRequest(HttpMethod.GET, BASE_PATH + haId + "/programs/available/" + programKey);
|
Request request = createRequest(HttpMethod.GET, BASE_PATH + haId + "/programs/available/" + programKey);
|
||||||
try {
|
try {
|
||||||
ContentResponse response = sendRequest(request, apiBridgeConfiguration.getClientId());
|
ContentResponse response = sendRequest(request, apiBridgeConfiguration.getClientId());
|
||||||
checkResponseCode(HttpStatus.OK_200, request, response, haId, null);
|
checkResponseCode(List.of(HttpStatus.OK_200, HttpStatus.NOT_FOUND_404), request, response, haId, null);
|
||||||
|
|
||||||
String responseBody = response.getContentAsString();
|
String responseBody = response.getContentAsString();
|
||||||
trackAndLogApiRequest(haId, request, null, response, responseBody);
|
trackAndLogApiRequest(haId, request, null, response, responseBody);
|
||||||
|
|
||||||
List<AvailableProgramOption> availableProgramOptions = mapToAvailableProgramOption(responseBody, haId);
|
// Code 404 accepted only if the returned error is "SDK.Error.UnsupportedProgram"
|
||||||
|
if (response.getStatus() == HttpStatus.NOT_FOUND_404
|
||||||
|
&& (responseBody == null || !responseBody.contains("SDK.Error.UnsupportedProgram"))) {
|
||||||
|
throw new CommunicationException(HttpStatus.NOT_FOUND_404, response.getReason(),
|
||||||
|
responseBody == null ? "" : responseBody);
|
||||||
|
}
|
||||||
|
|
||||||
|
List<AvailableProgramOption> availableProgramOptions = response.getStatus() == HttpStatus.OK_200
|
||||||
|
? mapToAvailableProgramOption(responseBody, haId)
|
||||||
|
: List.of();
|
||||||
availableProgramOptionsCache.put(programKey, availableProgramOptions);
|
availableProgramOptionsCache.put(programKey, availableProgramOptions);
|
||||||
return availableProgramOptions;
|
return availableProgramOptions;
|
||||||
} catch (InterruptedException | TimeoutException | ExecutionException e) {
|
} catch (InterruptedException | TimeoutException | ExecutionException e) {
|
||||||
|
@ -728,7 +733,7 @@ public class HomeConnectApiClient {
|
||||||
Request request = createRequest(HttpMethod.GET, path);
|
Request request = createRequest(HttpMethod.GET, path);
|
||||||
try {
|
try {
|
||||||
ContentResponse response = sendRequest(request, apiBridgeConfiguration.getClientId());
|
ContentResponse response = sendRequest(request, apiBridgeConfiguration.getClientId());
|
||||||
checkResponseCode(asList(HttpStatus.OK_200, HttpStatus.NOT_FOUND_404), request, response, haId, null);
|
checkResponseCode(List.of(HttpStatus.OK_200, HttpStatus.NOT_FOUND_404), request, response, haId, null);
|
||||||
|
|
||||||
String responseBody = response.getContentAsString();
|
String responseBody = response.getContentAsString();
|
||||||
trackAndLogApiRequest(haId, request, null, response, responseBody);
|
trackAndLogApiRequest(haId, request, null, response, responseBody);
|
||||||
|
|
|
@ -17,6 +17,7 @@ import static java.util.Collections.emptyList;
|
||||||
import static org.openhab.binding.homeconnect.internal.HomeConnectBindingConstants.*;
|
import static org.openhab.binding.homeconnect.internal.HomeConnectBindingConstants.*;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
|
@ -25,6 +26,7 @@ import org.openhab.binding.homeconnect.internal.client.HomeConnectApiClient;
|
||||||
import org.openhab.binding.homeconnect.internal.client.exception.ApplianceOfflineException;
|
import org.openhab.binding.homeconnect.internal.client.exception.ApplianceOfflineException;
|
||||||
import org.openhab.binding.homeconnect.internal.client.exception.AuthorizationException;
|
import org.openhab.binding.homeconnect.internal.client.exception.AuthorizationException;
|
||||||
import org.openhab.binding.homeconnect.internal.client.exception.CommunicationException;
|
import org.openhab.binding.homeconnect.internal.client.exception.CommunicationException;
|
||||||
|
import org.openhab.binding.homeconnect.internal.client.model.AvailableProgramOption;
|
||||||
import org.openhab.binding.homeconnect.internal.client.model.Data;
|
import org.openhab.binding.homeconnect.internal.client.model.Data;
|
||||||
import org.openhab.binding.homeconnect.internal.type.HomeConnectDynamicStateDescriptionProvider;
|
import org.openhab.binding.homeconnect.internal.type.HomeConnectDynamicStateDescriptionProvider;
|
||||||
import org.openhab.core.library.types.OnOffType;
|
import org.openhab.core.library.types.OnOffType;
|
||||||
|
@ -217,7 +219,12 @@ public class HomeConnectHoodHandler extends AbstractHomeConnectThingHandler {
|
||||||
new StateOption(COMMAND_DELAYED_SHUT_OFF, mapStringType(availableProgram.getKey())));
|
new StateOption(COMMAND_DELAYED_SHUT_OFF, mapStringType(availableProgram.getKey())));
|
||||||
} else if (PROGRAM_HOOD_VENTING.equals(availableProgram.getKey())) {
|
} else if (PROGRAM_HOOD_VENTING.equals(availableProgram.getKey())) {
|
||||||
try {
|
try {
|
||||||
apiClient.get().getProgramOptions(getThingHaId(), PROGRAM_HOOD_VENTING).forEach(option -> {
|
List<AvailableProgramOption> availableProgramOptions = apiClient.get()
|
||||||
|
.getProgramOptions(getThingHaId(), PROGRAM_HOOD_VENTING);
|
||||||
|
if (availableProgramOptions.isEmpty()) {
|
||||||
|
throw new CommunicationException("Program " + PROGRAM_HOOD_VENTING + " is unsupported");
|
||||||
|
}
|
||||||
|
availableProgramOptions.forEach(option -> {
|
||||||
if (OPTION_HOOD_VENTING_LEVEL.equalsIgnoreCase(option.getKey())) {
|
if (OPTION_HOOD_VENTING_LEVEL.equalsIgnoreCase(option.getKey())) {
|
||||||
option.getAllowedValues().stream().filter(s -> !STAGE_FAN_OFF.equalsIgnoreCase(s))
|
option.getAllowedValues().stream().filter(s -> !STAGE_FAN_OFF.equalsIgnoreCase(s))
|
||||||
.forEach(s -> stateOptions.add(createVentingStateOption(s)));
|
.forEach(s -> stateOptions.add(createVentingStateOption(s)));
|
||||||
|
|
Loading…
Reference in New Issue