parent
ab5ebbc41b
commit
e761240bf0
|
@ -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>();
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue