You are viewing a plain text version of this content. The canonical link for it is here.
Posted to rampart-dev@ws.apache.org by ru...@apache.org on 2008/01/04 09:47:50 UTC
svn commit: r608774 - in
/webservices/rampart/trunk/java/modules/rampart-extensions: ./
jpam-callback-handler/ jpam-callback-handler/src/
jpam-callback-handler/src/main/ jpam-callback-handler/src/main/java/
jpam-callback-handler/src/main/java/org/ jpam...
Author: ruchithf
Date: Fri Jan 4 00:47:49 2008
New Revision: 608774
URL: http://svn.apache.org/viewvc?rev=608774&view=rev
Log:
Added an callback handler to authenticate users against *nix PAM using JPAM
Added:
webservices/rampart/trunk/java/modules/rampart-extensions/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/rampart/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/rampart/extensions/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/rampart/extensions/jpam/
webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/rampart/extensions/jpam/JPAMCallbackHandler.java
Added: webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/rampart/extensions/jpam/JPAMCallbackHandler.java
URL: http://svn.apache.org/viewvc/webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/rampart/extensions/jpam/JPAMCallbackHandler.java?rev=608774&view=auto
==============================================================================
--- webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/rampart/extensions/jpam/JPAMCallbackHandler.java (added)
+++ webservices/rampart/trunk/java/modules/rampart-extensions/jpam-callback-handler/src/main/java/org/apache/rampart/extensions/jpam/JPAMCallbackHandler.java Fri Jan 4 00:47:49 2008
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2004,2005 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.
+ */
+
+import org.apache.ws.security.WSPasswordCallback;
+
+import javax.security.auth.callback.Callback;
+import javax.security.auth.callback.CallbackHandler;
+import javax.security.auth.callback.UnsupportedCallbackException;
+
+import java.io.IOException;
+
+import net.sf.jpam.Pam;
+import net.sf.jpam.PamReturnValue;
+
+public class JPAMCallbackHandler implements CallbackHandler {
+
+ public void handle(Callback[] callbacks) throws IOException,
+ UnsupportedCallbackException {
+ for (int i = 0; i < callbacks.length; i++) {
+ // When the server side need to authenticate the user
+ WSPasswordCallback pwcb = (WSPasswordCallback) callbacks[i];
+ if (pwcb.getUsage() == WSPasswordCallback.USERNAME_TOKEN_UNKNOWN) {
+ Pam pam = new Pam();
+ PamReturnValue ret = pam.authenticate(pwcb.getIdentifer(), pwcb
+ .getPassword());
+ if (ret.equals(PamReturnValue.PAM_SUCCESS)) {
+ return;
+ } else {
+ throw new IOException("check failed");
+ }
+
+ }
+ }
+ }
+
+}