Skip to content

Commit

Permalink
Short verification_uri for Device Authorization Request
Browse files Browse the repository at this point in the history
  • Loading branch information
cgeorgilakis authored and mposolda committed Jan 18, 2023
1 parent dceb2f9 commit c738597
Show file tree
Hide file tree
Showing 4 changed files with 45 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,8 @@ public class DeviceEndpoint extends AuthorizationEndpointBase implements RealmRe

protected static final Logger logger = Logger.getLogger(DeviceEndpoint.class);

public static final String SHORT_VERIFICATION_URI = "shortVerificationUri";

private final HttpRequest request;

private Cors cors;
Expand Down Expand Up @@ -168,7 +170,7 @@ public Response handleDeviceRequest() {
singleUseStore.put(userCode.serializeKey(), lifespanSeconds, userCode.serializeValue());

try {
String deviceUrl = DeviceGrantType.oauth2DeviceVerificationUrl(session.getContext().getUri()).build(realm.getName())
String deviceUrl = realm.getAttribute(SHORT_VERIFICATION_URI) != null ? realm.getAttribute(SHORT_VERIFICATION_URI) : DeviceGrantType.oauth2DeviceVerificationUrl(session.getContext().getUri()).build(realm.getName())
.toString();

OAuth2DeviceAuthorizationResponse response = new OAuth2DeviceAuthorizationResponse();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
import org.keycloak.models.OAuth2DeviceConfig;
import org.keycloak.models.utils.KeycloakModelUtils;
import org.keycloak.protocol.oidc.OIDCConfigAttributes;
import org.keycloak.protocol.oidc.grants.device.endpoints.DeviceEndpoint;
import org.keycloak.representations.AccessToken;
import org.keycloak.representations.UserInfo;
import org.keycloak.representations.idm.ClientRepresentation;
Expand Down Expand Up @@ -71,10 +72,11 @@ public class OAuth2DeviceAuthorizationGrantTest extends AbstractKeycloakTest {

private static String userId;

public static final String REALM_NAME = "test";
public static final String DEVICE_APP = "test-device";
public static final String DEVICE_APP_PUBLIC = "test-device-public";
public static final String DEVICE_APP_PUBLIC_CUSTOM_CONSENT = "test-device-public-custom-consent";
private static final String REALM_NAME = "test";
private static final String DEVICE_APP = "test-device";
private static final String DEVICE_APP_PUBLIC = "test-device-public";
private static final String DEVICE_APP_PUBLIC_CUSTOM_CONSENT = "test-device-public-custom-consent";
private static final String SHORT_DEVICE_FLOW_URL = "https://keycloak.org/device";

@Rule
public AssertEvents events = new AssertEvents(this);
Expand Down Expand Up @@ -217,6 +219,32 @@ public void testPublicClient() throws Exception {
assertNotNull(token);
}


@Test
public void testCustomVerificationUri() throws Exception {
// Device Authorization Request from device
try {
RealmResource testRealm = adminClient.realm(REALM_NAME);
RealmRepresentation realmRep = testRealm.toRepresentation();
realmRep.getAttributes().put(DeviceEndpoint.SHORT_VERIFICATION_URI, SHORT_DEVICE_FLOW_URL);
testRealm.update(realmRep);
oauth.realm(REALM_NAME);
oauth.clientId(DEVICE_APP_PUBLIC);
OAuthClient.DeviceAuthorizationResponse response = oauth.doDeviceAuthorizationRequest(DEVICE_APP_PUBLIC, null);

Assert.assertEquals(200, response.getStatusCode());
assertNotNull(response.getDeviceCode());
assertNotNull(response.getUserCode());
Assert.assertEquals(SHORT_DEVICE_FLOW_URL,response.getVerificationUri());
Assert.assertEquals(SHORT_DEVICE_FLOW_URL + "?user_code=" + response.getUserCode(),response.getVerificationUriComplete());
} finally {
RealmResource testRealm = adminClient.realm(REALM_NAME);
RealmRepresentation realmRep = testRealm.toRepresentation();
realmRep.getAttributes().remove("shortVerificationUri");
testRealm.update(realmRep);
}
}

@Test
public void testPublicClientOptionalScope() throws Exception {
// Device Authorization Request from device - check giving optional scope phone
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -474,6 +474,8 @@ policy-uri=Policy URL
policy-uri.tooltip=URL that the Relying Party Client provides to the End-User to read about the how the profile data will be used
tos-uri=Terms of service URL
tos-uri.tooltip=URL that the Relying Party Client provides to the End-User to read about the Relying Party's terms of service
short-verification-uri= Short verification_uri in Device Authorization flow
short-verification-uri.tooltip= If set, this value will be return as verification_uri in Device Authorization flow. This uri need to redirect to {server-root}/realms/{realm}/device


# client import
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -387,6 +387,14 @@
<kc-tooltip>{{:: 'oauth2-device-polling-interval.tooltip' | translate}}</kc-tooltip>
</div>

<div class="form-group">
<label class="col-md-2 control-label" for="shortVerificationUri">{{:: 'short-verification-uri' | translate}}</label>
<div class="col-md-6">
<input class="form-control" id="shortVerificationUri" type="text" ng-model="realm.attributes.shortVerificationUri" name="shortVerificationUri">
</div>
<kc-tooltip>{{:: 'short-verification-uri.tooltip' | translate}}</kc-tooltip>
</div>

<div class="form-group">
<div class="col-md-10 col-md-offset-2" data-ng-show="access.manageRealm">
<button kc-save data-ng-disabled="!changed">{{:: 'save' | translate}}</button>
Expand Down

0 comments on commit c738597

Please sign in to comment.