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