X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;ds=sidebyside;f=security%2Fruntime%2Forg.argeo.security.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fsecurity%2Fcore%2FAuthenticationProvidersRegister.java;fp=security%2Fruntime%2Forg.argeo.security.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fsecurity%2Fcore%2FAuthenticationProvidersRegister.java;h=bd14659c82cd1d8ac405316273b1eee0806f1c89;hb=2745f0c8c57d9468855179d56f858fb2448f779c;hp=0000000000000000000000000000000000000000;hpb=113e31e7c85bfad76d3c2ce6c20d63557a6fc02a;p=lgpl%2Fargeo-commons.git diff --git a/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/core/AuthenticationProvidersRegister.java b/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/core/AuthenticationProvidersRegister.java new file mode 100644 index 000000000..bd14659c8 --- /dev/null +++ b/security/runtime/org.argeo.security.core/src/main/java/org/argeo/security/core/AuthenticationProvidersRegister.java @@ -0,0 +1,48 @@ +package org.argeo.security.core; + +import java.util.ArrayList; +import java.util.List; +import java.util.Map; + +import org.apache.commons.logging.Log; +import org.apache.commons.logging.LogFactory; +import org.springframework.beans.factory.InitializingBean; + +/** + * Maintains a list of authentication providers injected in to a provider + * manager, in order to avoid issues with OSGi services and use packages. + */ +public class AuthenticationProvidersRegister implements InitializingBean { + private Log log = LogFactory.getLog(AuthenticationProvidersRegister.class); + + private List providers = new ArrayList(); + private List defaultProviders = new ArrayList(); + + public void register(Object authenticationProvider, + Map parameters) { + providers.add(authenticationProvider); + if (log.isDebugEnabled()) + log.debug("Registered authentication provider " + parameters); + } + + public void unregister(Object authenticationProvider, + Map parameters) { + providers.remove(authenticationProvider); + if (log.isDebugEnabled()) + log.debug("Unregistered authentication provider " + parameters); + } + + public List getProviders() { + return providers; + } + + public void setDefaultProviders( + List defaultProviders) { + this.defaultProviders = defaultProviders; + } + + public void afterPropertiesSet() throws Exception { + providers.addAll(defaultProviders); + } + +}