Skip to content

Commit

Permalink
[nanoleaf] Bugfix: Handle non-integer panel ids (openhab#13951)
Browse files Browse the repository at this point in the history
Panel ids are sometimes returned as BigInteger

We haven't been able to understand why this happens somewhere and
somewhere not, but this is an sledgehammer attempt to fix it quickly
to unblock users, and then we will try to understand it later.

Discussions:
https://community.openhab.org/t/java-lang-classcastexception-class-java-math-bigdecimal-cannot-be-cast-to-class-java-lang-integer/142035/16
https://community.openhab.org/t/nanoleaf-binding-oh3-stabilization-update/116300/61

Signed-off-by: Jørgen Austvik <jaustvik@acm.org>
Signed-off-by: Andras Uhrin <andras.uhrin@gmail.com>
  • Loading branch information
austvik authored and andrasU committed Dec 24, 2022
1 parent 3c2476c commit 33357fb
Showing 1 changed file with 15 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -286,7 +286,21 @@ public void updatePanelGesture(int gesture) {
}

public Integer getPanelID() {
return (Integer) getThing().getConfiguration().get(CONFIG_PANEL_ID);
Object panelId = getThing().getConfiguration().get(CONFIG_PANEL_ID);
if (panelId instanceof Integer) {
return (Integer) panelId;
} else if (panelId instanceof Number) {
return ((Number) panelId).intValue();
} else {
// Fall back to parsing string representation of panel if it is not returning an integer
String stringPanelId = panelId.toString();
Integer parsedPanelId = Integer.getInteger(stringPanelId);
if (parsedPanelId == null) {
return 0;
} else {
return parsedPanelId;
}
}
}

private void setPanelColor(HSBType color) {
Expand Down

0 comments on commit 33357fb

Please sign in to comment.