CachedClient.java

260 lines | 8.454 kB Blame History Raw Download
// /*
//  * Copyright 2016 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.models.cache.infinispan.entities;

// import org.keycloak.models.ClientModel;
// import org.keycloak.models.ClientScopeModel;
// import org.keycloak.models.ProtocolMapperModel;
// import org.keycloak.models.RealmModel;
// import org.keycloak.models.RoleModel;

// import java.util.HashMap;
// import java.util.HashSet;
// import java.util.LinkedList;
// import java.util.List;
// import java.util.Map;
// import java.util.Set;
// import java.util.TreeMap;

// /**
//  * @author <a href="mailto:bill@burkecentral.com">Bill Burke</a>
//  * @version $Revision: 1 $
//  */
// public class CachedClient extends AbstractRevisioned implements InRealm {
//     protected String clientId;
//     protected String name;
//     protected String description;
//     protected String realm;
//     protected Set<String> redirectUris = new HashSet<String>();
//     protected boolean enabled;
//     protected String clientAuthenticatorType;
//     protected String secret;
//     protected String registrationToken;
//     protected String protocol;
//     protected Map<String, String> attributes = new HashMap<String, String>();
//     protected Map<String, String> authFlowBindings = new HashMap<String, String>();
//     protected boolean publicClient;
//     protected boolean fullScopeAllowed;
//     protected boolean frontchannelLogout;
//     protected int notBefore;
//     protected Set<String> scope = new HashSet<String>();
//     protected Set<String> webOrigins = new HashSet<String>();
//     protected Set<ProtocolMapperModel> protocolMappers = new HashSet<ProtocolMapperModel>();
//     protected boolean surrogateAuthRequired;
//     protected String managementUrl;
//     protected String rootUrl;
//     protected String baseUrl;
//     protected List<String> defaultRoles = new LinkedList<String>();
//     protected boolean bearerOnly;
//     protected boolean consentRequired;
//     protected boolean standardFlowEnabled;
//     protected boolean implicitFlowEnabled;
//     protected boolean directAccessGrantsEnabled;
//     protected boolean serviceAccountsEnabled;
//     protected int nodeReRegistrationTimeout;
//     protected Map<String, Integer> registeredNodes;
//     protected List<String> defaultClientScopesIds;
//     protected List<String> optionalClientScopesIds;

//     public CachedClient(Long revision, RealmModel realm, ClientModel model) {
//         super(revision, model.getId());
//         clientAuthenticatorType = model.getClientAuthenticatorType();
//         secret = model.getSecret();
//         registrationToken = model.getRegistrationToken();
//         clientId = model.getClientId();
//         name = model.getName();
//         description = model.getDescription();
//         this.realm = realm.getId();
//         enabled = model.isEnabled();
//         protocol = model.getProtocol();
//         attributes.putAll(model.getAttributes());
//         authFlowBindings.putAll(model.getAuthenticationFlowBindingOverrides());
//         notBefore = model.getNotBefore();
//         frontchannelLogout = model.isFrontchannelLogout();
//         publicClient = model.isPublicClient();
//         fullScopeAllowed = model.isFullScopeAllowed();
//         redirectUris.addAll(model.getRedirectUris());
//         webOrigins.addAll(model.getWebOrigins());
//         for (RoleModel role : model.getScopeMappings())  {
//             scope.add(role.getId());
//         }
//         for (ProtocolMapperModel mapper : model.getProtocolMappers()) {
//             this.protocolMappers.add(mapper);
//         }
//         surrogateAuthRequired = model.isSurrogateAuthRequired();
//         managementUrl = model.getManagementUrl();
//         rootUrl = model.getRootUrl();
//         baseUrl = model.getBaseUrl();
//         defaultRoles.addAll(model.getDefaultRoles());
//         bearerOnly = model.isBearerOnly();
//         consentRequired = model.isConsentRequired();
//         standardFlowEnabled = model.isStandardFlowEnabled();
//         implicitFlowEnabled = model.isImplicitFlowEnabled();
//         directAccessGrantsEnabled = model.isDirectAccessGrantsEnabled();
//         serviceAccountsEnabled = model.isServiceAccountsEnabled();

//         nodeReRegistrationTimeout = model.getNodeReRegistrationTimeout();
//         registeredNodes = new TreeMap<>(model.getRegisteredNodes());

//         defaultClientScopesIds = new LinkedList<>();
//         for (ClientScopeModel clientScope : model.getClientScopes(true, false).values()) {
//             defaultClientScopesIds.add(clientScope.getId());
//         }
//         optionalClientScopesIds = new LinkedList<>();
//         for (ClientScopeModel clientScope : model.getClientScopes(false, false).values()) {
//             optionalClientScopesIds.add(clientScope.getId());
//         }
//     }

//     public String getClientId() {
//         return clientId;
//     }

//     public String getName() {
//         return name;
//     }

//     public String getDescription() { return description; }

//     public void setDescription(String description) { this.description = description; }

//     public String getRealm() {
//         return realm;
//     }

//     public Set<String> getRedirectUris() {
//         return redirectUris;
//     }

//     public boolean isEnabled() {
//         return enabled;
//     }

//     public String getClientAuthenticatorType() {
//         return clientAuthenticatorType;
//     }

//     public String getSecret() {
//         return secret;
//     }

//     public String getRegistrationToken() {
//         return registrationToken;
//     }

//     public boolean isPublicClient() {
//         return publicClient;
//     }

//     public int getNotBefore() {
//         return notBefore;
//     }

//     public Set<String> getScope() {
//         return scope;
//     }

//     public Set<String> getWebOrigins() {
//         return webOrigins;
//     }

//     public boolean isFullScopeAllowed() {
//         return fullScopeAllowed;
//     }

//     public String getProtocol() {
//         return protocol;
//     }

//     public Map<String, String> getAttributes() {
//         return attributes;
//     }

//     public boolean isFrontchannelLogout() {
//         return frontchannelLogout;
//     }

//     public Set<ProtocolMapperModel> getProtocolMappers() {
//         return protocolMappers;
//     }

//     public boolean isSurrogateAuthRequired() {
//         return surrogateAuthRequired;
//     }

//     public String getManagementUrl() {
//         return managementUrl;
//     }

//     public String getRootUrl() {
//         return rootUrl;
//     }

//     public String getBaseUrl() {
//         return baseUrl;
//     }

//     public List<String> getDefaultRoles() {
//         return defaultRoles;
//     }

//     public boolean isBearerOnly() {
//         return bearerOnly;
//     }

//     public boolean isConsentRequired() {
//         return consentRequired;
//     }

//     public boolean isStandardFlowEnabled() {
//         return standardFlowEnabled;
//     }

//     public boolean isImplicitFlowEnabled() {
//         return implicitFlowEnabled;
//     }

//     public boolean isDirectAccessGrantsEnabled() {
//         return directAccessGrantsEnabled;
//     }

//     public boolean isServiceAccountsEnabled() {
//         return serviceAccountsEnabled;
//     }

//     public int getNodeReRegistrationTimeout() {
//         return nodeReRegistrationTimeout;
//     }

//     public Map<String, Integer> getRegisteredNodes() {
//         return registeredNodes;
//     }

//     public List<String> getDefaultClientScopesIds() {
//         return defaultClientScopesIds;
//     }

//     public List<String> getOptionalClientScopesIds() {
//         return optionalClientScopesIds;
//     }

//     public Map<String, String> getAuthFlowBindings() {
//         return authFlowBindings;
//     }
// }