2003-11-30 02:03:43 +08:00
|
|
|
/* $OpenLDAP$ */
|
2003-11-27 00:05:06 +08:00
|
|
|
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
|
|
|
|
*
|
2005-01-02 04:49:32 +08:00
|
|
|
* Copyright 2002-2005 The OpenLDAP Foundation.
|
2003-11-27 00:05:06 +08:00
|
|
|
* Portions Copyright 1997,2002-2003 IBM Corporation.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
2003-11-20 13:11:37 +08:00
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted only as authorized by the OpenLDAP
|
2003-11-27 00:05:06 +08:00
|
|
|
* 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 work was initially developed by IBM Corporation for use in
|
|
|
|
* IBM products and subsequently ported to OpenLDAP Software by
|
|
|
|
* Steve Omrani. Additional significant contributors include:
|
|
|
|
* Luke Howard
|
2002-12-08 01:19:29 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "portable.h"
|
|
|
|
#include <slap.h>
|
|
|
|
#include <slapi.h>
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
#ifdef LDAP_SLAPI
|
|
|
|
|
|
|
|
/* some parameters require a valid connection and operation */
|
|
|
|
#define PBLOCK_LOCK_CONN( _pb ) do { \
|
|
|
|
ldap_pvt_thread_mutex_lock( &(_pb)->pconn->c_mutex ); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define PBLOCK_UNLOCK_CONN( _pb ) do { \
|
|
|
|
ldap_pvt_thread_mutex_unlock( &(_pb)->pconn->c_mutex ); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
/* some parameters are only settable for internal operations */
|
|
|
|
#define PBLOCK_VALIDATE_IS_INTOP( _pb ) do { if ( (_pb)->internal_op == 0 ) break; } while ( 0 )
|
|
|
|
|
2005-02-20 10:13:14 +08:00
|
|
|
static slapi_pblock_class_t
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_get_param_class( int param )
|
2002-12-08 01:19:29 +08:00
|
|
|
{
|
|
|
|
switch ( param ) {
|
2005-02-20 10:13:14 +08:00
|
|
|
case SLAPI_PLUGIN_TYPE:
|
|
|
|
case SLAPI_PLUGIN_ARGC:
|
|
|
|
case SLAPI_PLUGIN_VERSION:
|
|
|
|
case SLAPI_PLUGIN_OPRETURN:
|
|
|
|
case SLAPI_PLUGIN_INTOP_RESULT:
|
|
|
|
case SLAPI_CONFIG_LINENO:
|
|
|
|
case SLAPI_CONFIG_ARGC:
|
|
|
|
case SLAPI_BIND_METHOD:
|
|
|
|
case SLAPI_MODRDN_DELOLDRDN:
|
|
|
|
case SLAPI_SEARCH_SCOPE:
|
|
|
|
case SLAPI_SEARCH_DEREF:
|
|
|
|
case SLAPI_SEARCH_SIZELIMIT:
|
|
|
|
case SLAPI_SEARCH_TIMELIMIT:
|
|
|
|
case SLAPI_SEARCH_ATTRSONLY:
|
|
|
|
case SLAPI_NENTRIES:
|
|
|
|
case SLAPI_CHANGENUMBER:
|
|
|
|
case SLAPI_DBSIZE:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_REQUESTOR_ISROOT:
|
|
|
|
case SLAPI_BE_READONLY:
|
|
|
|
case SLAPI_BE_LASTMOD:
|
2005-02-20 10:13:14 +08:00
|
|
|
case SLAPI_DB2LDIF_PRINTKEY:
|
|
|
|
case SLAPI_LDIF2DB_REMOVEDUPVALS:
|
|
|
|
case SLAPI_MANAGEDSAIT:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_REQUESTOR_ISUPDATEDN:
|
2003-01-22 22:41:51 +08:00
|
|
|
case SLAPI_X_CONN_IS_UDP:
|
2003-07-04 07:17:54 +08:00
|
|
|
case SLAPI_X_CONN_SSF:
|
2005-02-20 10:13:14 +08:00
|
|
|
case SLAPI_RESULT_CODE:
|
|
|
|
return PBLOCK_CLASS_INTEGER;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SLAPI_CONN_ID:
|
|
|
|
case SLAPI_OPERATION_ID:
|
|
|
|
case SLAPI_OPINITIATED_TIME:
|
|
|
|
case SLAPI_ABANDON_MSGID:
|
|
|
|
return PBLOCK_CLASS_LONG_INTEGER;
|
|
|
|
break;
|
|
|
|
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_PLUGIN_DESTROY_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_BIND_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_UNBIND_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_SEARCH_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_COMPARE_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_MODIFY_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_MODRDN_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_ADD_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_DELETE_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_ABANDON_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_CONFIG_FN:
|
|
|
|
case SLAPI_PLUGIN_CLOSE_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_FLUSH_FN:
|
|
|
|
case SLAPI_PLUGIN_START_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_SEQ_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_ENTRY_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_REFERRAL_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_RESULT_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_LDIF2DB_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_DB2LDIF_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_BEGIN_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_COMMIT_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_ABORT_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_ARCHIVE2DB_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_DB2ARCHIVE_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_NEXT_SEARCH_ENTRY_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_FREE_RESULT_SET_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_SIZE_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_TEST_FN:
|
|
|
|
case SLAPI_PLUGIN_DB_NO_ACL:
|
|
|
|
case SLAPI_PLUGIN_EXT_OP_FN:
|
|
|
|
case SLAPI_PLUGIN_EXT_OP_OIDLIST:
|
|
|
|
case SLAPI_PLUGIN_PRE_BIND_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_UNBIND_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_SEARCH_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_COMPARE_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_MODIFY_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_MODRDN_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_ADD_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_DELETE_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_ABANDON_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_ENTRY_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_REFERRAL_FN:
|
|
|
|
case SLAPI_PLUGIN_PRE_RESULT_FN:
|
2005-07-25 12:19:33 +08:00
|
|
|
case SLAPI_PLUGIN_INTERNAL_PRE_ADD_FN:
|
|
|
|
case SLAPI_PLUGIN_INTERNAL_PRE_MODIFY_FN:
|
|
|
|
case SLAPI_PLUGIN_INTERNAL_PRE_MODRDN_FN:
|
|
|
|
case SLAPI_PLUGIN_INTERNAL_PRE_DELETE_FN:
|
|
|
|
case SLAPI_PLUGIN_BE_PRE_ADD_FN:
|
|
|
|
case SLAPI_PLUGIN_BE_PRE_MODIFY_FN:
|
|
|
|
case SLAPI_PLUGIN_BE_PRE_MODRDN_FN:
|
|
|
|
case SLAPI_PLUGIN_BE_PRE_DELETE_FN:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_PLUGIN_POST_BIND_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_UNBIND_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_SEARCH_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_COMPARE_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_MODIFY_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_MODRDN_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_ADD_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_DELETE_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_ABANDON_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_ENTRY_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_REFERRAL_FN:
|
|
|
|
case SLAPI_PLUGIN_POST_RESULT_FN:
|
2005-07-25 12:19:33 +08:00
|
|
|
case SLAPI_PLUGIN_INTERNAL_POST_ADD_FN:
|
|
|
|
case SLAPI_PLUGIN_INTERNAL_POST_MODIFY_FN:
|
|
|
|
case SLAPI_PLUGIN_INTERNAL_POST_MODRDN_FN:
|
|
|
|
case SLAPI_PLUGIN_INTERNAL_POST_DELETE_FN:
|
|
|
|
case SLAPI_PLUGIN_BE_POST_ADD_FN:
|
|
|
|
case SLAPI_PLUGIN_BE_POST_MODIFY_FN:
|
|
|
|
case SLAPI_PLUGIN_BE_POST_MODRDN_FN:
|
|
|
|
case SLAPI_PLUGIN_BE_POST_DELETE_FN:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_PLUGIN_MR_FILTER_CREATE_FN:
|
|
|
|
case SLAPI_PLUGIN_MR_INDEXER_CREATE_FN:
|
|
|
|
case SLAPI_PLUGIN_MR_FILTER_MATCH_FN:
|
|
|
|
case SLAPI_PLUGIN_MR_FILTER_INDEX_FN:
|
|
|
|
case SLAPI_PLUGIN_MR_FILTER_RESET_FN:
|
|
|
|
case SLAPI_PLUGIN_MR_INDEX_FN:
|
2005-02-20 10:13:14 +08:00
|
|
|
case SLAPI_PLUGIN_COMPUTE_EVALUATOR_FN:
|
|
|
|
case SLAPI_PLUGIN_COMPUTE_SEARCH_REWRITER_FN:
|
|
|
|
case SLAPI_PLUGIN_ACL_ALLOW_ACCESS:
|
|
|
|
case SLAPI_X_PLUGIN_PRE_GROUP_FN:
|
|
|
|
case SLAPI_X_PLUGIN_POST_GROUP_FN:
|
|
|
|
case SLAPI_PLUGIN_AUDIT_FN:
|
|
|
|
return PBLOCK_CLASS_FUNCTION_POINTER;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SLAPI_BACKEND:
|
|
|
|
case SLAPI_CONNECTION:
|
|
|
|
case SLAPI_OPERATION:
|
|
|
|
case SLAPI_OPERATION_PARAMETERS:
|
|
|
|
case SLAPI_OPERATION_TYPE:
|
|
|
|
case SLAPI_OPERATION_AUTHTYPE:
|
|
|
|
case SLAPI_BE_MONITORDN:
|
|
|
|
case SLAPI_BE_TYPE:
|
|
|
|
case SLAPI_REQUESTOR_DN:
|
|
|
|
case SLAPI_CONN_DN:
|
|
|
|
case SLAPI_CONN_CLIENTIP:
|
|
|
|
case SLAPI_CONN_SERVERIP:
|
|
|
|
case SLAPI_CONN_AUTHTYPE:
|
|
|
|
case SLAPI_CONN_AUTHMETHOD:
|
|
|
|
case SLAPI_CONN_CERT:
|
|
|
|
case SLAPI_X_CONN_CLIENTPATH:
|
|
|
|
case SLAPI_X_CONN_SERVERPATH:
|
|
|
|
case SLAPI_X_CONN_SASL_CONTEXT:
|
2005-03-02 04:08:36 +08:00
|
|
|
case SLAPI_X_CONFIG_ARGV:
|
2005-07-19 14:48:45 +08:00
|
|
|
case SLAPI_X_INTOP_FLAGS:
|
2005-07-19 16:39:56 +08:00
|
|
|
case SLAPI_X_INTOP_RESULT_CALLBACK:
|
|
|
|
case SLAPI_X_INTOP_SEARCH_ENTRY_CALLBACK:
|
|
|
|
case SLAPI_X_INTOP_REFERRAL_ENTRY_CALLBACK:
|
|
|
|
case SLAPI_X_INTOP_CALLBACK_DATA:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_PLUGIN_MR_OID:
|
|
|
|
case SLAPI_PLUGIN_MR_TYPE:
|
|
|
|
case SLAPI_PLUGIN_MR_VALUE:
|
|
|
|
case SLAPI_PLUGIN_MR_VALUES:
|
|
|
|
case SLAPI_PLUGIN_MR_KEYS:
|
2005-02-20 10:13:14 +08:00
|
|
|
case SLAPI_PLUGIN:
|
|
|
|
case SLAPI_PLUGIN_PRIVATE:
|
|
|
|
case SLAPI_PLUGIN_ARGV:
|
|
|
|
case SLAPI_PLUGIN_OBJECT:
|
|
|
|
case SLAPI_PLUGIN_DESCRIPTION:
|
2005-07-19 14:48:45 +08:00
|
|
|
case SLAPI_PLUGIN_IDENTITY:
|
2005-02-20 10:13:14 +08:00
|
|
|
case SLAPI_PLUGIN_INTOP_SEARCH_ENTRIES:
|
|
|
|
case SLAPI_PLUGIN_INTOP_SEARCH_REFERRALS:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_PLUGIN_MR_FILTER_REUSABLE:
|
|
|
|
case SLAPI_PLUGIN_MR_QUERY_OPERATOR:
|
|
|
|
case SLAPI_PLUGIN_MR_USAGE:
|
|
|
|
case SLAPI_OP_LESS:
|
|
|
|
case SLAPI_OP_LESS_OR_EQUAL:
|
|
|
|
case SLAPI_PLUGIN_MR_USAGE_INDEX:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_FILTER_AVA:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_FILTER_SUB:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_VALUES2KEYS:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_ASSERTION2KEYS_AVA:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_ASSERTION2KEYS_SUB:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_NAMES:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_OID:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_FLAGS:
|
|
|
|
case SLAPI_PLUGIN_SYNTAX_COMPARE:
|
|
|
|
case SLAPI_CONFIG_FILENAME:
|
|
|
|
case SLAPI_CONFIG_ARGV:
|
2005-07-19 14:48:45 +08:00
|
|
|
case SLAPI_TARGET_ADDRESS:
|
|
|
|
case SLAPI_TARGET_UNIQUEID:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_TARGET_DN:
|
|
|
|
case SLAPI_REQCONTROLS:
|
|
|
|
case SLAPI_ENTRY_PRE_OP:
|
|
|
|
case SLAPI_ENTRY_POST_OP:
|
|
|
|
case SLAPI_RESCONTROLS:
|
2005-07-25 12:19:33 +08:00
|
|
|
case SLAPI_X_OLD_RESCONTROLS:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_ADD_RESCONTROL:
|
2005-07-25 12:19:33 +08:00
|
|
|
case SLAPI_CONTROLS_ARG:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_ADD_ENTRY:
|
2005-07-19 14:48:45 +08:00
|
|
|
case SLAPI_ADD_EXISTING_DN_ENTRY:
|
|
|
|
case SLAPI_ADD_PARENT_ENTRY:
|
|
|
|
case SLAPI_ADD_PARENT_UNIQUEID:
|
|
|
|
case SLAPI_ADD_EXISTING_UNIQUEID_ENTRY:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_BIND_CREDENTIALS:
|
|
|
|
case SLAPI_BIND_SASLMECHANISM:
|
|
|
|
case SLAPI_BIND_RET_SASLCREDS:
|
|
|
|
case SLAPI_COMPARE_TYPE:
|
|
|
|
case SLAPI_COMPARE_VALUE:
|
|
|
|
case SLAPI_MODIFY_MODS:
|
|
|
|
case SLAPI_MODRDN_NEWRDN:
|
|
|
|
case SLAPI_MODRDN_NEWSUPERIOR:
|
2005-07-19 14:48:45 +08:00
|
|
|
case SLAPI_MODRDN_PARENT_ENTRY:
|
|
|
|
case SLAPI_MODRDN_NEWPARENT_ENTRY:
|
|
|
|
case SLAPI_MODRDN_TARGET_ENTRY:
|
|
|
|
case SLAPI_MODRDN_NEWSUPERIOR_ADDRESS:
|
2002-12-08 01:19:29 +08:00
|
|
|
case SLAPI_SEARCH_FILTER:
|
|
|
|
case SLAPI_SEARCH_STRFILTER:
|
|
|
|
case SLAPI_SEARCH_ATTRS:
|
|
|
|
case SLAPI_SEQ_TYPE:
|
|
|
|
case SLAPI_SEQ_ATTRNAME:
|
|
|
|
case SLAPI_SEQ_VAL:
|
|
|
|
case SLAPI_EXT_OP_REQ_OID:
|
|
|
|
case SLAPI_EXT_OP_REQ_VALUE:
|
|
|
|
case SLAPI_EXT_OP_RET_OID:
|
|
|
|
case SLAPI_EXT_OP_RET_VALUE:
|
|
|
|
case SLAPI_MR_FILTER_ENTRY:
|
|
|
|
case SLAPI_MR_FILTER_TYPE:
|
|
|
|
case SLAPI_MR_FILTER_VALUE:
|
|
|
|
case SLAPI_MR_FILTER_OID:
|
|
|
|
case SLAPI_MR_FILTER_DNATTRS:
|
|
|
|
case SLAPI_LDIF2DB_FILE:
|
|
|
|
case SLAPI_PARENT_TXN:
|
|
|
|
case SLAPI_TXN:
|
|
|
|
case SLAPI_SEARCH_RESULT_SET:
|
|
|
|
case SLAPI_SEARCH_RESULT_ENTRY:
|
|
|
|
case SLAPI_SEARCH_REFERRALS:
|
|
|
|
case SLAPI_LOG_OPERATION:
|
2003-01-21 16:34:25 +08:00
|
|
|
case SLAPI_RESULT_TEXT:
|
|
|
|
case SLAPI_RESULT_MATCHED:
|
2004-08-25 23:20:19 +08:00
|
|
|
case SLAPI_X_GROUP_ENTRY:
|
|
|
|
case SLAPI_X_GROUP_ATTRIBUTE:
|
|
|
|
case SLAPI_X_GROUP_OPERATION_DN:
|
2004-08-26 12:24:29 +08:00
|
|
|
case SLAPI_X_GROUP_TARGET_ENTRY:
|
2005-02-20 10:13:14 +08:00
|
|
|
case SLAPI_PLUGIN_AUDIT_DATA:
|
|
|
|
case SLAPI_IBM_PBLOCK:
|
|
|
|
return PBLOCK_CLASS_POINTER;
|
|
|
|
break;
|
2002-12-08 01:19:29 +08:00
|
|
|
default:
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
2005-02-20 10:13:14 +08:00
|
|
|
return PBLOCK_CLASS_INVALID;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_lock( Slapi_PBlock *pb )
|
2002-12-08 01:19:29 +08:00
|
|
|
{
|
|
|
|
ldap_pvt_thread_mutex_lock(&pb->pblockMutex);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_unlock( Slapi_PBlock *pb )
|
2002-12-08 01:19:29 +08:00
|
|
|
{
|
|
|
|
ldap_pvt_thread_mutex_unlock(&pb->pblockMutex);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_get_default( Slapi_PBlock *pb, int param, void **value )
|
2002-12-08 01:19:29 +08:00
|
|
|
{
|
|
|
|
int i;
|
2005-02-20 10:13:14 +08:00
|
|
|
slapi_pblock_class_t pbClass;
|
2002-12-08 01:19:29 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
pbClass = pblock_get_param_class( param );
|
2005-02-20 10:13:14 +08:00
|
|
|
if ( pbClass == PBLOCK_CLASS_INVALID ) {
|
2002-12-08 01:19:29 +08:00
|
|
|
return PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
|
2005-02-20 10:13:14 +08:00
|
|
|
switch ( pbClass ) {
|
|
|
|
case PBLOCK_CLASS_INTEGER:
|
2005-07-25 12:19:33 +08:00
|
|
|
*((int *)value) = 0;
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
|
|
|
case PBLOCK_CLASS_LONG_INTEGER:
|
2005-07-25 12:19:33 +08:00
|
|
|
*((long *)value) = 0L;
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
|
|
|
case PBLOCK_CLASS_POINTER:
|
|
|
|
case PBLOCK_CLASS_FUNCTION_POINTER:
|
2005-07-25 12:19:33 +08:00
|
|
|
*value = NULL;
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
2005-07-25 12:19:33 +08:00
|
|
|
case PBLOCK_CLASS_INVALID:
|
|
|
|
return PBLOCK_ERROR;
|
2005-02-20 10:13:14 +08:00
|
|
|
}
|
|
|
|
|
2002-12-08 01:19:29 +08:00
|
|
|
for ( i = 0; i < pb->numParams; i++ ) {
|
|
|
|
if ( pb->curParams[i] == param ) {
|
2005-02-20 10:13:14 +08:00
|
|
|
switch ( pbClass ) {
|
|
|
|
case PBLOCK_CLASS_INTEGER:
|
2005-07-25 12:19:33 +08:00
|
|
|
*((int *)value) = (int)pb->curVals[i];
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
|
|
|
case PBLOCK_CLASS_LONG_INTEGER:
|
2005-07-25 12:19:33 +08:00
|
|
|
*((long *)value) = (long)pb->curVals[i];
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
|
|
|
case PBLOCK_CLASS_POINTER:
|
|
|
|
case PBLOCK_CLASS_FUNCTION_POINTER:
|
2005-07-25 12:19:33 +08:00
|
|
|
*value = pb->curVals[i];
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2002-12-08 01:19:29 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2005-07-25 12:19:33 +08:00
|
|
|
|
2005-02-20 10:13:14 +08:00
|
|
|
return PBLOCK_SUCCESS;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
static char *
|
|
|
|
pblock_get_authtype( AuthorizationInformation *authz, int is_tls )
|
|
|
|
{
|
|
|
|
char *authType;
|
|
|
|
|
|
|
|
switch ( authz->sai_method ) {
|
|
|
|
case LDAP_AUTH_SASL:
|
|
|
|
authType = SLAPD_AUTH_SASL;
|
|
|
|
break;
|
|
|
|
case LDAP_AUTH_SIMPLE:
|
|
|
|
authType = SLAPD_AUTH_SIMPLE;
|
|
|
|
break;
|
|
|
|
case LDAP_AUTH_NONE:
|
|
|
|
authType = SLAPD_AUTH_NONE;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
authType = NULL;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( is_tls && authType == NULL ) {
|
|
|
|
authType = SLAPD_AUTH_SSL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return authType;
|
|
|
|
}
|
|
|
|
|
2002-12-08 01:19:29 +08:00
|
|
|
static int
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_set_default( Slapi_PBlock *pb, int param, void *value )
|
2002-12-08 01:19:29 +08:00
|
|
|
{
|
2005-02-20 10:13:14 +08:00
|
|
|
slapi_pblock_class_t pbClass;
|
2005-07-25 12:19:33 +08:00
|
|
|
size_t i;
|
2002-12-08 01:19:29 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
pbClass = pblock_get_param_class( param );
|
2005-02-20 10:13:14 +08:00
|
|
|
if ( pbClass == PBLOCK_CLASS_INVALID ) {
|
2002-12-08 01:19:29 +08:00
|
|
|
return PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
|
2003-01-27 22:44:39 +08:00
|
|
|
if ( pb->numParams == PBLOCK_MAX_PARAMS ) {
|
2005-07-25 12:19:33 +08:00
|
|
|
return PBLOCK_ERROR;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
for ( i = 0; i < pb->numParams; i++ ) {
|
|
|
|
if ( pb->curParams[i] == param ) {
|
|
|
|
break;
|
|
|
|
}
|
2003-12-04 08:52:03 +08:00
|
|
|
}
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
if ( i >= pb->numParams ) {
|
|
|
|
pb->curParams[i] = param;
|
|
|
|
pb->numParams++;
|
|
|
|
}
|
|
|
|
|
|
|
|
pb->curVals[i] = value;
|
|
|
|
|
|
|
|
return PBLOCK_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
pblock_get( Slapi_PBlock *pb, int param, void **value )
|
|
|
|
{
|
|
|
|
int rc = PBLOCK_SUCCESS;
|
|
|
|
|
|
|
|
pblock_lock( pb );
|
|
|
|
|
2003-09-24 08:32:27 +08:00
|
|
|
switch ( param ) {
|
2005-07-25 12:19:33 +08:00
|
|
|
case SLAPI_OPERATION:
|
|
|
|
*value = pb->pop;
|
|
|
|
break;
|
|
|
|
case SLAPI_OPINITIATED_TIME:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((time_t *)value) = pb->pop->o_time;
|
|
|
|
break;
|
|
|
|
case SLAPI_OPERATION_ID:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((unsigned long *)value) = pb->pop->o_opid;
|
|
|
|
break;
|
|
|
|
case SLAPI_OPERATION_TYPE:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((ber_tag_t *)value) = pb->pop->o_tag;
|
|
|
|
break;
|
|
|
|
case SLAPI_REQCONTROLS:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((LDAPControl ***)value) = pb->pop->o_ctrls;
|
|
|
|
break;
|
|
|
|
case SLAPI_REQUESTOR_DN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((char **)value) = pb->pop->o_ndn.bv_val;
|
|
|
|
break;
|
|
|
|
case SLAPI_MANAGEDSAIT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((int *)value) = get_manageDSAit( pb->pop );
|
|
|
|
break;
|
|
|
|
case SLAPI_BACKEND:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((BackendDB **)value) = pb->pop->o_bd;
|
|
|
|
break;
|
|
|
|
case SLAPI_BE_TYPE:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_bd != NULL )
|
|
|
|
*((char **)value) = pb->pop->o_bd->bd_info->bi_type;
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_CONNECTION:
|
|
|
|
*value = pb->pconn;
|
|
|
|
break;
|
|
|
|
case SLAPI_X_CONN_SSF:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((slap_ssf_t *)value) = pb->pconn->c_ssf;
|
|
|
|
break;
|
|
|
|
case SLAPI_X_CONN_SASL_CONTEXT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pconn->c_sasl_authctx != NULL )
|
|
|
|
*value = pb->pconn->c_sasl_authctx;
|
|
|
|
else
|
|
|
|
*value = pb->pconn->c_sasl_sockctx;
|
|
|
|
break;
|
|
|
|
case SLAPI_TARGET_DN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((char **)value) = pb->pop->o_req_ndn.bv_val;
|
|
|
|
break;
|
|
|
|
case SLAPI_REQUESTOR_ISROOT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((int *)value) = be_isroot( pb->pop );
|
|
|
|
break;
|
|
|
|
case SLAPI_REQUESTOR_ISUPDATEDN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((int *)value) = be_isupdate( pb->pop );
|
|
|
|
break;
|
|
|
|
case SLAPI_CONN_AUTHTYPE:
|
|
|
|
case SLAPI_CONN_AUTHMETHOD: /* XXX should return SASL mech */
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((char **)value) = pblock_get_authtype( &pb->pconn->c_authz,
|
|
|
|
#ifdef HAVE_TLS
|
|
|
|
pb->pconn->c_is_tls
|
|
|
|
#else
|
|
|
|
0
|
|
|
|
#endif
|
|
|
|
);
|
|
|
|
break;
|
|
|
|
case SLAPI_X_CONN_IS_UDP:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
#ifdef LDAP_CONNECTIONLESS
|
|
|
|
*((int *)value) = pb->pconn->c_is_udp;
|
|
|
|
#else
|
|
|
|
*((int *)value) = 0;
|
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
case SLAPI_CONN_ID:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((unsigned long *)value) = pb->pconn->c_connid;
|
|
|
|
break;
|
|
|
|
case SLAPI_CONN_DN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
*((char **)value) = pb->pconn->c_dn.bv_val;
|
|
|
|
break;
|
|
|
|
case SLAPI_CONN_CLIENTIP:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( strncmp( pb->pconn->c_peer_name.bv_val, "IP=", 3 ) == 0 )
|
|
|
|
*((char **)value) = &pb->pconn->c_peer_name.bv_val[3];
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_X_CONN_CLIENTPATH:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( strncmp( pb->pconn->c_peer_name.bv_val, "PATH=", 3 ) == 0 )
|
|
|
|
*((char **)value) = &pb->pconn->c_peer_name.bv_val[5];
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_CONN_SERVERIP:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( strncmp( pb->pconn->c_peer_name.bv_val, "IP=", 3 ) == 0 )
|
|
|
|
*((char **)value) = &pb->pconn->c_sock_name.bv_val[3];
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_X_CONN_SERVERPATH:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( strncmp( pb->pconn->c_peer_name.bv_val, "PATH=", 3 ) == 0 )
|
|
|
|
*((char **)value) = &pb->pconn->c_sock_name.bv_val[5];
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_RESULT_CODE:
|
|
|
|
case SLAPI_PLUGIN_INTOP_RESULT:
|
|
|
|
*((int *)value) = pb->rs.sr_err;
|
|
|
|
break;
|
2003-09-24 08:32:27 +08:00
|
|
|
case SLAPI_RESULT_TEXT:
|
2005-07-25 12:19:33 +08:00
|
|
|
*((const char **)value) = pb->rs.sr_text;
|
|
|
|
break;
|
2003-09-24 08:32:27 +08:00
|
|
|
case SLAPI_RESULT_MATCHED:
|
2005-07-25 12:19:33 +08:00
|
|
|
*((const char **)value) = pb->rs.sr_matched;
|
|
|
|
break;
|
|
|
|
case SLAPI_ADD_ENTRY:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_ADD )
|
|
|
|
*((Slapi_Entry **)value) = pb->pop->ora_e;
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_MODIFY_MODS: {
|
|
|
|
LDAPMod **mods = NULL;
|
|
|
|
|
|
|
|
pblock_get_default( pb, param, (void **)&mods );
|
|
|
|
if ( mods == NULL && pb->internal_op == 0 ) {
|
|
|
|
if ( pb->pop->o_tag != LDAP_REQ_MODIFY ) {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
mods = slapi_int_modifications2ldapmods( &pb->pop->orm_modlist, NULL );
|
|
|
|
pblock_set_default( pb, param, (void *)mods );
|
|
|
|
}
|
|
|
|
*((LDAPMod ***)value) = mods;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case SLAPI_MODRDN_NEWRDN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_MODRDN )
|
|
|
|
*((char **)value) = pb->pop->orr_newrdn.bv_val;
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_MODRDN_NEWSUPERIOR:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_MODRDN && pb->pop->orr_newSup != NULL )
|
|
|
|
*((char **)value) = pb->pop->orr_newSup->bv_val;
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_MODRDN_DELOLDRDN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_MODRDN )
|
|
|
|
*((int *)value) = pb->pop->orr_deleteoldrdn;
|
|
|
|
else
|
|
|
|
*((int *)value) = 0;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_SCOPE:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
*((int *)value) = pb->pop->ors_scope;
|
|
|
|
else
|
|
|
|
*((int *)value) = 0;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_DEREF:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
*((int *)value) = pb->pop->ors_deref;
|
|
|
|
else
|
|
|
|
*((int *)value) = 0;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_SIZELIMIT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
*((int *)value) = pb->pop->ors_slimit;
|
|
|
|
else
|
|
|
|
*((int *)value) = 0;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_TIMELIMIT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
*((int *)value) = pb->pop->ors_tlimit;
|
|
|
|
else
|
|
|
|
*((int *)value) = 0;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_FILTER:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
*((Slapi_Filter **)value) = pb->pop->ors_filter;
|
|
|
|
else
|
|
|
|
*((Slapi_Filter **)value) = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_STRFILTER:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
*((char **)value) = pb->pop->ors_filterstr.bv_val;
|
|
|
|
else
|
|
|
|
*((char **)value) = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_ATTRS: {
|
|
|
|
char **attrs = NULL;
|
|
|
|
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag != LDAP_REQ_SEARCH ) {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
pblock_get_default( pb, param, (void **)&attrs );
|
|
|
|
if ( attrs == NULL && pb->internal_op == 0 ) {
|
|
|
|
attrs = anlist2charray_x( pb->pop->ors_attrs, 0, pb->pop->o_tmpmemctx );
|
|
|
|
pblock_set_default( pb, param, (void *)attrs );
|
|
|
|
}
|
|
|
|
*((char ***)attrs) = attrs;
|
|
|
|
}
|
|
|
|
case SLAPI_SEARCH_ATTRSONLY:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
*((int *)value) = pb->pop->ors_attrsonly;
|
|
|
|
else
|
|
|
|
*((int *)value) = 0;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_RESULT_ENTRY:
|
|
|
|
*((Slapi_Entry **)value) = pb->rs.sr_entry;
|
|
|
|
break;
|
|
|
|
case SLAPI_BIND_RET_SASLCREDS:
|
|
|
|
*((struct berval **)value) = pb->rs.sr_sasldata;
|
|
|
|
break;
|
|
|
|
case SLAPI_EXT_OP_REQ_OID:
|
|
|
|
*((const char **)value) = pb->pop->ore_reqoid.bv_val;
|
|
|
|
break;
|
|
|
|
case SLAPI_EXT_OP_REQ_VALUE:
|
|
|
|
*((struct berval **)value) = pb->pop->ore_reqdata;
|
|
|
|
break;
|
|
|
|
case SLAPI_EXT_OP_RET_OID:
|
|
|
|
*((const char **)value) = pb->rs.sr_rspoid;
|
|
|
|
break;
|
|
|
|
case SLAPI_EXT_OP_RET_VALUE:
|
|
|
|
*((struct berval **)value) = pb->rs.sr_rspdata;
|
|
|
|
break;
|
|
|
|
case SLAPI_BIND_METHOD:
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_BIND )
|
|
|
|
*((int *)value) = pb->pop->orb_method;
|
|
|
|
else
|
|
|
|
*((int *)value) = 0;
|
|
|
|
break;
|
|
|
|
case SLAPI_BIND_CREDENTIALS:
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_BIND )
|
|
|
|
*((struct berval **)value) = &pb->pop->orb_cred;
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_COMPARE_TYPE:
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_COMPARE )
|
|
|
|
*((char **)value) = pb->pop->orc_ava->aa_desc->ad_cname.bv_val;
|
|
|
|
else
|
|
|
|
*value = NULL;
|
|
|
|
break;
|
|
|
|
case SLAPI_COMPARE_VALUE:
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_COMPARE )
|
|
|
|
*((struct berval **)value) = &pb->pop->orc_ava->aa_value;
|
|
|
|
else
|
|
|
|
*value = NULL;
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
2003-09-24 08:32:27 +08:00
|
|
|
default:
|
2005-07-25 12:19:33 +08:00
|
|
|
rc = pblock_get_default( pb, param, value );
|
2005-02-20 10:13:14 +08:00
|
|
|
break;
|
2003-09-24 08:32:27 +08:00
|
|
|
}
|
2005-07-25 12:19:33 +08:00
|
|
|
|
|
|
|
pblock_unlock( pb );
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
pblock_add_control( Slapi_PBlock *pb, LDAPControl *control )
|
|
|
|
{
|
|
|
|
LDAPControl **controls = NULL;
|
|
|
|
size_t i;
|
|
|
|
|
|
|
|
pblock_get_default( pb, SLAPI_RESCONTROLS, (void **)&controls );
|
|
|
|
|
|
|
|
if ( controls != NULL ) {
|
|
|
|
for ( i = 0; controls[i] != NULL; i++ )
|
|
|
|
;
|
|
|
|
} else {
|
|
|
|
i = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
controls = (LDAPControl **)slapi_ch_realloc( (char *)controls,
|
|
|
|
( i + 2 ) * sizeof(LDAPControl *));
|
|
|
|
controls[i] = control;
|
|
|
|
|
|
|
|
return pblock_set_default( pb, SLAPI_RESCONTROLS, (void *)controls );
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
pblock_set_dn( void *value, struct berval *dn, struct berval *ndn, void *memctx )
|
|
|
|
{
|
|
|
|
struct berval bv;
|
|
|
|
|
|
|
|
if ( !BER_BVISNULL( dn )) {
|
|
|
|
slap_sl_free( dn->bv_val, memctx );
|
|
|
|
BER_BVZERO( dn );
|
|
|
|
}
|
|
|
|
if ( !BER_BVISNULL( ndn )) {
|
|
|
|
slap_sl_free( ndn->bv_val, memctx );
|
|
|
|
BER_BVZERO( ndn );
|
|
|
|
}
|
|
|
|
|
|
|
|
bv.bv_val = (char *)value;
|
|
|
|
bv.bv_len = strlen( bv.bv_val );
|
|
|
|
|
|
|
|
return dnPrettyNormal( NULL, &bv, dn, ndn, memctx );
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
pblock_set( Slapi_PBlock *pb, int param, void *value )
|
|
|
|
{
|
|
|
|
int rc = PBLOCK_SUCCESS;
|
|
|
|
|
|
|
|
pblock_lock( pb );
|
|
|
|
|
|
|
|
switch ( param ) {
|
|
|
|
case SLAPI_OPERATION:
|
|
|
|
pb->pop = (Operation *)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_OPINITIATED_TIME:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
pb->pop->o_time = (time_t)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_OPERATION_ID:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
pb->pop->o_opid = (unsigned long)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_OPERATION_TYPE:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
pb->pop->o_tag = (ber_tag_t)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_REQCONTROLS:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
pb->pop->o_ctrls = (LDAPControl **)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_RESCONTROLS: {
|
|
|
|
LDAPControl **ctrls = NULL;
|
|
|
|
|
|
|
|
pblock_get_default( pb, param, (void **)&ctrls );
|
|
|
|
if ( ctrls == NULL ) {
|
|
|
|
/* free old ones first */
|
|
|
|
ldap_controls_free( ctrls );
|
|
|
|
}
|
|
|
|
rc = pblock_set_default( pb, param, value );
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case SLAPI_ADD_RESCONTROL:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
rc = pblock_add_control( pb, (LDAPControl *)value );
|
|
|
|
break;
|
|
|
|
case SLAPI_REQUESTOR_DN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
rc = pblock_set_dn( value, &pb->pop->o_dn, &pb->pop->o_ndn, pb->pop->o_tmpmemctx );
|
|
|
|
break;
|
|
|
|
case SLAPI_MANAGEDSAIT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
pb->pop->o_managedsait = (int)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_BACKEND:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
pb->pop->o_bd = (BackendDB *)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_CONNECTION:
|
|
|
|
pb->pconn = (Connection *)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_X_CONN_SSF:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_LOCK_CONN( pb );
|
|
|
|
pb->pconn->c_ssf = (slap_ssf_t)value;
|
|
|
|
PBLOCK_UNLOCK_CONN( pb );
|
|
|
|
break;
|
|
|
|
case SLAPI_X_CONN_SASL_CONTEXT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_LOCK_CONN( pb );
|
|
|
|
pb->pconn->c_sasl_authctx = value;
|
|
|
|
PBLOCK_UNLOCK_CONN( pb );
|
|
|
|
break;
|
|
|
|
case SLAPI_TARGET_DN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
rc = pblock_set_dn( value, &pb->pop->o_req_dn, &pb->pop->o_req_ndn, pb->pop->o_tmpmemctx );
|
|
|
|
break;
|
|
|
|
case SLAPI_CONN_ID:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_LOCK_CONN( pb );
|
|
|
|
pb->pconn->c_connid = (unsigned long)value;
|
|
|
|
PBLOCK_UNLOCK_CONN( pb );
|
|
|
|
break;
|
|
|
|
case SLAPI_CONN_DN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_LOCK_CONN( pb );
|
|
|
|
rc = pblock_set_dn( value, &pb->pconn->c_dn, &pb->pconn->c_ndn, NULL );
|
|
|
|
PBLOCK_UNLOCK_CONN( pb );
|
|
|
|
break;
|
|
|
|
case SLAPI_RESULT_CODE:
|
|
|
|
case SLAPI_PLUGIN_INTOP_RESULT:
|
|
|
|
pb->rs.sr_err = (int)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_RESULT_TEXT:
|
|
|
|
snprintf( pb->textbuf, sizeof( pb->textbuf ), "%s", (char *)value );
|
|
|
|
pb->rs.sr_text = pb->textbuf;
|
|
|
|
break;
|
|
|
|
case SLAPI_RESULT_MATCHED:
|
|
|
|
pb->rs.sr_matched = (char *)value; /* XXX should dup? */
|
|
|
|
break;
|
|
|
|
case SLAPI_ADD_ENTRY:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_ADD ) {
|
|
|
|
pb->pop->ora_e = (Slapi_Entry *)value;
|
|
|
|
} else {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SLAPI_MODIFY_MODS: {
|
|
|
|
Modifications **mlp;
|
|
|
|
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
rc = pblock_set_default( pb, param, value );
|
|
|
|
if ( rc != PBLOCK_SUCCESS ) {
|
2002-12-08 01:19:29 +08:00
|
|
|
break;
|
|
|
|
}
|
2005-07-25 12:19:33 +08:00
|
|
|
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_MODIFY ) {
|
|
|
|
mlp = &pb->pop->orm_modlist;
|
|
|
|
} else if ( pb->pop->o_tag == LDAP_REQ_ADD ) {
|
|
|
|
mlp = &pb->pop->ora_modlist;
|
|
|
|
} else {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( *mlp != NULL ) {
|
|
|
|
if ( pb->internal_op )
|
|
|
|
slapi_int_mods_free( *mlp ); /* caller owns values */
|
|
|
|
else
|
|
|
|
slap_mods_free( *mlp ); /* we own values */
|
|
|
|
*mlp = NULL;
|
|
|
|
}
|
|
|
|
*mlp = slapi_int_ldapmods2modifications( (LDAPMod **)value, NULL );
|
|
|
|
break;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
2005-07-25 12:19:33 +08:00
|
|
|
case SLAPI_MODRDN_NEWRDN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_MODRDN ) {
|
|
|
|
rc = pblock_set_dn( value, &pb->pop->orr_newrdn, &pb->pop->orr_nnewrdn, pb->pop->o_tmpmemctx );
|
|
|
|
if ( rc == LDAP_SUCCESS ) rc = rdn_validate( &pb->pop->orr_nnewrdn );
|
|
|
|
} else {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SLAPI_MODRDN_NEWSUPERIOR:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_MODRDN ) {
|
|
|
|
if ( value == NULL ) {
|
|
|
|
if ( pb->pop->orr_newSup != NULL ) {
|
|
|
|
pb->pop->o_tmpfree( pb->pop->orr_newSup, pb->pop->o_tmpmemctx );
|
|
|
|
pb->pop->orr_newSup = NULL;
|
|
|
|
}
|
|
|
|
if ( pb->pop->orr_newSup != NULL ) {
|
|
|
|
pb->pop->o_tmpfree( pb->pop->orr_nnewSup, pb->pop->o_tmpmemctx );
|
|
|
|
pb->pop->orr_nnewSup = NULL;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ( pb->pop->orr_newSup == NULL ) {
|
|
|
|
pb->pop->orr_newSup = (struct berval *)pb->pop->o_tmpalloc(
|
|
|
|
sizeof(struct berval), pb->pop->o_tmpmemctx );
|
|
|
|
}
|
|
|
|
if ( pb->pop->orr_nnewSup == NULL ) {
|
|
|
|
pb->pop->orr_nnewSup = (struct berval *)pb->pop->o_tmpalloc(
|
|
|
|
sizeof(struct berval), pb->pop->o_tmpmemctx );
|
|
|
|
}
|
|
|
|
rc = pblock_set_dn( value, pb->pop->orr_newSup, pb->pop->orr_nnewSup, pb->pop->o_tmpmemctx );
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SLAPI_MODRDN_DELOLDRDN:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_MODRDN )
|
|
|
|
pb->pop->orr_deleteoldrdn = (int)value;
|
|
|
|
else
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_SCOPE:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH ) {
|
|
|
|
switch ( (int)value ) {
|
|
|
|
case LDAP_SCOPE_BASE:
|
|
|
|
case LDAP_SCOPE_ONELEVEL:
|
|
|
|
case LDAP_SCOPE_SUBTREE:
|
|
|
|
#ifdef LDAP_SCOPE_SUBORDINATE
|
|
|
|
case LDAP_SCOPE_SUBORDINATE:
|
|
|
|
#endif
|
|
|
|
pb->pop->ors_scope = (int)value;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_DEREF:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
pb->pop->ors_deref = (int)value;
|
|
|
|
else
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_SIZELIMIT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
pb->pop->ors_slimit = (int)value;
|
|
|
|
else
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_TIMELIMIT:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
pb->pop->ors_tlimit = (int)value;
|
|
|
|
else
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_FILTER:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH ) {
|
|
|
|
pb->pop->ors_filter = (Slapi_Filter *)value;
|
|
|
|
} else {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_STRFILTER:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH ) {
|
|
|
|
pb->pop->ors_filterstr.bv_val = (char *)value;
|
|
|
|
pb->pop->ors_filterstr.bv_len = strlen((char *)value);
|
|
|
|
} else {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_ATTRS: {
|
|
|
|
AttributeName *an = NULL;
|
|
|
|
size_t i = 0;
|
|
|
|
char **attrs = (char **)value;
|
2002-12-08 01:19:29 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
|
|
|
|
if ( pb->pop->o_tag != LDAP_REQ_SEARCH ) {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
/* also set mapped attrs */
|
|
|
|
rc = pblock_set_default( pb, param, value );
|
|
|
|
if ( rc != PBLOCK_SUCCESS ) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if ( pb->pop->ors_attrs != NULL ) {
|
|
|
|
pb->pop->o_tmpfree( pb->pop->ors_attrs, pb->pop->o_tmpmemctx );
|
|
|
|
pb->pop->ors_attrs = NULL;
|
|
|
|
}
|
|
|
|
if ( attrs != NULL ) {
|
|
|
|
for ( i = 0; attrs[i] != NULL; i++ )
|
|
|
|
;
|
|
|
|
}
|
|
|
|
if ( i ) {
|
|
|
|
an = (AttributeName *)pb->pop->o_tmpalloc( (i + 1) *
|
|
|
|
sizeof(AttributeName), pb->pop->o_tmpmemctx );
|
|
|
|
for ( i = 0; attrs[i] != NULL; i++ ) {
|
|
|
|
an[i].an_desc = NULL;
|
|
|
|
an[i].an_oc = NULL;
|
|
|
|
an[i].an_oc_exclude = 0;
|
|
|
|
an[i].an_name.bv_val = attrs[i];
|
|
|
|
an[i].an_name.bv_len = strlen( attrs[i] );
|
|
|
|
slap_bv2ad( &an[i].an_name, &an[i].an_desc, &pb->rs.sr_text );
|
|
|
|
}
|
|
|
|
an[i].an_name.bv_val = NULL;
|
|
|
|
an[i].an_name.bv_len = 0;
|
|
|
|
}
|
|
|
|
pb->pop->ors_attrs = an;
|
|
|
|
break;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
2005-07-25 12:19:33 +08:00
|
|
|
case SLAPI_SEARCH_ATTRSONLY:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_SEARCH )
|
|
|
|
pb->pop->ors_attrsonly = (int)value;
|
|
|
|
else
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
case SLAPI_SEARCH_RESULT_ENTRY:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
pb->rs.sr_entry = (Slapi_Entry *)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_BIND_RET_SASLCREDS:
|
|
|
|
pb->rs.sr_sasldata = (struct berval *)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_EXT_OP_REQ_OID:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
2003-12-04 08:52:03 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_EXTENDED ) {
|
|
|
|
pb->pop->ore_reqoid.bv_val = (char *)value;
|
|
|
|
pb->pop->ore_reqoid.bv_len = strlen((char *)value);
|
2004-03-03 04:31:37 +08:00
|
|
|
} else {
|
2005-07-25 12:19:33 +08:00
|
|
|
rc = PBLOCK_ERROR;
|
2004-03-03 04:31:37 +08:00
|
|
|
}
|
2005-07-25 12:19:33 +08:00
|
|
|
break;
|
|
|
|
case SLAPI_EXT_OP_REQ_VALUE:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_EXTENDED )
|
|
|
|
pb->pop->ore_reqdata = (struct berval *)value;
|
|
|
|
else
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
case SLAPI_EXT_OP_RET_OID:
|
|
|
|
pb->rs.sr_rspoid = (char *)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_EXT_OP_RET_VALUE:
|
|
|
|
pb->rs.sr_rspdata = (struct berval *)value;
|
|
|
|
break;
|
|
|
|
case SLAPI_BIND_METHOD:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_BIND )
|
|
|
|
pb->pop->orb_method = (int)value;
|
|
|
|
else
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
case SLAPI_BIND_CREDENTIALS:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_BIND )
|
|
|
|
pb->pop->orb_cred = *((struct berval *)value);
|
|
|
|
else
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
case SLAPI_COMPARE_TYPE:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_COMPARE ) {
|
|
|
|
const char *text;
|
|
|
|
|
|
|
|
pb->pop->orc_ava->aa_desc = NULL;
|
|
|
|
rc = slap_str2ad( (char *)value, &pb->pop->orc_ava->aa_desc, &text );
|
|
|
|
} else {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SLAPI_COMPARE_VALUE:
|
|
|
|
PBLOCK_ASSERT_OP( pb, 0 );
|
|
|
|
PBLOCK_VALIDATE_IS_INTOP( pb );
|
|
|
|
|
|
|
|
if ( pb->pop->o_tag == LDAP_REQ_COMPARE ) {
|
|
|
|
pb->pop->orc_ava->aa_value = *((struct berval *)value);
|
|
|
|
} else {
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SLAPI_REQUESTOR_ISROOT:
|
|
|
|
case SLAPI_REQUESTOR_ISUPDATEDN:
|
|
|
|
case SLAPI_CONN_AUTHTYPE:
|
|
|
|
case SLAPI_CONN_AUTHMETHOD:
|
|
|
|
case SLAPI_X_CONN_IS_UDP:
|
|
|
|
case SLAPI_CONN_CLIENTIP:
|
|
|
|
case SLAPI_X_CONN_CLIENTPATH:
|
|
|
|
case SLAPI_CONN_SERVERIP:
|
|
|
|
case SLAPI_X_CONN_SERVERPATH:
|
|
|
|
rc = PBLOCK_ERROR;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
rc = pblock_set_default( pb, param, value );
|
|
|
|
break;
|
2003-12-04 08:52:03 +08:00
|
|
|
}
|
2002-12-08 01:19:29 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_unlock( pb );
|
2002-12-08 01:19:29 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
return rc;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_clear( Slapi_PBlock *pb )
|
2002-12-08 01:19:29 +08:00
|
|
|
{
|
2005-07-25 12:19:33 +08:00
|
|
|
pb->numParams = 1;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_delete_param( Slapi_PBlock *p, int param )
|
2002-12-08 01:19:29 +08:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_lock(p);
|
|
|
|
|
2002-12-08 01:19:29 +08:00
|
|
|
for ( i = 0; i < p->numParams; i++ ) {
|
|
|
|
if ( p->curParams[i] == param ) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (i >= p->numParams ) {
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_unlock( p );
|
2002-12-08 01:19:29 +08:00
|
|
|
return PBLOCK_ERROR;
|
|
|
|
}
|
|
|
|
if ( p->numParams > 1 ) {
|
|
|
|
p->curParams[i] = p->curParams[p->numParams];
|
|
|
|
p->curVals[i] = p->curVals[p->numParams];
|
|
|
|
}
|
|
|
|
p->numParams--;
|
2005-07-25 12:19:33 +08:00
|
|
|
|
|
|
|
pblock_unlock( p );
|
|
|
|
|
2005-02-20 10:13:14 +08:00
|
|
|
return PBLOCK_SUCCESS;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
Slapi_PBlock *
|
2005-07-25 12:19:33 +08:00
|
|
|
slapi_pblock_new(void)
|
2002-12-08 01:19:29 +08:00
|
|
|
{
|
|
|
|
Slapi_PBlock *pb;
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
pb = (Slapi_PBlock *) ch_calloc( 1, sizeof(Slapi_PBlock) );
|
2002-12-08 01:19:29 +08:00
|
|
|
if ( pb != NULL ) {
|
2005-07-22 02:07:16 +08:00
|
|
|
pb->ckParams = 1;
|
2002-12-08 01:19:29 +08:00
|
|
|
ldap_pvt_thread_mutex_init( &pb->pblockMutex );
|
|
|
|
memset( pb->curParams, 0, sizeof(pb->curParams) );
|
|
|
|
memset( pb->curVals, 0, sizeof(pb->curVals) );
|
|
|
|
pb->curParams[0] = SLAPI_IBM_PBLOCK;
|
|
|
|
pb->curVals[0] = NULL;
|
|
|
|
pb->numParams = 1;
|
2005-07-25 12:19:33 +08:00
|
|
|
pb->pconn = NULL;
|
|
|
|
pb->pop = NULL;
|
|
|
|
pb->internal_op = 0;
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
return pb;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
slapi_pblock_destroy( Slapi_PBlock* pb )
|
|
|
|
{
|
2005-07-25 12:19:33 +08:00
|
|
|
LDAPControl **controls = NULL;
|
2002-12-08 01:19:29 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
assert( pb != NULL );
|
2003-01-21 16:34:25 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
if ( pb->internal_op ) {
|
|
|
|
slapi_int_connection_done_pb( pb );
|
|
|
|
} else {
|
|
|
|
LDAPMod **mods = NULL;
|
|
|
|
char **attrs = NULL;
|
|
|
|
|
|
|
|
pblock_get_default( pb, SLAPI_MODIFY_MODS, (void **)&mods );
|
|
|
|
|
|
|
|
if ( mods != NULL )
|
|
|
|
slapi_int_free_ldapmods( mods );
|
2003-01-21 07:18:11 +08:00
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_get_default( pb, SLAPI_SEARCH_ATTRS, (void **)&attrs );
|
|
|
|
|
|
|
|
if ( attrs != NULL )
|
|
|
|
pb->pop->o_tmpfree( attrs, pb->pop->o_tmpmemctx );
|
2003-01-21 07:18:11 +08:00
|
|
|
}
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_get_default( pb, SLAPI_RESCONTROLS, (void **)&controls );
|
|
|
|
if ( controls != NULL ) {
|
|
|
|
ldap_controls_free( controls );
|
2003-12-16 13:59:50 +08:00
|
|
|
}
|
|
|
|
|
2002-12-08 01:19:29 +08:00
|
|
|
ldap_pvt_thread_mutex_destroy( &pb->pblockMutex );
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
slapi_ch_free( (void **)&pb );
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
slapi_pblock_get( Slapi_PBlock *pb, int arg, void *value )
|
|
|
|
{
|
2005-07-25 12:19:33 +08:00
|
|
|
return pblock_get( pb, arg, (void **)value );
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
slapi_pblock_set( Slapi_PBlock *pb, int arg, void *value )
|
|
|
|
{
|
2005-07-25 12:19:33 +08:00
|
|
|
return pblock_set( pb, arg, value );
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
slapi_pblock_clear( Slapi_PBlock *pb )
|
|
|
|
{
|
2005-07-25 12:19:33 +08:00
|
|
|
pblock_clear( pb );
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
slapi_pblock_delete_param( Slapi_PBlock *p, int param )
|
|
|
|
{
|
2005-07-25 12:19:33 +08:00
|
|
|
return pblock_delete_param( p, param );
|
2002-12-08 01:19:29 +08:00
|
|
|
}
|
|
|
|
|
2002-12-14 23:04:37 +08:00
|
|
|
/*
|
|
|
|
* OpenLDAP extension
|
|
|
|
*/
|
|
|
|
int
|
2003-12-16 23:49:31 +08:00
|
|
|
slapi_int_pblock_get_first( Backend *be, Slapi_PBlock **pb )
|
2002-12-14 23:04:37 +08:00
|
|
|
{
|
2005-07-18 14:22:33 +08:00
|
|
|
assert( pb != NULL );
|
2005-07-22 13:26:15 +08:00
|
|
|
*pb = SLAPI_BACKEND_PBLOCK( be );
|
2002-12-14 23:04:37 +08:00
|
|
|
return (*pb == NULL ? LDAP_OTHER : LDAP_SUCCESS);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* OpenLDAP extension
|
|
|
|
*/
|
|
|
|
int
|
2003-12-16 23:49:31 +08:00
|
|
|
slapi_int_pblock_get_next( Slapi_PBlock **pb )
|
2002-12-14 23:04:37 +08:00
|
|
|
{
|
2005-07-18 14:22:33 +08:00
|
|
|
assert( pb != NULL );
|
2002-12-14 23:04:37 +08:00
|
|
|
return slapi_pblock_get( *pb, SLAPI_IBM_PBLOCK, pb );
|
|
|
|
}
|
|
|
|
|
2005-07-25 12:19:33 +08:00
|
|
|
#endif /* LDAP_SLAPI */
|
|
|
|
|