123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- /* $OpenLDAP$ */
- /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
- *
- * Copyright 1998-2022 The OpenLDAP Foundation.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted only as authorized by the OpenLDAP
- * Public License.
- *
- * A copy of this license is available in the file LICENSE in the
- * top-level directory of the distribution or, alternatively, at
- * <http://www.OpenLDAP.org/license.html>.
- */
- /* ACKNOWLEDGEMENTS:
- * This program was originally developed by Kurt D. Zeilenga for inclusion in
- * OpenLDAP Software.
- */
- #include "portable.h"
- #include <stdio.h>
- #include <ac/stdlib.h>
- #include <ac/string.h>
- #include <ac/time.h>
- #include "ldap-int.h"
- /*
- * LDAP Password Modify (Extended) Operation (RFC 3062)
- */
- int ldap_parse_passwd(
- LDAP *ld,
- LDAPMessage *res,
- struct berval *newpasswd )
- {
- int rc;
- struct berval *retdata = NULL;
- assert( ld != NULL );
- assert( LDAP_VALID( ld ) );
- assert( res != NULL );
- assert( newpasswd != NULL );
- newpasswd->bv_val = NULL;
- newpasswd->bv_len = 0;
- rc = ldap_parse_extended_result( ld, res, NULL, &retdata, 0 );
- if ( rc != LDAP_SUCCESS ) {
- return rc;
- }
- if ( retdata != NULL ) {
- ber_tag_t tag;
- BerElement *ber = ber_init( retdata );
- if ( ber == NULL ) {
- rc = ld->ld_errno = LDAP_NO_MEMORY;
- goto done;
- }
- /* we should check the tag */
- tag = ber_scanf( ber, "{o}", newpasswd );
- ber_free( ber, 1 );
- if ( tag == LBER_ERROR ) {
- rc = ld->ld_errno = LDAP_DECODING_ERROR;
- }
- }
- done:;
- ber_bvfree( retdata );
- return rc;
- }
- int
- ldap_passwd( LDAP *ld,
- struct berval *user,
- struct berval *oldpw,
- struct berval *newpw,
- LDAPControl **sctrls,
- LDAPControl **cctrls,
- int *msgidp )
- {
- int rc;
- struct berval bv = BER_BVNULL;
- BerElement *ber = NULL;
- assert( ld != NULL );
- assert( LDAP_VALID( ld ) );
- assert( msgidp != NULL );
- if( user != NULL || oldpw != NULL || newpw != NULL ) {
- /* build change password control */
- ber = ber_alloc_t( LBER_USE_DER );
- if( ber == NULL ) {
- ld->ld_errno = LDAP_NO_MEMORY;
- return ld->ld_errno;
- }
- ber_printf( ber, "{" /*}*/ );
- if( user != NULL ) {
- ber_printf( ber, "tO",
- LDAP_TAG_EXOP_MODIFY_PASSWD_ID, user );
- }
- if( oldpw != NULL ) {
- ber_printf( ber, "tO",
- LDAP_TAG_EXOP_MODIFY_PASSWD_OLD, oldpw );
- }
- if( newpw != NULL ) {
- ber_printf( ber, "tO",
- LDAP_TAG_EXOP_MODIFY_PASSWD_NEW, newpw );
- }
- ber_printf( ber, /*{*/ "N}" );
- rc = ber_flatten2( ber, &bv, 0 );
- if( rc < 0 ) {
- ld->ld_errno = LDAP_ENCODING_ERROR;
- return ld->ld_errno;
- }
- }
-
- rc = ldap_extended_operation( ld, LDAP_EXOP_MODIFY_PASSWD,
- bv.bv_val ? &bv : NULL, sctrls, cctrls, msgidp );
- ber_free( ber, 1 );
- return rc;
- }
- int
- ldap_passwd_s(
- LDAP *ld,
- struct berval *user,
- struct berval *oldpw,
- struct berval *newpw,
- struct berval *newpasswd,
- LDAPControl **sctrls,
- LDAPControl **cctrls )
- {
- int rc;
- int msgid;
- LDAPMessage *res;
- rc = ldap_passwd( ld, user, oldpw, newpw, sctrls, cctrls, &msgid );
- if ( rc != LDAP_SUCCESS ) {
- return rc;
- }
- if ( ldap_result( ld, msgid, LDAP_MSG_ALL, (struct timeval *) NULL, &res ) == -1 || !res ) {
- return ld->ld_errno;
- }
- rc = ldap_parse_passwd( ld, res, newpasswd );
- if( rc != LDAP_SUCCESS ) {
- ldap_msgfree( res );
- return rc;
- }
- return( ldap_result2error( ld, res, 1 ) );
- }
|