mirror of
https://git.openldap.org/openldap/openldap.git
synced 2024-12-21 03:10:25 +08:00
531 lines
14 KiB
C
531 lines
14 KiB
C
/* $OpenLDAP$ */
|
|
/*
|
|
* Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved.
|
|
* COPYING RESTRICTIONS APPLY, see COPYRIGHT file
|
|
*/
|
|
#ifndef _PROTO_SLAP
|
|
#define _PROTO_SLAP
|
|
|
|
#include <ldap_cdefs.h>
|
|
|
|
LDAP_BEGIN_DECL
|
|
|
|
/*
|
|
* acl.c
|
|
*/
|
|
|
|
int access_allowed LDAP_P(( Backend *be, Connection *conn,
|
|
Operation *op, Entry *e,
|
|
char *attr, struct berval *val, slap_access_t access ));
|
|
|
|
int acl_check_modlist LDAP_P(( Backend *be,
|
|
Connection *conn,
|
|
Operation *op,
|
|
Entry *e,
|
|
LDAPModList *ml ));
|
|
|
|
void acl_append( AccessControl **l, AccessControl *a );
|
|
|
|
/*
|
|
* aclparse.c
|
|
*/
|
|
|
|
void parse_acl LDAP_P(( Backend *be,
|
|
const char *fname,
|
|
int lineno,
|
|
int argc, char **argv ));
|
|
|
|
char * access2str LDAP_P(( slap_access_t access ));
|
|
slap_access_t str2access LDAP_P(( const char *str ));
|
|
|
|
#define ACCESSMASK_MAXLEN sizeof("unknown (+wrscan)")
|
|
char * accessmask2str LDAP_P(( slap_access_mask_t mask, char* ));
|
|
slap_access_mask_t str2accessmask LDAP_P(( const char *str ));
|
|
|
|
/*
|
|
* attr.c
|
|
*/
|
|
|
|
void attr_free LDAP_P(( Attribute *a ));
|
|
Attribute *attr_dup LDAP_P(( Attribute *a ));
|
|
char * attr_normalize LDAP_P(( char *s ));
|
|
int attr_merge_fast LDAP_P(( Entry *e, char *type, struct berval **vals, int nvals,
|
|
int naddvals, int *maxvals, Attribute ***a ));
|
|
int attr_merge LDAP_P(( Entry *e, char *type, struct berval **vals ));
|
|
Attribute * attr_find LDAP_P(( Attribute *a, const char *type ));
|
|
int attr_delete LDAP_P(( Attribute **attrs, const char *type ));
|
|
int attr_syntax LDAP_P(( char *type ));
|
|
void attr_syntax_config LDAP_P(( const char *fname, int lineno, int argc, char **argv ));
|
|
AttributeType * at_find LDAP_P(( const char *name ));
|
|
int at_find_in_list LDAP_P(( AttributeType *sat, AttributeType **list ));
|
|
int at_append_to_list LDAP_P(( AttributeType *sat, AttributeType ***listp ));
|
|
int at_delete_from_list LDAP_P(( int pos, AttributeType ***listp ));
|
|
int at_fake_if_needed LDAP_P(( char *name ));
|
|
int at_schema_info LDAP_P(( Entry *e ));
|
|
int at_add LDAP_P(( LDAP_ATTRIBUTE_TYPE *at, const char **err ));
|
|
char * at_canonical_name LDAP_P(( char * a_type ));
|
|
|
|
void attrs_free LDAP_P(( Attribute *a ));
|
|
Attribute *attrs_dup LDAP_P(( Attribute *a ));
|
|
|
|
/*
|
|
* ava.c
|
|
*/
|
|
|
|
int get_ava LDAP_P(( BerElement *ber, Ava *ava ));
|
|
void ava_free LDAP_P(( Ava *ava, int freeit ));
|
|
|
|
/*
|
|
* backend.c
|
|
*/
|
|
|
|
int backend_init LDAP_P((void));
|
|
int backend_add LDAP_P((BackendInfo *aBackendInfo));
|
|
int backend_num LDAP_P((Backend *be));
|
|
int backend_startup LDAP_P((Backend *be));
|
|
int backend_shutdown LDAP_P((Backend *be));
|
|
int backend_destroy LDAP_P((void));
|
|
|
|
BackendInfo * backend_info LDAP_P(( const char *type ));
|
|
BackendDB * backend_db_init LDAP_P(( const char *type ));
|
|
|
|
BackendDB * select_backend LDAP_P(( const char * dn ));
|
|
|
|
int be_issuffix LDAP_P(( Backend *be, const char *suffix ));
|
|
int be_isroot LDAP_P(( Backend *be, const char *ndn ));
|
|
int be_isroot_pw LDAP_P(( Backend *be, const char *ndn, struct berval *cred ));
|
|
char* be_root_dn LDAP_P(( Backend *be ));
|
|
int be_entry_release_rw LDAP_P(( Backend *be, Entry *e, int rw ));
|
|
#define be_entry_release_r( be, e ) be_entry_release_rw( be, e, 0 )
|
|
#define be_entry_release_w( be, e ) be_entry_release_rw( be, e, 1 )
|
|
|
|
|
|
extern int backend_unbind LDAP_P((Connection *conn, Operation *op));
|
|
|
|
extern int backend_connection_init LDAP_P((Connection *conn));
|
|
extern int backend_connection_destroy LDAP_P((Connection *conn));
|
|
|
|
extern int backend_group LDAP_P((Backend *be,
|
|
Entry *target,
|
|
const char *gr_ndn,
|
|
const char *op_ndn,
|
|
const char *objectclassValue,
|
|
const char *groupattrName));
|
|
|
|
#ifdef SLAPD_SCHEMA_DN
|
|
/* temporary extern for temporary routine*/
|
|
extern Attribute *backend_subschemasubentry( Backend * );
|
|
#endif
|
|
|
|
|
|
/*
|
|
* ch_malloc.c
|
|
*/
|
|
|
|
#ifdef CSRIMALLOC
|
|
#define ch_malloc malloc
|
|
#define ch_realloc realloc
|
|
#define ch_calloc calloc
|
|
#define ch_strdup strdup
|
|
#define ch_free free
|
|
|
|
#else
|
|
void * ch_malloc LDAP_P(( ber_len_t size ));
|
|
void * ch_realloc LDAP_P(( void *block, ber_len_t size ));
|
|
void * ch_calloc LDAP_P(( ber_len_t nelem, ber_len_t size ));
|
|
char * ch_strdup LDAP_P(( const char *string ));
|
|
void ch_free LDAP_P(( void * ));
|
|
|
|
#ifndef CH_FREE
|
|
#undef free
|
|
#define free ch_free
|
|
#endif
|
|
#endif
|
|
|
|
/*
|
|
* charray.c
|
|
*/
|
|
|
|
void charray_add LDAP_P(( char ***a, const char *s ));
|
|
void charray_merge LDAP_P(( char ***a, char **s ));
|
|
void charray_free LDAP_P(( char **array ));
|
|
int charray_inlist LDAP_P(( char **a, const char *s ));
|
|
char ** charray_dup LDAP_P(( char **a ));
|
|
char ** str2charray LDAP_P(( const char *str, const char *brkstr ));
|
|
char * charray2str LDAP_P(( char **a ));
|
|
|
|
/*
|
|
* controls.c
|
|
*/
|
|
int get_ctrls LDAP_P((
|
|
Connection *co,
|
|
Operation *op,
|
|
int senderrors ));
|
|
|
|
int get_manageDSAit LDAP_P(( Operation *op ));
|
|
|
|
/*
|
|
* config.c
|
|
*/
|
|
|
|
int read_config LDAP_P(( const char *fname ));
|
|
|
|
/*
|
|
* connection.c
|
|
*/
|
|
int connections_init LDAP_P((void));
|
|
int connections_shutdown LDAP_P((void));
|
|
int connections_destroy LDAP_P((void));
|
|
int connections_timeout_idle LDAP_P((time_t));
|
|
|
|
long connection_init LDAP_P((
|
|
ber_socket_t s,
|
|
const char* url,
|
|
const char* dnsname,
|
|
const char* peername,
|
|
const char* sockname,
|
|
int use_tls ));
|
|
|
|
void connection_closing LDAP_P(( Connection *c ));
|
|
int connection_state_closing LDAP_P(( Connection *c ));
|
|
const char *connection_state2str LDAP_P(( int state )) LDAP_GCCATTR((const));
|
|
|
|
int connection_write LDAP_P((ber_socket_t s));
|
|
int connection_read LDAP_P((ber_socket_t s));
|
|
|
|
unsigned long connections_nextid(void);
|
|
|
|
Connection* connection_first LDAP_P((ber_socket_t *));
|
|
Connection* connection_next LDAP_P((Connection *, ber_socket_t *));
|
|
void connection_done LDAP_P((Connection *));
|
|
|
|
/*
|
|
* dn.c
|
|
*/
|
|
|
|
char * dn_validate LDAP_P(( char *dn ));
|
|
char * dn_normalize LDAP_P(( char *dn ));
|
|
char * dn_parent LDAP_P(( Backend *be, const char *dn ));
|
|
char ** dn_subtree LDAP_P(( Backend *be, const char *dn ));
|
|
char * dn_rdn LDAP_P(( Backend *be, char *dn ));
|
|
int dn_issuffix LDAP_P(( char *dn, char *suffix ));
|
|
#ifdef DNS_DN
|
|
int dn_type LDAP_P(( char *dn ));
|
|
#endif
|
|
int rdn_validate LDAP_P(( const char* str ));
|
|
char * rdn_attr_value LDAP_P(( char * rdn ));
|
|
char * rdn_attr_type LDAP_P(( char * rdn ));
|
|
|
|
void build_new_dn LDAP_P(( char ** new_dn,
|
|
const char *e_dn,
|
|
const char * p_dn,
|
|
const char * newrdn ));
|
|
/*
|
|
* entry.c
|
|
*/
|
|
|
|
int entry_destroy LDAP_P((void));
|
|
|
|
Entry * str2entry LDAP_P(( char *s ));
|
|
char * entry2str LDAP_P(( Entry *e, int *len ));
|
|
void entry_free LDAP_P(( Entry *e ));
|
|
|
|
int entry_cmp LDAP_P(( Entry *a, Entry *b ));
|
|
int entry_dn_cmp LDAP_P(( Entry *a, Entry *b ));
|
|
int entry_id_cmp LDAP_P(( Entry *a, Entry *b ));
|
|
|
|
/*
|
|
* filter.c
|
|
*/
|
|
|
|
int get_filter LDAP_P(( Connection *conn, BerElement *ber, Filter **filt, char **fstr ));
|
|
void filter_free LDAP_P(( Filter *f ));
|
|
void filter_print LDAP_P(( Filter *f ));
|
|
|
|
/*
|
|
* filterentry.c
|
|
*/
|
|
|
|
int test_filter LDAP_P(( Backend *be, Connection *conn, Operation *op, Entry *e,
|
|
Filter *f ));
|
|
|
|
/*
|
|
* lock.c
|
|
*/
|
|
|
|
FILE * lock_fopen LDAP_P(( const char *fname, const char *type, FILE **lfp ));
|
|
int lock_fclose LDAP_P(( FILE *fp, FILE *lfp ));
|
|
|
|
/*
|
|
* module.c
|
|
*/
|
|
|
|
#ifdef SLAPD_MODULES
|
|
int module_load LDAP_P(( const char* file_name, int argc, char *argv[] ));
|
|
int module_path LDAP_P(( const char* path ));
|
|
#endif /* SLAPD_MODULES */
|
|
|
|
/*
|
|
* monitor.c
|
|
*/
|
|
extern char *supportedExtensions[];
|
|
extern char *supportedControls[];
|
|
|
|
void monitor_info LDAP_P((
|
|
Connection *conn,
|
|
Operation *op,
|
|
char ** attrs,
|
|
int attrsonly ));
|
|
|
|
/*
|
|
* operation.c
|
|
*/
|
|
|
|
void slap_op_free LDAP_P(( Operation *op ));
|
|
Operation * slap_op_alloc LDAP_P((
|
|
BerElement *ber, ber_int_t msgid,
|
|
ber_tag_t tag, ber_int_t id ));
|
|
|
|
int slap_op_add LDAP_P(( Operation **olist, Operation *op ));
|
|
int slap_op_remove LDAP_P(( Operation **olist, Operation *op ));
|
|
Operation * slap_op_pop LDAP_P(( Operation **olist ));
|
|
|
|
/*
|
|
* phonetic.c
|
|
*/
|
|
|
|
char * first_word LDAP_P(( char *s ));
|
|
char * next_word LDAP_P(( char *s ));
|
|
char * word_dup LDAP_P(( char *w ));
|
|
char * phonetic LDAP_P(( char *s ));
|
|
|
|
/*
|
|
* repl.c
|
|
*/
|
|
|
|
void replog LDAP_P(( Backend *be, Operation *op, char *dn, void *change ));
|
|
|
|
/*
|
|
* result.c
|
|
*/
|
|
|
|
struct berval **get_entry_referrals LDAP_P((
|
|
Backend *be, Connection *conn, Operation *op,
|
|
Entry *e ));
|
|
|
|
void send_ldap_result LDAP_P((
|
|
Connection *conn, Operation *op,
|
|
int err, const char *matched, const char *text,
|
|
struct berval **refs,
|
|
LDAPControl **ctrls ));
|
|
|
|
void send_ldap_disconnect LDAP_P((
|
|
Connection *conn, Operation *op,
|
|
int err, const char *text ));
|
|
|
|
void send_ldap_extended LDAP_P((
|
|
Connection *conn, Operation *op,
|
|
ber_int_t err, const char *matched,
|
|
const char *text, char *rspoid,
|
|
struct berval *rspdata ));
|
|
|
|
void send_search_result LDAP_P((
|
|
Connection *conn, Operation *op,
|
|
int err, const char *matched, const char *text,
|
|
struct berval **refs,
|
|
LDAPControl **ctrls,
|
|
int nentries ));
|
|
|
|
int send_search_reference LDAP_P((
|
|
Backend *be, Connection *conn, Operation *op,
|
|
Entry *e, struct berval **refs, int scope,
|
|
LDAPControl **ctrls,
|
|
struct berval ***v2refs ));
|
|
|
|
int send_search_entry LDAP_P((
|
|
Backend *be, Connection *conn, Operation *op,
|
|
Entry *e, char **attrs, int attrsonly,
|
|
LDAPControl **ctrls ));
|
|
|
|
int str2result LDAP_P(( char *s,
|
|
int *code, char **matched, char **info ));
|
|
|
|
/*
|
|
* sasl.c
|
|
*/
|
|
extern char **supportedSASLMechanisms;
|
|
|
|
int sasl_init(void);
|
|
int sasl_destroy(void);
|
|
|
|
/*
|
|
* schema.c
|
|
*/
|
|
|
|
int oc_schema_check LDAP_P(( Entry *e ));
|
|
int oc_check_operational_attr LDAP_P(( const char *type ));
|
|
int oc_check_usermod_attr LDAP_P(( const char *type ));
|
|
int oc_check_no_usermod_attr LDAP_P(( const char *type ));
|
|
ObjectClass *oc_find LDAP_P((const char *ocname));
|
|
int oc_add LDAP_P((LDAP_OBJECT_CLASS *oc, const char **err));
|
|
Syntax *syn_find LDAP_P((const char *synname));
|
|
Syntax *syn_find_desc LDAP_P((const char *syndesc, int *slen));
|
|
int syn_add LDAP_P((LDAP_SYNTAX *syn, slap_syntax_check_func *check, const char **err));
|
|
MatchingRule *mr_find LDAP_P((const char *mrname));
|
|
int mr_add LDAP_P((LDAP_MATCHING_RULE *mr, slap_mr_normalize_func *normalize, slap_mr_compare_func *compare, const char **err));
|
|
int case_ignore_normalize LDAP_P((struct berval *val, struct berval **normalized));
|
|
int register_syntax LDAP_P((char *desc, slap_syntax_check_func *check ));
|
|
int register_matching_rule LDAP_P((char * desc, slap_mr_normalize_func *normalize, slap_mr_compare_func *compare));
|
|
void schema_info LDAP_P((Connection *conn, Operation *op, char **attrs, int attrsonly));
|
|
int schema_init LDAP_P((void));
|
|
|
|
int is_entry_objectclass LDAP_P(( Entry *, const char* objectclass ));
|
|
#define is_entry_alias(e) is_entry_objectclass((e), "ALIAS")
|
|
#define is_entry_referral(e) is_entry_objectclass((e), "REFERRAL")
|
|
|
|
|
|
/*
|
|
* schemaparse.c
|
|
*/
|
|
|
|
void parse_oc_old LDAP_P(( Backend *be, const char *fname, int lineno, int argc, char **argv ));
|
|
void parse_oc LDAP_P(( const char *fname, int lineno, char *line, char **argv ));
|
|
void parse_at LDAP_P(( const char *fname, int lineno, char *line, char **argv ));
|
|
void parse_oidm LDAP_P(( const char *fname, int lineno, int argc, char **argv ));
|
|
char *scherr2str LDAP_P((int code)) LDAP_GCCATTR((const));
|
|
int dscompare LDAP_P(( const char *s1, const char *s2del, char delim ));
|
|
/*
|
|
* str2filter.c
|
|
*/
|
|
|
|
Filter * str2filter LDAP_P(( char *str ));
|
|
|
|
/*
|
|
* suffixalias.c
|
|
*/
|
|
char *suffix_alias LDAP_P(( Backend *be, char *ndn ));
|
|
|
|
/*
|
|
* value.c
|
|
*/
|
|
|
|
int value_add_fast LDAP_P(( struct berval ***vals, struct berval **addvals, int nvals,
|
|
int naddvals, int *maxvals ));
|
|
int value_add LDAP_P(( struct berval ***vals, struct berval **addvals ));
|
|
void value_normalize LDAP_P(( char *s, int syntax ));
|
|
int value_cmp LDAP_P(( struct berval *v1, struct berval *v2, int syntax,
|
|
int normalize ));
|
|
int value_find LDAP_P(( struct berval **vals, struct berval *v, int syntax,
|
|
int normalize ));
|
|
|
|
/*
|
|
* user.c
|
|
*/
|
|
#if defined(HAVE_PWD_H) && defined(HAVE_GRP_H)
|
|
void slap_init_user LDAP_P(( char *username, char *groupname ));
|
|
#endif
|
|
|
|
/*
|
|
* Other...
|
|
*/
|
|
|
|
extern struct berval **default_referral;
|
|
extern char *replogfile;
|
|
extern const char Versionstr[];
|
|
extern int active_threads;
|
|
extern int defsize;
|
|
extern int deftime;
|
|
extern int g_argc;
|
|
extern slap_access_t global_default_access;
|
|
extern int global_readonly;
|
|
extern int global_lastmod;
|
|
extern int global_idletimeout;
|
|
extern int global_schemacheck;
|
|
extern char *global_realm;
|
|
extern int lber_debug;
|
|
extern int ldap_syslog;
|
|
|
|
extern ldap_pvt_thread_mutex_t num_sent_mutex;
|
|
extern long num_bytes_sent;
|
|
extern long num_pdu_sent;
|
|
extern long num_entries_sent;
|
|
extern long num_refs_sent;
|
|
|
|
extern ldap_pvt_thread_mutex_t num_ops_mutex;
|
|
extern long num_ops_completed;
|
|
extern long num_ops_initiated;
|
|
|
|
extern char *slapd_pid_file;
|
|
extern char *slapd_args_file;
|
|
extern char **g_argv;
|
|
extern time_t starttime;
|
|
|
|
time_t slap_get_time LDAP_P((void));
|
|
|
|
extern ldap_pvt_thread_mutex_t active_threads_mutex;
|
|
extern ldap_pvt_thread_cond_t active_threads_cond;
|
|
|
|
extern ldap_pvt_thread_mutex_t entry2str_mutex;
|
|
extern ldap_pvt_thread_mutex_t replog_mutex;
|
|
|
|
#ifdef SLAPD_CRYPT
|
|
extern ldap_pvt_thread_mutex_t crypt_mutex;
|
|
#endif
|
|
extern ldap_pvt_thread_mutex_t gmtime_mutex;
|
|
|
|
extern AccessControl *global_acl;
|
|
|
|
int slap_init LDAP_P((int mode, char* name));
|
|
int slap_startup LDAP_P(( Backend *be ));
|
|
int slap_shutdown LDAP_P(( Backend *be ));
|
|
int slap_destroy LDAP_P((void));
|
|
|
|
struct sockaddr_in;
|
|
|
|
extern int slapd_daemon_init( char *urls, int port, int tls_port );
|
|
extern int slapd_daemon_destroy(void);
|
|
extern int slapd_daemon(void);
|
|
|
|
extern void slapd_set_write LDAP_P((ber_socket_t s, int wake));
|
|
extern void slapd_clr_write LDAP_P((ber_socket_t s, int wake));
|
|
extern void slapd_set_read LDAP_P((ber_socket_t s, int wake));
|
|
extern void slapd_clr_read LDAP_P((ber_socket_t s, int wake));
|
|
|
|
extern void slapd_remove LDAP_P((ber_socket_t s, int wake));
|
|
|
|
extern RETSIGTYPE slap_sig_shutdown LDAP_P((int sig));
|
|
extern RETSIGTYPE slap_sig_wake LDAP_P((int sig));
|
|
|
|
extern void config_info LDAP_P((
|
|
Connection *conn,
|
|
Operation *op,
|
|
char ** attrs,
|
|
int attrsonly ));
|
|
|
|
extern void root_dse_info LDAP_P((
|
|
Connection *conn,
|
|
Operation *op,
|
|
char ** attrs,
|
|
int attrsonly ));
|
|
|
|
extern int do_abandon LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_add LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_bind LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_compare LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_delete LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_modify LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_modrdn LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_search LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_unbind LDAP_P((Connection *conn, Operation *op));
|
|
extern int do_extended LDAP_P((Connection *conn, Operation *op));
|
|
|
|
extern int load_extension LDAP_P((char *oid, char *libpath, int argc, char **argv));
|
|
|
|
|
|
extern ber_socket_t dtblsize;
|
|
|
|
LDAP_END_DECL
|
|
|
|
#endif /* _proto_slap */
|
|
|