X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=security%2Fplugins%2Forg.argeo.security.ui.rcp%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fsecurity%2Fui%2Frcp%2FSecureApplicationActivator.java;h=d5617d773c8c647509754e11ef393f0a75ebd361;hb=6d8b1042b023fa1e4adeb649ceefb23f8a9cea86;hp=53d2a7570d069f06698444d71c52035bfff89953;hpb=0aa1c816931dfce599fb6855eb216d743c1583b2;p=lgpl%2Fargeo-commons.git diff --git a/security/plugins/org.argeo.security.ui.rcp/src/main/java/org/argeo/security/ui/rcp/SecureApplicationActivator.java b/security/plugins/org.argeo.security.ui.rcp/src/main/java/org/argeo/security/ui/rcp/SecureApplicationActivator.java index 53d2a7570..d5617d773 100644 --- a/security/plugins/org.argeo.security.ui.rcp/src/main/java/org/argeo/security/ui/rcp/SecureApplicationActivator.java +++ b/security/plugins/org.argeo.security.ui.rcp/src/main/java/org/argeo/security/ui/rcp/SecureApplicationActivator.java @@ -1,29 +1,51 @@ package org.argeo.security.ui.rcp; +import java.io.IOException; import java.net.URL; +import javax.security.auth.callback.Callback; +import javax.security.auth.callback.CallbackHandler; +import javax.security.auth.callback.UnsupportedCallbackException; + +import org.argeo.security.ui.dialogs.DefaultLoginDialog; import org.eclipse.equinox.security.auth.ILoginContext; import org.eclipse.equinox.security.auth.LoginContextFactory; import org.osgi.framework.BundleActivator; import org.osgi.framework.BundleContext; +import org.osgi.framework.ServiceReference; +import org.osgi.framework.ServiceRegistration; +/** Activator able to create {@link ILoginContext} */ public class SecureApplicationActivator implements BundleActivator { - public final static String CONTEXT_SPRING = "SPRING"; + public final static String CONTEXT_NIX = "NIX"; + public final static String CONTEXT_WINDOWS = "WINDOWS"; private static final String JAAS_CONFIG_FILE = "/META-INF/jaas_default.txt"; - private static ILoginContext loginContext = null; + private static BundleContext bundleContext; + private ServiceRegistration callbackHandlerRegistration; public void start(BundleContext bundleContext) throws Exception { - URL configUrl = bundleContext.getBundle().getEntry(JAAS_CONFIG_FILE); - loginContext = LoginContextFactory.createContext(CONTEXT_SPRING, - configUrl); + SecureApplicationActivator.bundleContext = bundleContext; + + CallbackHandler callbackHandler = new CallbackHandler() { + + public void handle(Callback[] callbacks) throws IOException, + UnsupportedCallbackException { + DefaultLoginDialog dialog = new DefaultLoginDialog(); + dialog.handle(callbacks); + } + }; + callbackHandlerRegistration = bundleContext.registerService( + CallbackHandler.class.getName(), callbackHandler, null); } public void stop(BundleContext context) throws Exception { + callbackHandlerRegistration.unregister(); } - static ILoginContext getLoginContext() { - return loginContext; + static ILoginContext createLoginContext(String context) { + URL configUrl = bundleContext.getBundle().getEntry(JAAS_CONFIG_FILE); + return LoginContextFactory.createContext(context, configUrl); } }