From 7c2d5dcca5f4386f13560857e92dcb397dcd5cc5 Mon Sep 17 00:00:00 2001 From: Cody Cutrer Date: Thu, 22 Dec 2022 16:16:55 -0700 Subject: [PATCH] [homekit] implement List-Pairings method (#13982) * [homekit] implement List-Pairings method * [homekit] fix listUsers() method * [homekit] bump HAP-java to 2.0.5 refs #13949 Signed-off-by: Cody Cutrer --- bundles/org.openhab.io.homekit/pom.xml | 2 +- .../io/homekit/internal/HomekitAuthInfoImpl.java | 15 ++++++++++++++- 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/bundles/org.openhab.io.homekit/pom.xml b/bundles/org.openhab.io.homekit/pom.xml index 516609c66..12a0c39fd 100644 --- a/bundles/org.openhab.io.homekit/pom.xml +++ b/bundles/org.openhab.io.homekit/pom.xml @@ -22,7 +22,7 @@ io.github.hap-java hap - 2.0.4 + 2.0.5 compile diff --git a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitAuthInfoImpl.java b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitAuthInfoImpl.java index 941081150..57904c273 100644 --- a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitAuthInfoImpl.java +++ b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitAuthInfoImpl.java @@ -17,6 +17,7 @@ import java.security.InvalidAlgorithmParameterException; import java.util.Base64; import java.util.Collection; import java.util.HashSet; +import java.util.stream.Collectors; import org.eclipse.jdt.annotation.Nullable; import org.openhab.core.storage.Storage; @@ -62,7 +63,7 @@ public class HomekitAuthInfoImpl implements HomekitAuthInfo { } @Override - public void createUser(String username, byte[] publicKey) { + public void createUser(String username, byte[] publicKey, boolean isAdmin) { logger.trace("create user {}", username); final String userKey = createUserKey(username); final String encodedPublicKey = Base64.getEncoder().encodeToString(publicKey); @@ -133,6 +134,18 @@ public class HomekitAuthInfoImpl implements HomekitAuthInfo { return keys.stream().anyMatch(this::isUserKey); } + @Override + public Collection listUsers() { + Collection keys = storage.getKeys(); + // don't forget to strip user_ prefix + return keys.stream().filter(this::isUserKey).map(u -> u.substring(5)).collect(Collectors.toList()); + } + + @Override + public boolean userIsAdmin(String username) { + return true; + } + public void clear() { logger.trace("clear all users"); if (!this.blockUserDeletion) {