adapt to core StringUtils (#15784)

Signed-off-by: Leo Siepel <leosiepel@gmail.com>
This commit is contained in:
lsiepel 2023-10-28 14:39:27 +02:00 committed by GitHub
parent ab5ebbc41b
commit e761240bf0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 6 additions and 17 deletions

View File

@ -52,6 +52,7 @@ import org.openhab.binding.mybmw.internal.utils.Converter;
import org.openhab.binding.mybmw.internal.utils.HTTPConstants; import org.openhab.binding.mybmw.internal.utils.HTTPConstants;
import org.openhab.binding.mybmw.internal.utils.ImageProperties; import org.openhab.binding.mybmw.internal.utils.ImageProperties;
import org.openhab.core.io.net.http.HttpClientFactory; import org.openhab.core.io.net.http.HttpClientFactory;
import org.openhab.core.util.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -323,12 +324,12 @@ public class MyBMWProxy {
/* /*
* Step 2) Calculate values for base parameters * Step 2) Calculate values for base parameters
*/ */
String verfifierBytes = Converter.getRandomString(64); String verfifierBytes = StringUtils.getRandomAlphabetic(64).toLowerCase();
String codeVerifier = Base64.getUrlEncoder().withoutPadding().encodeToString(verfifierBytes.getBytes()); String codeVerifier = Base64.getUrlEncoder().withoutPadding().encodeToString(verfifierBytes.getBytes());
MessageDigest digest = MessageDigest.getInstance("SHA-256"); MessageDigest digest = MessageDigest.getInstance("SHA-256");
byte[] hash = digest.digest(codeVerifier.getBytes(StandardCharsets.UTF_8)); byte[] hash = digest.digest(codeVerifier.getBytes(StandardCharsets.UTF_8));
String codeChallange = Base64.getUrlEncoder().withoutPadding().encodeToString(hash); String codeChallange = Base64.getUrlEncoder().withoutPadding().encodeToString(hash);
String stateBytes = Converter.getRandomString(16); String stateBytes = StringUtils.getRandomAlphabetic(16).toLowerCase();
String state = Base64.getUrlEncoder().withoutPadding().encodeToString(stateBytes.getBytes()); String state = Base64.getUrlEncoder().withoutPadding().encodeToString(stateBytes.getBytes());
MultiMap<String> baseParams = new MultiMap<String>(); MultiMap<String> baseParams = new MultiMap<String>();

View File

@ -13,7 +13,6 @@
package org.openhab.binding.mybmw.internal.utils; package org.openhab.binding.mybmw.internal.utils;
import java.lang.reflect.Type; import java.lang.reflect.Type;
import java.security.SecureRandom;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import java.time.LocalTime; import java.time.LocalTime;
import java.time.ZoneId; import java.time.ZoneId;
@ -24,7 +23,6 @@ import java.util.ArrayList;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;
import java.util.Random;
import java.util.TimeZone; import java.util.TimeZone;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
@ -249,15 +247,6 @@ public class Converter {
return v; return v;
} }
public static String getRandomString(int size) {
int leftLimit = 97; // letter 'a'
int rightLimit = 122; // letter 'z'
Random random = new SecureRandom();
return random.ints(leftLimit, rightLimit + 1).limit(size)
.collect(StringBuilder::new, StringBuilder::appendCodePoint, StringBuilder::append).toString();
}
public static State getLockState(boolean lock) { public static State getLockState(boolean lock) {
if (lock) { if (lock) {
return StringType.valueOf(Constants.LOCKED); return StringType.valueOf(Constants.LOCKED);

View File

@ -46,6 +46,7 @@ import org.openhab.binding.mybmw.internal.utils.BimmerConstants;
import org.openhab.binding.mybmw.internal.utils.Constants; import org.openhab.binding.mybmw.internal.utils.Constants;
import org.openhab.binding.mybmw.internal.utils.Converter; import org.openhab.binding.mybmw.internal.utils.Converter;
import org.openhab.core.io.net.http.HttpClientFactory; import org.openhab.core.io.net.http.HttpClientFactory;
import org.openhab.core.util.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -78,16 +79,14 @@ class AuthTest {
AuthQueryResponse aqr = Converter.getGson().fromJson(firstResponse.getContentAsString(), AuthQueryResponse aqr = Converter.getGson().fromJson(firstResponse.getContentAsString(),
AuthQueryResponse.class); AuthQueryResponse.class);
// String verifier_bytes = RandomStringUtils.randomAlphanumeric(64); String verifierBytes = StringUtils.getRandomAlphabetic(64).toLowerCase();
String verifierBytes = Converter.getRandomString(64);
String codeVerifier = Base64.getUrlEncoder().withoutPadding().encodeToString(verifierBytes.getBytes()); String codeVerifier = Base64.getUrlEncoder().withoutPadding().encodeToString(verifierBytes.getBytes());
MessageDigest digest = MessageDigest.getInstance("SHA-256"); MessageDigest digest = MessageDigest.getInstance("SHA-256");
byte[] hash = digest.digest(codeVerifier.getBytes(StandardCharsets.UTF_8)); byte[] hash = digest.digest(codeVerifier.getBytes(StandardCharsets.UTF_8));
String codeChallenge = Base64.getUrlEncoder().withoutPadding().encodeToString(hash); String codeChallenge = Base64.getUrlEncoder().withoutPadding().encodeToString(hash);
// String state_bytes = RandomStringUtils.randomAlphanumeric(16); String stateBytes = StringUtils.getRandomAlphabetic(16).toLowerCase();
String stateBytes = Converter.getRandomString(16);
String state = Base64.getUrlEncoder().withoutPadding().encodeToString(stateBytes.getBytes()); String state = Base64.getUrlEncoder().withoutPadding().encodeToString(stateBytes.getBytes());
String authUrl = aqr.gcdmBaseUrl + BimmerConstants.OAUTH_ENDPOINT; String authUrl = aqr.gcdmBaseUrl + BimmerConstants.OAUTH_ENDPOINT;