You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@juddi.apache.org by tc...@apache.org on 2010/03/04 03:28:27 UTC

svn commit: r918820 - in /webservices/juddi/trunk/docs/examples/auth/src/main/java/org/apache/juddi/v3/auth: JBossAuthenticator.java jboss/ jboss/JBossAuthenticator.java

Author: tcunning
Date: Thu Mar  4 02:28:27 2010
New Revision: 918820

URL: http://svn.apache.org/viewvc?rev=918820&view=rev
Log:
JUDDI-371
Change the package name of JBossAuthenticator so that it doesn't collide
with signed JARs in jboss.

Added:
    webservices/juddi/trunk/docs/examples/auth/src/main/java/org/apache/juddi/v3/auth/jboss/
    webservices/juddi/trunk/docs/examples/auth/src/main/java/org/apache/juddi/v3/auth/jboss/JBossAuthenticator.java
Removed:
    webservices/juddi/trunk/docs/examples/auth/src/main/java/org/apache/juddi/v3/auth/JBossAuthenticator.java

Added: webservices/juddi/trunk/docs/examples/auth/src/main/java/org/apache/juddi/v3/auth/jboss/JBossAuthenticator.java
URL: http://svn.apache.org/viewvc/webservices/juddi/trunk/docs/examples/auth/src/main/java/org/apache/juddi/v3/auth/jboss/JBossAuthenticator.java?rev=918820&view=auto
==============================================================================
--- webservices/juddi/trunk/docs/examples/auth/src/main/java/org/apache/juddi/v3/auth/jboss/JBossAuthenticator.java (added)
+++ webservices/juddi/trunk/docs/examples/auth/src/main/java/org/apache/juddi/v3/auth/jboss/JBossAuthenticator.java Thu Mar  4 02:28:27 2010
@@ -0,0 +1,153 @@
+/*
+ * Copyright 2001-2009 The Apache Software Foundation.
+ * 
+ * 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.apache.juddi.v3.auth.jboss;
+
+import org.apache.juddi.v3.auth.Authenticator;
+
+import org.apache.commons.configuration.ConfigurationException;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+
+import org.apache.juddi.model.AuthToken;
+import org.apache.juddi.model.Publisher;
+import org.apache.juddi.model.UddiEntityPublisher;
+import org.apache.juddi.v3.error.AuthTokenRequiredException;
+import org.apache.juddi.v3.error.AuthenticationException;
+import org.apache.juddi.v3.error.ErrorMessage;
+import org.apache.juddi.v3.error.UnknownUserException;
+import org.apache.juddi.config.AppConfig;
+import org.apache.juddi.config.PersistenceManager;
+import org.apache.juddi.config.Property;
+import org.apache.log4j.Logger;
+import org.jboss.security.AuthenticationManager;
+
+import javax.naming.Context;
+import javax.naming.InitialContext;
+import javax.naming.NamingException;
+import javax.persistence.EntityManager;
+import javax.persistence.EntityTransaction;
+
+import java.security.Principal;
+
+/**
+ * This is a implementation of jUDDI's Authenticator interface, that uses the
+ * JBoss authentication manager.
+ * 
+ * Usage:
+ * 
+ * To use this class you must add the following properties to the
+ * juddiv3.properties file:
+ * 
+ * # The JBoss Authenticator
+ * juddi.authenticator=org.apache.juddi.auth.JBossAuthenticator
+ * 
+ * # The security-domain, defined in $JBOSS/default/conf/login-config.xml
+ * juddi.securityDomain=java:/jaas/other
+ * 
+ * @author Antoni Reus (areus@ibit.org)
+ * @author Tom Cunningham (tcunning@apache.org)
+ */
+public class JBossAuthenticator implements Authenticator {
+	// private reference to the logger
+	private Logger logger = Logger.getLogger(this.getClass());
+
+	// JBoss authentication manager
+	AuthenticationManager authManager;
+
+	public JBossAuthenticator() throws NamingException, ConfigurationException {
+		init();
+	}
+
+	/**
+     *
+     */
+	public String authenticate(final String userID, final String credential)
+			throws AuthenticationException {
+		if (userID == null) {
+			throw new UnknownUserException(new ErrorMessage("errors.auth.InvalidUserId", userID));
+		}
+
+		EntityManager em = PersistenceManager.getEntityManager();
+		EntityTransaction tx = em.getTransaction();
+		try {
+			// Create a principal for the userID
+			Principal principal = new Principal() {
+				public String getName() {
+					return userID;
+				}
+			};
+	
+			if (!authManager.isValid(principal, credential)) {
+				throw new UnknownUserException(new ErrorMessage("errors.auth.InvalidCredentials"));
+			} else {
+				tx.begin();
+				Publisher publisher = em.find(Publisher.class, userID);
+				if (publisher == null) {
+					publisher = new Publisher();
+					publisher.setAuthorizedName(userID);
+					publisher.setIsAdmin("false");
+					publisher.setIsEnabled("true");
+					publisher.setMaxBindingsPerService(199);
+					publisher.setMaxBusinesses(100);
+					publisher.setMaxServicesPerBusiness(100);
+					publisher.setMaxTmodels(100);
+					publisher.setPublisherName("Unknown");
+					em.persist(publisher);
+					tx.commit();
+				}
+			}
+		} finally {
+			if (tx.isActive()) {
+				tx.rollback();
+			}
+			em.close();
+		}
+		return userID;
+	}
+
+	private void init() throws NamingException, ConfigurationException {
+		String securityDomain = AppConfig.getConfiguration().getString(
+				Property.JUDDI_SECURITY_DOMAIN,
+				Property.DEFAULT_SECURITY_DOMAIN);
+
+		// lookup the authentication manager.
+		Context ctx = new InitialContext();
+		authManager = (AuthenticationManager) ctx.lookup(securityDomain);
+		ctx.close();
+	}
+	
+	public UddiEntityPublisher identify(String authInfo, String authorizedName) throws AuthenticationException {
+		EntityManager em = PersistenceManager.getEntityManager();
+		EntityTransaction tx = em.getTransaction();
+		Publisher publisher = null;
+		try {
+			tx.begin();
+			publisher = em.find(Publisher.class, authorizedName);
+			if (publisher == null)
+				throw new UnknownUserException(new ErrorMessage("errors.auth.NoPublisher", authorizedName));
+			
+			AuthToken at = em.find(AuthToken.class, authInfo);
+			if (at == null) 
+				throw new AuthTokenRequiredException(new ErrorMessage("E_authTokenRequired", authInfo));				
+		} finally {
+			if (tx.isActive()) {
+				tx.rollback();
+			}
+			em.close();
+		}
+		return publisher;
+	}
+}



---------------------------------------------------------------------
To unsubscribe, e-mail: juddi-cvs-unsubscribe@ws.apache.org
For additional commands, e-mail: juddi-cvs-help@ws.apache.org