All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.wildfly.security.auth.realm.CachingModifiableSecurityRealm Maven / Gradle / Ivy

The newest version!
/*
 * JBoss, Home of Professional Open Source.
 * Copyright 2016 Red Hat, Inc., and individual 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.wildfly.security.auth.realm;

import java.security.Principal;
import java.security.Provider;
import java.security.spec.AlgorithmParameterSpec;
import java.util.Collection;
import java.util.function.Function;
import java.util.function.Supplier;

import org.wildfly.common.function.ExceptionConsumer;
import org.wildfly.security.auth.SupportLevel;
import org.wildfly.security.auth.server.ModifiableRealmIdentityIterator;
import org.wildfly.security.auth.server.ModifiableRealmIdentity;
import org.wildfly.security.auth.server.ModifiableSecurityRealm;
import org.wildfly.security.auth.server.RealmIdentity;
import org.wildfly.security.auth.server.RealmUnavailableException;
import org.wildfly.security.authz.Attributes;
import org.wildfly.security.authz.AuthorizationIdentity;
import org.wildfly.security.cache.RealmIdentityCache;
import org.wildfly.security.credential.Credential;
import org.wildfly.security.evidence.Evidence;

/**
 * 

A wrapper class that provides caching capabilities for a {@link org.wildfly.security.auth.server.ModifiableSecurityRealm} and its identities. * * @author Pedro Igor */ public class CachingModifiableSecurityRealm extends CachingSecurityRealm implements ModifiableSecurityRealm { /** * Creates a new instance. * * @param realm the {@link CacheableSecurityRealm} whose {@link RealmIdentity} should be cached. * @param cache the {@link RealmIdentityCache} instance */ public CachingModifiableSecurityRealm(CacheableSecurityRealm realm, RealmIdentityCache cache) { super(realm, cache); } /** * Creates a new instance. * * @param realm the {@link CacheableSecurityRealm} whose {@link RealmIdentity} should be cached. * @param cache the {@link RealmIdentityCache} instance * @param providerSupplier the provider supplier to use for verification purposes (must not be {@code null}) */ public CachingModifiableSecurityRealm(CacheableSecurityRealm realm, RealmIdentityCache cache, Supplier providerSupplier) { super(realm, cache, providerSupplier); } @Override public ModifiableRealmIdentity getRealmIdentityForUpdate(Principal principal) throws RealmUnavailableException { return wrap(getModifiableSecurityRealm().getRealmIdentityForUpdate(principal)); } @Override public ModifiableRealmIdentityIterator getRealmIdentityIterator() throws RealmUnavailableException { ModifiableRealmIdentityIterator iterator = getModifiableSecurityRealm().getRealmIdentityIterator(); return new ModifiableRealmIdentityIterator() { @Override public boolean hasNext() { return iterator.hasNext(); } @Override public ModifiableRealmIdentity next() { return wrap(iterator.next()); } }; } private ModifiableRealmIdentity wrap(final ModifiableRealmIdentity modifiable) { return new ModifiableRealmIdentity() { @Override public void delete() throws RealmUnavailableException { executeAndInvalidate(modifiable -> { modifiable.delete(); }); } @Override public void create() throws RealmUnavailableException { modifiable.create(); } @Override public void setCredentials(Collection credentials) throws RealmUnavailableException { executeAndInvalidate(modifiable -> { modifiable.setCredentials(credentials); }); } @Override public void setAttributes(Attributes attributes) throws RealmUnavailableException { executeAndInvalidate(modifiable -> { modifiable.setAttributes(attributes); }); } @Override public SupportLevel getCredentialAcquireSupport(Class credentialType, String algorithmName, final AlgorithmParameterSpec parameterSpec) throws RealmUnavailableException { return modifiable.getCredentialAcquireSupport(credentialType, algorithmName, parameterSpec); } @Override public C getCredential(Class credentialType) throws RealmUnavailableException { return modifiable.getCredential(credentialType); } @Override public SupportLevel getEvidenceVerifySupport(Class evidenceType, String algorithmName) throws RealmUnavailableException { return modifiable.getEvidenceVerifySupport(evidenceType, algorithmName); } @Override public boolean verifyEvidence(Evidence evidence) throws RealmUnavailableException { return modifiable.verifyEvidence(evidence); } @Override public boolean exists() throws RealmUnavailableException { return modifiable.exists(); } @Override public void updateCredential(Credential credential) throws RealmUnavailableException { executeAndInvalidate(modifiable -> { modifiable.updateCredential(credential); }); } @Override public Principal getRealmIdentityPrincipal() { return modifiable.getRealmIdentityPrincipal(); } @Override public C getCredential(Class credentialType, String algorithmName) throws RealmUnavailableException { return modifiable.getCredential(credentialType, algorithmName); } @Override public C getCredential(final Class credentialType, final String algorithmName, final AlgorithmParameterSpec parameterSpec) throws RealmUnavailableException { return modifiable.getCredential(credentialType, algorithmName, parameterSpec); } @Override public R applyToCredential(Class credentialType, Function function) throws RealmUnavailableException { return modifiable.applyToCredential(credentialType, function); } @Override public R applyToCredential(Class credentialType, String algorithmName, Function function) throws RealmUnavailableException { return modifiable.applyToCredential(credentialType, algorithmName, function); } @Override public R applyToCredential(final Class credentialType, final String algorithmName, final AlgorithmParameterSpec parameterSpec, final Function function) throws RealmUnavailableException { return modifiable.applyToCredential(credentialType, algorithmName, parameterSpec, function); } @Override public void dispose() { modifiable.dispose(); } @Override public AuthorizationIdentity getAuthorizationIdentity() throws RealmUnavailableException { return modifiable.getAuthorizationIdentity(); } @Override public Attributes getAttributes() throws RealmUnavailableException { return modifiable.getAttributes(); } private void executeAndInvalidate(ExceptionConsumer operation) throws RealmUnavailableException { try { operation.accept(modifiable); } catch (RealmUnavailableException rue) { throw rue; } finally { removeFromCache(modifiable.getRealmIdentityPrincipal()); } } }; } private ModifiableSecurityRealm getModifiableSecurityRealm() { return (ModifiableSecurityRealm) getCacheableRealm(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy