[ecobee] Updates in prep for Dec 1 changes to Ecobee authorization process (#9065)

Signed-off-by: Mark Hilbush <mark@hilbush.com>
This commit is contained in:
Mark Hilbush 2020-11-24 13:05:10 -05:00 committed by GitHub
parent de04ad0dde
commit df971caa7a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 42 additions and 16 deletions

View File

@ -57,14 +57,14 @@ After you have installed the binding, you can create the Account thing using the
Once the Account thing is created, the binding will try to get information about your thermostats from the Ecobee web service.
When this happens, the binding will determine that it has not yet been authorized by the Ecobee web service.
At this point the binding will retrieve a four-character PIN code from the Ecobee web service.
At this point the binding will retrieve a multi-character PIN code from the Ecobee web service.
The binding will mark the Account thing OFFLINE with a detailed status message that contains the
PIN code needed to complete the authorization.
The PIN code will be valid for 9 minutes.
The PIN code will be valid for several minutes.
The status message will look something like this.
```
Enter PIN 'RVLA' in MyApps. PIN expires in 9 minutes.
Enter PIN 'JULO-RVLA' in MyApps. PIN expires in 257 minutes.
```
To complete the authorization, the PIN code must be entered into the Ecobee **My Apps** settings in your account at ecobee.com.
@ -72,6 +72,28 @@ This will authorize the binding to work with the thermostats associated with you
Once authorization is complete, the binding will retrieve information about the available thermostats,
and add those thermostats to the inbox.
## Ecobee Authorization Changes Effective 1 December 2020
Effective 1 Dec 2020, Ecobee implemented changes to their authorization process.
Ecobee recommends that users who authorized with Ecobee prior to 1 Dec 2020 should reauthorize their application as the new process affords greater security.
While the binding will continue to work using the old authorization method, it's recommended that you reauthorize the binding using the following process.
- You may need to update openHAB to get the latest version of the binding
- In the MyApps section of your Ecobee Portal, remove the application using the **Remove App** function.
- Wait up to one hour for the binding to do a token refresh with the Ecobee servers.
- At this point the Ecobee Account thing should be OFFLINE with a CONFIGURATION_PENDING status.
- In the MyApps section of your Ecobee Portal, re-add the binding using the **Add Application** function.
Use the PIN code that is displayed in the Ecobee Account thing status, or in the log file.
- Confirm that the binding is again communicating with the Ecobee servers.
You can do this by verifying that your items are updating, or by putting the binding in DEBUG mode and monitoring the log file.
- Post any issues on the forum.
## Thing Configuration
### Ecobee Account

View File

@ -117,25 +117,27 @@ public class EcobeeApi implements AccessTokenRefreshListener {
}
public void createOAuthClientService() {
logger.debug("API: Creating OAuth Client Service");
OAuthClientService service = oAuthFactory.createOAuthClientService(
bridgeHandler.getThing().getUID().getAsString(), ECOBEE_TOKEN_URL, null, apiKey, "", ECOBEE_SCOPE,
false);
String bridgeUID = bridgeHandler.getThing().getUID().getAsString();
logger.debug("API: Creating OAuth Client Service for {}", bridgeUID);
OAuthClientService service = oAuthFactory.createOAuthClientService(bridgeUID, ECOBEE_TOKEN_URL, null, apiKey,
"", ECOBEE_SCOPE, false);
service.addAccessTokenRefreshListener(this);
ecobeeAuth = new EcobeeAuth(bridgeHandler, apiKey, apiTimeout, service, httpClient);
oAuthClientService = service;
}
public void deleteOAuthClientService() {
logger.debug("API: Deleting OAuth Client Service");
String bridgeUID = bridgeHandler.getThing().getUID().getAsString();
logger.debug("API: Deleting OAuth Client Service for {}", bridgeUID);
oAuthClientService.removeAccessTokenRefreshListener(this);
oAuthFactory.deleteServiceAndAccessToken(bridgeHandler.getThing().getUID().getAsString());
oAuthFactory.deleteServiceAndAccessToken(bridgeUID);
}
public void closeOAuthClientService() {
logger.debug("API: Closing OAuth Client Service");
String bridgeUID = bridgeHandler.getThing().getUID().getAsString();
logger.debug("API: Closing OAuth Client Service for {}", bridgeUID);
oAuthClientService.removeAccessTokenRefreshListener(this);
oAuthFactory.ungetOAuthService(bridgeHandler.getThing().getUID().getAsString());
oAuthFactory.ungetOAuthService(bridgeUID);
}
/**
@ -319,10 +321,8 @@ public class EcobeeApi implements AccessTokenRefreshListener {
}
private boolean isSuccess(@Nullable AbstractResponseDTO response) {
boolean success = true;
if (response == null) {
logger.info("API: Ecobee API returned null response");
success = false;
} else if (response.status.code.intValue() != 0) {
logger.info("API: Ecobee API returned unsuccessful status: code={}, message={}", response.status.code,
response.status.message);
@ -334,13 +334,16 @@ public class EcobeeApi implements AccessTokenRefreshListener {
} else if (response.status.code == ECOBEE_TOKEN_EXPIRED) {
// Check isAuthorized again to see if we can get a valid token
logger.info("API: Unable to complete API call because token is expired");
if (!isAuthorized()) {
if (isAuthorized()) {
return true;
} else {
logger.warn("API: isAuthorized was NOT successful on second try");
}
}
success = false;
} else {
return true;
}
return success;
return false;
}
private Properties setHeaders() throws EcobeeAuthException {

View File

@ -80,6 +80,7 @@ public class EcobeeAuth {
this.bridgeHandler = bridgeHandler;
pinExpirationTime = 0;
state = EcobeeAuthState.NEED_PIN;
authResponse = null;
}
public void setState(EcobeeAuthState newState) {