/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- * * The contents of this file are subject to the Netscape Public * License Version 1.1 (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.mozilla.org/NPL/ * * Software distributed under the License is distributed on an "AS * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is mozilla.org code. * * The Initial Developer of the Original Code is Netscape * Communications Corporation. Portions created by Netscape are * Copyright (C) 1999 Netscape Communications Corporation. All * Rights Reserved. * * Contributor(s): */ package netscape.ldap.beans; import netscape.ldap.*; import netscape.ldap.beans.LDAPBasePropertySupport; import java.io.Serializable; import java.awt.event.*; /** * Invisible Bean that just authenticates a user with a Directory * Server and returns Y or N. It takes a host and port, and then either * a full distinguished name and password, an RDN and directory base, or * a cn value and directory base. *

* Optionally, a client can register as * a PropertyChangeListener and will be notified when an authentication * completes. *

* The Bean can be used from JavaScript, as in the following example * where the parameters are taken from HTML text fields in an HTML * form called "input": *
 * 
 * <SCRIPT LANGUAGE="JavaScript">
 * function checkAuthentication() {
 *     auth = new Packages.netscape.ldap.beans.LDAPSimpleAuth();
 *     auth.setHost( document.input.host.value );
 *     auth.setPort( parseInt(document.input.port.value) );
 *     auth.setAuthDN( document.input.username.value );
 *     auth.setAuthPassword( document.input.password.value );
 *     result = auth.authenticate();
 *     alert( "The response is: " + result );
 * }
 * </SCRIPT>
 * 
 *
*/ public class LDAPSimpleAuth extends LDAPBasePropertySupport implements Serializable { /** * Constructor with no parameters */ public LDAPSimpleAuth() {} /** * Constructor with host and port initializers * @param theHost host string * @param thePort port number */ public LDAPSimpleAuth( String theHost, int thePort ) { setHost( theHost ); setPort( thePort ); } /** * Constructor with all required authentication parameters * @param theHost host string * @param thePort port number * @param dn fully qualified distinguished name to authenticate * @param password password for authenticating the dn */ public LDAPSimpleAuth( String theHost, int thePort, String dn, String password ) { setHost( theHost ); setPort( thePort ); setAuthDN( dn ); setAuthPassword( password ); } private void notifyResult( String newResult ) { firePropertyChange( "result", result, newResult ); result = newResult; } /** * Connect to LDAP server using parameters specified in * constructor and/or by setting properties and attempt to * authenticate. * @return "Y" on successful authentication, "N" otherwise */ public String authenticate() { LDAPConnection m_ldc = null; String result = "N"; try { m_ldc = new LDAPConnection(); System.out.println("Connecting to " + getHost() + " " + getPort()); connect( m_ldc, getHost(), getPort()); } catch (Exception e) { System.out.println( "Failed to connect to " + getHost() + ": " + e.toString() ); } if ( m_ldc.isConnected() ) { System.out.println( "Authenticating " + getAuthDN() ); try { m_ldc.authenticate( getAuthDN(), getAuthPassword() ); result = "Y"; } catch (Exception e) { System.out.println( "Failed to authenticate to " + getHost() + ": " + e.toString() ); } } try { if ( (m_ldc != null) && m_ldc.isConnected() ) m_ldc.disconnect(); } catch ( Exception e ) { } notifyResult( result ); return result; } /** * Connect to LDAP server using parameters specified in * constructor and/or by setting properties and attempt to * authenticate. * @param dn fully qualified distinguished name to authenticate * @param password password for authenticating the dn * @return "Y" on successful authentication, "N" otherwise */ public String authenticate( String dn, String password ) { setAuthDN( dn ); setAuthPassword( password ); return authenticate(); } public void authenticate( ActionEvent x) { authenticate(); } /** * The main body if we run it as stand-alone application. * @param args list of arguments */ public static void main(String args[]) { if (args.length != 4) { System.out.println( " LDAPSimpleAuth " + "host port DN password" ); System.exit(1); } LDAPSimpleAuth app = new LDAPSimpleAuth(); app.setHost( args[0] ); app.setPort( java.lang.Integer.parseInt( args[1] ) ); app.setAuthDN( args[2] ); app.setAuthPassword( args[3] ); String response = app.authenticate(); System.out.println( "Response: " + response ); System.exit(0); } /* * Variables */ transient private String result = new String(""); }