|
@@ -1,5 +1,5 @@
|
|
|
/*
|
|
|
- * Copyright 2020-2023 the original author or authors.
|
|
|
+ * Copyright 2020-2025 the original author or authors.
|
|
|
*
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
* you may not use this file except in compliance with the License.
|
|
@@ -134,9 +134,30 @@ public final class OAuth2DeviceCodeAuthenticationProvider implements Authenticat
|
|
|
throw new OAuth2AuthenticationException(OAuth2ErrorCodes.INVALID_GRANT);
|
|
|
}
|
|
|
|
|
|
+ if (deviceCode.isInvalidated() && !userCode.isInvalidated()) {
|
|
|
+ throw new OAuth2AuthenticationException(OAuth2ErrorCodes.INVALID_GRANT);
|
|
|
+ }
|
|
|
+
|
|
|
// In https://www.rfc-editor.org/rfc/rfc8628.html#section-3.5,
|
|
|
// the following error codes are defined:
|
|
|
|
|
|
+ // expired_token
|
|
|
+ // The "device_code" has expired, and the device authorization
|
|
|
+ // session has concluded. The client MAY commence a new device
|
|
|
+ // authorization request but SHOULD wait for user interaction before
|
|
|
+ // restarting to avoid unnecessary polling.
|
|
|
+ if (deviceCode.isExpired()) {
|
|
|
+ // Invalidate the device code
|
|
|
+ authorization = OAuth2AuthenticationProviderUtils.invalidate(authorization, deviceCode.getToken());
|
|
|
+ this.authorizationService.save(authorization);
|
|
|
+ if (this.logger.isWarnEnabled()) {
|
|
|
+ this.logger.warn(LogMessage.format("Invalidated device code used by registered client '%s'",
|
|
|
+ authorization.getRegisteredClientId()));
|
|
|
+ }
|
|
|
+ OAuth2Error error = new OAuth2Error(EXPIRED_TOKEN, null, DEVICE_ERROR_URI);
|
|
|
+ throw new OAuth2AuthenticationException(error);
|
|
|
+ }
|
|
|
+
|
|
|
// authorization_pending
|
|
|
// The authorization request is still pending as the end user hasn't
|
|
|
// yet completed the user-interaction steps (Section 3.3). The
|
|
@@ -165,23 +186,6 @@ public final class OAuth2DeviceCodeAuthenticationProvider implements Authenticat
|
|
|
throw new OAuth2AuthenticationException(error);
|
|
|
}
|
|
|
|
|
|
- // expired_token
|
|
|
- // The "device_code" has expired, and the device authorization
|
|
|
- // session has concluded. The client MAY commence a new device
|
|
|
- // authorization request but SHOULD wait for user interaction before
|
|
|
- // restarting to avoid unnecessary polling.
|
|
|
- if (deviceCode.isExpired()) {
|
|
|
- // Invalidate the device code
|
|
|
- authorization = OAuth2AuthenticationProviderUtils.invalidate(authorization, deviceCode.getToken());
|
|
|
- this.authorizationService.save(authorization);
|
|
|
- if (this.logger.isWarnEnabled()) {
|
|
|
- this.logger.warn(LogMessage.format("Invalidated device code used by registered client '%s'",
|
|
|
- authorization.getRegisteredClientId()));
|
|
|
- }
|
|
|
- OAuth2Error error = new OAuth2Error(EXPIRED_TOKEN, null, DEVICE_ERROR_URI);
|
|
|
- throw new OAuth2AuthenticationException(error);
|
|
|
- }
|
|
|
-
|
|
|
if (this.logger.isTraceEnabled()) {
|
|
|
this.logger.trace("Validated device token request parameters");
|
|
|
}
|