parent
c5eeb704ee
commit
654f1f74ff
2 changed files with 163 additions and 31 deletions
|
@ -21,35 +21,52 @@ import org.keycloak.models.ClientModel;
|
||||||
import org.keycloak.models.UserModel;
|
import org.keycloak.models.UserModel;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author <a href="mailto:bill@burkecentral.com">Bill Burke</a>
|
* @author <a href="mailto:bill@burkecentral.com">Bill Burke</a>
|
||||||
* @version $Revision: 1 $
|
* @version $Revision: 1 $
|
||||||
*/
|
*/
|
||||||
public class StorageId implements Serializable {
|
public class StorageId implements Serializable {
|
||||||
private String id;
|
private final String providerId;
|
||||||
private String providerId;
|
private final String externalId;
|
||||||
private String externalId;
|
|
||||||
|
|
||||||
|
|
||||||
public StorageId(String id) {
|
public StorageId(String id) {
|
||||||
this.id = id;
|
|
||||||
if (!id.startsWith("f:")) {
|
if (!id.startsWith("f:")) {
|
||||||
|
providerId = null;
|
||||||
externalId = id;
|
externalId = id;
|
||||||
return;
|
} else {
|
||||||
|
int providerIndex = id.indexOf(':', 2);
|
||||||
|
providerId = id.substring(2, providerIndex);
|
||||||
|
externalId = id.substring(providerIndex + 1);
|
||||||
}
|
}
|
||||||
int providerIndex = id.indexOf(':', 2);
|
|
||||||
providerId = id.substring(2, providerIndex);
|
|
||||||
externalId = id.substring(providerIndex + 1);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public StorageId(String providerId, String externalId) {
|
public StorageId(String providerId, String externalId) {
|
||||||
this.id = "f:" + providerId + ":" + externalId;
|
if (providerId != null && providerId.contains(":")) {
|
||||||
|
throw new IllegalArgumentException("Provider must not contain a colon (:) character");
|
||||||
|
}
|
||||||
this.providerId = providerId;
|
this.providerId = providerId;
|
||||||
this.externalId = externalId;
|
this.externalId = externalId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isLocal() {
|
||||||
|
return getProviderId() == null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getId() {
|
||||||
|
return providerId == null ? externalId : ("f:" + providerId + ":" + externalId);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getProviderId() {
|
||||||
|
return providerId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getExternalId() {
|
||||||
|
return externalId;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* generate the id string that should be returned by UserModel.getId()
|
* generate the id string that should be returned by UserModel.getId()
|
||||||
*
|
*
|
||||||
|
@ -68,40 +85,67 @@ public class StorageId implements Serializable {
|
||||||
return new StorageId(keycloakId).getProviderId();
|
return new StorageId(keycloakId).getProviderId();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static String resolveProviderId(UserModel user) {
|
|
||||||
return new StorageId(user.getId()).getProviderId();
|
|
||||||
}
|
|
||||||
public static boolean isLocalStorage(UserModel user) {
|
|
||||||
return new StorageId(user.getId()).getProviderId() == null;
|
|
||||||
}
|
|
||||||
public static boolean isLocalStorage(String id) {
|
public static boolean isLocalStorage(String id) {
|
||||||
return new StorageId(id).getProviderId() == null;
|
return new StorageId(id).getProviderId() == null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use {@link #providerId(String)} instead.
|
||||||
|
*/
|
||||||
|
public static String resolveProviderId(UserModel user) {
|
||||||
|
return providerId(user.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use {@link #isLocalStorage(String)} instead.
|
||||||
|
*/
|
||||||
|
public static boolean isLocalStorage(UserModel user) {
|
||||||
|
return isLocalStorage(user.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use {@link #providerId(String)} instead.
|
||||||
|
*/
|
||||||
public static String resolveProviderId(ClientModel client) {
|
public static String resolveProviderId(ClientModel client) {
|
||||||
return new StorageId(client.getId()).getProviderId();
|
return providerId(client.getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Use {@link #isLocalStorage(String)} instead.
|
||||||
|
*/
|
||||||
public static boolean isLocalStorage(ClientModel client) {
|
public static boolean isLocalStorage(ClientModel client) {
|
||||||
return new StorageId(client.getId()).getProviderId() == null;
|
return isLocalStorage(client.getId());
|
||||||
}
|
|
||||||
public boolean isLocal() {
|
|
||||||
return getProviderId() == null;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getId() {
|
@Override
|
||||||
return id;
|
public int hashCode() {
|
||||||
|
return Objects.hash(providerId, externalId);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getProviderId() {
|
@Override
|
||||||
return providerId;
|
public boolean equals(Object obj) {
|
||||||
|
if (this == obj) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (obj == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (getClass() != obj.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final StorageId other = (StorageId) obj;
|
||||||
|
if ( ! Objects.equals(this.providerId, other.providerId)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if ( ! Objects.equals(this.externalId, other.externalId)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getExternalId() {
|
@Override
|
||||||
return externalId;
|
public String toString() {
|
||||||
|
return getId();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,88 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2021 Red Hat, Inc. and/or its affiliates
|
||||||
|
* and other contributors as indicated by the @author tags.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.keycloak.storage;
|
||||||
|
|
||||||
|
import org.keycloak.component.ComponentModel;
|
||||||
|
import org.junit.Test;
|
||||||
|
import static org.hamcrest.CoreMatchers.equalTo;
|
||||||
|
import static org.hamcrest.CoreMatchers.is;
|
||||||
|
import static org.hamcrest.CoreMatchers.not;
|
||||||
|
import static org.hamcrest.CoreMatchers.notNullValue;
|
||||||
|
import static org.hamcrest.CoreMatchers.nullValue;
|
||||||
|
import static org.hamcrest.MatcherAssert.assertThat;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author hmlnarik
|
||||||
|
*/
|
||||||
|
public class StorageIdTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testStatic() {
|
||||||
|
final String localId = "123";
|
||||||
|
assertThat(StorageId.externalId(localId), is("123"));
|
||||||
|
assertThat(StorageId.providerId(localId), nullValue());
|
||||||
|
assertTrue(StorageId.isLocalStorage(localId));
|
||||||
|
|
||||||
|
final String remoteId = "f:abc:123";
|
||||||
|
assertThat(StorageId.externalId(remoteId), is("123"));
|
||||||
|
assertThat(StorageId.providerId(remoteId), is("abc"));
|
||||||
|
assertFalse(StorageId.isLocalStorage(remoteId));
|
||||||
|
|
||||||
|
final ComponentModel cm = new ComponentModel();
|
||||||
|
cm.setId("localId");
|
||||||
|
assertThat(StorageId.keycloakId(cm, localId), is("f:localId:123"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLocalId() {
|
||||||
|
StorageId id = new StorageId("123");
|
||||||
|
assertThat(id, notNullValue());
|
||||||
|
assertThat(id.getExternalId(), is("123"));
|
||||||
|
assertThat(id.getProviderId(), nullValue());
|
||||||
|
assertThat(id.getId(), is("123"));
|
||||||
|
assertTrue(id.isLocal());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testExternalIdString() {
|
||||||
|
StorageId id = new StorageId("f:abc:123");
|
||||||
|
assertThat(id, notNullValue());
|
||||||
|
assertThat(id.getExternalId(), is("123"));
|
||||||
|
assertThat(id.getProviderId(), is("abc"));
|
||||||
|
assertThat(id.getId(), is("f:abc:123"));
|
||||||
|
assertFalse(id.isLocal());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testExternalIdTwoStrings() {
|
||||||
|
StorageId id = new StorageId("abc", "123");
|
||||||
|
assertThat(id, notNullValue());
|
||||||
|
assertThat(id.getExternalId(), is("123"));
|
||||||
|
assertThat(id.getProviderId(), is("abc"));
|
||||||
|
assertThat(id.getId(), is("f:abc:123"));
|
||||||
|
assertFalse(id.isLocal());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testEquals() {
|
||||||
|
assertThat(new StorageId("abc", "123"), equalTo(new StorageId("f:abc:123")));
|
||||||
|
assertThat(new StorageId("abc", "123"), not(equalTo(new StorageId("f:abc:1234"))));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue