xref: /netbsd-src/external/bsd/openldap/dist/libraries/libldap/sbind.c (revision 549b59ed3ccf0d36d3097190a0db27b770f3a839)
1*549b59edSchristos /*	$NetBSD: sbind.c,v 1.3 2021/08/14 16:14:56 christos Exp $	*/
24e6df137Slukem 
3d11b170bStron /* $OpenLDAP$ */
42de962bdSlukem /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
52de962bdSlukem  *
6*549b59edSchristos  * Copyright 1998-2021 The OpenLDAP Foundation.
72de962bdSlukem  * All rights reserved.
82de962bdSlukem  *
92de962bdSlukem  * Redistribution and use in source and binary forms, with or without
102de962bdSlukem  * modification, are permitted only as authorized by the OpenLDAP
112de962bdSlukem  * Public License.
122de962bdSlukem  *
132de962bdSlukem  * A copy of this license is available in the file LICENSE in the
142de962bdSlukem  * top-level directory of the distribution or, alternatively, at
152de962bdSlukem  * <http://www.OpenLDAP.org/license.html>.
162de962bdSlukem  */
172de962bdSlukem /* Portions Copyright (c) 1993 Regents of the University of Michigan.
182de962bdSlukem  * All rights reserved.
192de962bdSlukem  */
202de962bdSlukem 
212de962bdSlukem /*
222de962bdSlukem  *	BindRequest ::= SEQUENCE {
232de962bdSlukem  *		version		INTEGER,
242de962bdSlukem  *		name		DistinguishedName,	 -- who
252de962bdSlukem  *		authentication	CHOICE {
262de962bdSlukem  *			simple		[0] OCTET STRING -- passwd
272de962bdSlukem  *			krbv42ldap	[1] OCTET STRING  -- OBSOLETE
282de962bdSlukem  *			krbv42dsa	[2] OCTET STRING  -- OBSOLETE
292de962bdSlukem  *			sasl		[3] SaslCredentials	-- LDAPv3
302de962bdSlukem  *		}
312de962bdSlukem  *	}
322de962bdSlukem  *
332de962bdSlukem  *	BindResponse ::= SEQUENCE {
342de962bdSlukem  *		COMPONENTS OF LDAPResult,
352de962bdSlukem  *		serverSaslCreds		OCTET STRING OPTIONAL -- LDAPv3
362de962bdSlukem  *	}
372de962bdSlukem  *
382de962bdSlukem  */
392de962bdSlukem 
40376af7d7Schristos #include <sys/cdefs.h>
41*549b59edSchristos __RCSID("$NetBSD: sbind.c,v 1.3 2021/08/14 16:14:56 christos Exp $");
42376af7d7Schristos 
432de962bdSlukem #include "portable.h"
442de962bdSlukem 
452de962bdSlukem #include <stdio.h>
462de962bdSlukem 
472de962bdSlukem #include <ac/socket.h>
482de962bdSlukem #include <ac/string.h>
492de962bdSlukem #include <ac/time.h>
502de962bdSlukem 
512de962bdSlukem #include "ldap-int.h"
522de962bdSlukem 
532de962bdSlukem /*
542de962bdSlukem  * ldap_simple_bind - bind to the ldap server (and X.500).  The dn and
552de962bdSlukem  * password of the entry to which to bind are supplied.  The message id
562de962bdSlukem  * of the request initiated is returned.
572de962bdSlukem  *
582de962bdSlukem  * Example:
592de962bdSlukem  *	ldap_simple_bind( ld, "cn=manager, o=university of michigan, c=us",
602de962bdSlukem  *	    "secret" )
612de962bdSlukem  */
622de962bdSlukem 
632de962bdSlukem int
ldap_simple_bind(LDAP * ld,LDAP_CONST char * dn,LDAP_CONST char * passwd)642de962bdSlukem ldap_simple_bind(
652de962bdSlukem 	LDAP *ld,
662de962bdSlukem 	LDAP_CONST char *dn,
672de962bdSlukem 	LDAP_CONST char *passwd )
682de962bdSlukem {
692de962bdSlukem 	int rc;
702de962bdSlukem 	int msgid;
712de962bdSlukem 	struct berval cred;
722de962bdSlukem 
73*549b59edSchristos 	Debug0( LDAP_DEBUG_TRACE, "ldap_simple_bind\n" );
742de962bdSlukem 
752de962bdSlukem 	assert( ld != NULL );
762de962bdSlukem 	assert( LDAP_VALID( ld ) );
772de962bdSlukem 
782de962bdSlukem 	if ( passwd != NULL ) {
792de962bdSlukem 		cred.bv_val = (char *) passwd;
802de962bdSlukem 		cred.bv_len = strlen( passwd );
812de962bdSlukem 	} else {
822de962bdSlukem 		cred.bv_val = "";
832de962bdSlukem 		cred.bv_len = 0;
842de962bdSlukem 	}
852de962bdSlukem 
862de962bdSlukem 	rc = ldap_sasl_bind( ld, dn, LDAP_SASL_SIMPLE, &cred,
872de962bdSlukem 		NULL, NULL, &msgid );
882de962bdSlukem 
892de962bdSlukem 	return rc == LDAP_SUCCESS ? msgid : -1;
902de962bdSlukem }
912de962bdSlukem 
922de962bdSlukem /*
932de962bdSlukem  * ldap_simple_bind - bind to the ldap server (and X.500) using simple
942de962bdSlukem  * authentication.  The dn and password of the entry to which to bind are
952de962bdSlukem  * supplied.  LDAP_SUCCESS is returned upon success, the ldap error code
962de962bdSlukem  * otherwise.
972de962bdSlukem  *
982de962bdSlukem  * Example:
992de962bdSlukem  *	ldap_simple_bind_s( ld, "cn=manager, o=university of michigan, c=us",
1002de962bdSlukem  *	    "secret" )
1012de962bdSlukem  */
1022de962bdSlukem 
1032de962bdSlukem int
ldap_simple_bind_s(LDAP * ld,LDAP_CONST char * dn,LDAP_CONST char * passwd)1042de962bdSlukem ldap_simple_bind_s( LDAP *ld, LDAP_CONST char *dn, LDAP_CONST char *passwd )
1052de962bdSlukem {
1062de962bdSlukem 	struct berval cred;
1072de962bdSlukem 
108*549b59edSchristos 	Debug0( LDAP_DEBUG_TRACE, "ldap_simple_bind_s\n" );
1092de962bdSlukem 
1102de962bdSlukem 	if ( passwd != NULL ) {
1112de962bdSlukem 		cred.bv_val = (char *) passwd;
1122de962bdSlukem 		cred.bv_len = strlen( passwd );
1132de962bdSlukem 	} else {
1142de962bdSlukem 		cred.bv_val = "";
1152de962bdSlukem 		cred.bv_len = 0;
1162de962bdSlukem 	}
1172de962bdSlukem 
1182de962bdSlukem 	return ldap_sasl_bind_s( ld, dn, LDAP_SASL_SIMPLE, &cred,
1192de962bdSlukem 		NULL, NULL, NULL );
1202de962bdSlukem }
121