/* $OpenLDAP$ */
/* This work is part of OpenLDAP Software .
*
* Copyright 2004 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
* .
*/
/* ACKNOWLEDGEMENTS:
* This program was orignally developed by Kurt D. Zeilenga for inclusion in
* OpenLDAP Software.
*/
#include "portable.h"
#include
#include
#include
#include "ldap-int.h"
#ifdef LDAP_EXOP_GROUPING_CREATE
int ldap_grouping_create(
LDAP *ld,
LDAP_CONST char *grpoid,
struct berval *grpdata,
LDAPControl **sctrls,
LDAPControl **cctrls,
int *msgidp )
{
int rc;
BerElement *ber = NULL;
struct berval bv = {0, NULL};
#ifdef NEW_LOGGING
LDAP_LOG ( OPERATION, ENTRY, "ldap_grouping_create\n", 0,0,0 );
#else
Debug( LDAP_DEBUG_TRACE, "ldap_grouping_create\n", 0, 0, 0 );
#endif
assert( ld != NULL );
assert( LDAP_VALID( ld ) );
assert( grpoid != NULL || *grpoid == '\0' );
assert( msgidp != NULL );
/* build the create grouping exop */
ber = ber_alloc_t( LBER_USE_DER );
if( ber == NULL ) {
ld->ld_errno = LDAP_NO_MEMORY;
return( ld->ld_errno );
}
if ( grpdata != NULL ) {
ber_printf( ber, "{sON}", grpoid, grpdata );
} else {
ber_printf( ber, "{sN}", grpoid );
}
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_GROUPING_CREATE,
&bv, sctrls, cctrls, msgidp );
ber_free( ber, 1 );
return rc;
}
int ldap_grouping_create_s(
LDAP *ld,
LDAP_CONST char *grpoid,
struct berval *grpdata,
LDAPControl **sctrls,
LDAPControl **cctrls,
struct berval **retgrpcookiep,
struct berval **retgrpdatap )
{
int rc;
int msgid;
LDAPMessage *res;
#ifdef NEW_LOGGING
LDAP_LOG ( OPERATION, ENTRY, "ldap_grouping_create_s\n", 0,0,0 );
#else
Debug( LDAP_DEBUG_TRACE, "ldap_grouping_create_s\n", 0, 0, 0 );
#endif
assert( ld != NULL );
assert( LDAP_VALID( ld ) );
assert( grpoid != NULL || *grpoid == '\0' );
rc = ldap_grouping_create( ld, grpoid, grpdata,
sctrls, cctrls, &msgid );
if ( rc != LDAP_SUCCESS ) {
return rc;
}
if ( ldap_result( ld, msgid, 1, (struct timeval *) NULL, &res ) == -1 ) {
return ld->ld_errno;
}
if ( retgrpcookiep != NULL ) *retgrpcookiep = NULL;
if ( retgrpdatap != NULL ) *retgrpdatap = NULL;
#if 0
rc = ldap_parse_extended_result( ld, res, retoidp, retdatap, 0 );
#else
rc = LDAP_NOT_SUPPORTED;
#endif
if( rc != LDAP_SUCCESS ) {
ldap_msgfree( res );
return rc;
}
return( ldap_result2error( ld, res, 1 ) );
}
int ldap_grouping_end(
LDAP *ld,
LDAP_CONST char *grpoid,
struct berval *grpdata,
LDAPControl **sctrls,
LDAPControl **cctrls,
int *msgidp )
{
}
int ldap_grouping_end_s(
LDAP *ld,
LDAP_CONST char *grpoid,
struct berval *grpdata,
LDAPControl **sctrls,
LDAPControl **cctrls,
struct berval **retgrpdatap )
{
}
#endif