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");
+                }
+
+            }
+        }
+    }
+
+}