2003-06-05 02:34:30 +00:00
/*
2005-09-30 17:13:37 +00:00
Unix SMB / CIFS mplementation .
2003-06-05 02:34:30 +00:00
LDAP protocol helper functions for SAMBA
Copyright ( C ) Gerald Carter 2001 - 2003
2009-05-31 11:14:06 +02:00
2003-06-05 02:34:30 +00:00
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-09 19:25:36 +00:00
the Free Software Foundation ; either version 3 of the License , or
2003-06-05 02:34:30 +00:00
( at your option ) any later version .
2009-05-31 11:14:06 +02:00
2003-06-05 02:34:30 +00:00
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
2009-05-31 11:14:06 +02:00
2003-06-05 02:34:30 +00:00
You should have received a copy of the GNU General Public License
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2009-05-31 11:14:06 +02:00
2003-06-05 02:34:30 +00:00
*/
# ifndef _SMBLDAP_H
# define _SMBLDAP_H
2011-10-17 17:17:18 +02:00
# include "include/smb_ldap.h"
2011-02-24 11:56:08 +01:00
2003-06-25 12:51:58 +00:00
# ifdef HAVE_LDAP
2011-11-16 22:50:18 +01:00
# include <talloc.h>
# include <tevent.h>
2003-06-25 12:51:58 +00:00
/**
* Struct to keep the state for all the ldap stuff
*
*/
struct smbldap_state {
LDAP * ldap_struct ;
2004-11-05 22:53:35 +00:00
pid_t pid ;
2010-09-07 01:04:10 +02:00
time_t last_ping ; /* monotonic */
2003-06-25 12:51:58 +00:00
/* retrive-once info */
const char * uri ;
2006-12-12 14:52:13 +00:00
/* credentials */
2007-10-18 17:40:25 -07:00
bool anonymous ;
2003-06-25 12:51:58 +00:00
char * bind_dn ;
char * bind_secret ;
2006-12-12 14:52:13 +00:00
2007-10-18 17:40:25 -07:00
bool paged_results ;
2003-06-25 12:51:58 +00:00
unsigned int num_failures ;
2003-07-17 11:24:54 +00:00
2010-09-07 01:04:10 +02:00
time_t last_use ; /* monotonic */
2011-10-27 16:19:07 +02:00
struct tevent_context * tevent_context ;
2007-03-11 16:49:16 +00:00
struct timed_event * idle_event ;
2003-12-25 22:42:15 +00:00
2010-09-07 01:04:10 +02:00
struct timeval last_rebind ; /* monotonic */
2003-06-25 12:51:58 +00:00
} ;
2003-06-06 20:31:19 +00:00
2005-03-05 01:22:53 +00:00
/* struct used by both pdb_ldap.c and pdb_nds.c */
2010-09-03 09:39:45 +02:00
struct ipasam_privates ;
2005-03-05 01:22:53 +00:00
struct ldapsam_privates {
struct smbldap_state * smbldap_state ;
/* Former statics */
LDAPMessage * result ;
LDAPMessage * entry ;
int index ;
const char * domain_name ;
2010-05-21 11:25:01 +10:00
struct dom_sid domain_sid ;
2005-03-05 01:22:53 +00:00
/* configuration items */
int schema_ver ;
char * domain_dn ;
/* Is this NDS ldap? */
int is_nds_ldap ;
2010-07-14 15:08:02 +02:00
/* Is this IPA ldap? */
int is_ipa_ldap ;
2010-09-03 09:39:45 +02:00
struct ipasam_privates * ipasam_privates ;
2010-07-14 15:08:02 +02:00
2005-03-05 01:22:53 +00:00
/* ldap server location parameter */
char * location ;
2010-02-03 11:32:41 +01:00
struct {
char * filter ;
LDAPMessage * result ;
} search_cache ;
2005-03-05 01:22:53 +00:00
} ;
2010-08-26 14:07:20 +02:00
/* The following definitions come from lib/smbldap.c */
2011-11-16 18:59:26 +01:00
NTSTATUS smbldap_init ( TALLOC_CTX * mem_ctx ,
struct tevent_context * tevent_ctx ,
const char * location ,
bool anon ,
const char * bind_dn ,
const char * bind_secret ,
struct smbldap_state * * smbldap_state ) ;
void smbldap_set_mod ( LDAPMod * * * modlist , int modop , const char * attribute , const char * value ) ;
void smbldap_set_mod_blob ( LDAPMod * * * modlist , int modop , const char * attribute , const DATA_BLOB * newblob ) ;
void smbldap_make_mod ( LDAP * ldap_struct , LDAPMessage * existing ,
LDAPMod * * * mods ,
const char * attribute , const char * newval ) ;
void smbldap_make_mod_blob ( LDAP * ldap_struct , LDAPMessage * existing ,
LDAPMod * * * mods ,
const char * attribute , const DATA_BLOB * newblob ) ;
bool smbldap_get_single_attribute ( LDAP * ldap_struct , LDAPMessage * entry ,
const char * attribute , char * value ,
int max_len ) ;
int smbldap_modify ( struct smbldap_state * ldap_state ,
const char * dn ,
LDAPMod * attrs [ ] ) ;
2010-08-26 14:07:20 +02:00
int smb_ldap_start_tls ( LDAP * ldap_struct , int version ) ;
int smb_ldap_setup_full_conn ( LDAP * * ldap_struct , const char * uri ) ;
int smbldap_search ( struct smbldap_state * ldap_state ,
const char * base , int scope , const char * filter ,
const char * attrs [ ] , int attrsonly ,
LDAPMessage * * res ) ;
int smbldap_search_paged ( struct smbldap_state * ldap_state ,
const char * base , int scope , const char * filter ,
const char * * attrs , int attrsonly , int pagesize ,
LDAPMessage * * res , void * * cookie ) ;
int smbldap_modify ( struct smbldap_state * ldap_state , const char * dn , LDAPMod * attrs [ ] ) ;
int smbldap_add ( struct smbldap_state * ldap_state , const char * dn , LDAPMod * attrs [ ] ) ;
int smbldap_delete ( struct smbldap_state * ldap_state , const char * dn ) ;
int smbldap_extended_operation ( struct smbldap_state * ldap_state ,
LDAP_CONST char * reqoid , struct berval * reqdata ,
LDAPControl * * serverctrls , LDAPControl * * clientctrls ,
char * * retoidp , struct berval * * retdatap ) ;
int smbldap_search_suffix ( struct smbldap_state * ldap_state ,
const char * filter , const char * * search_attr ,
LDAPMessage * * result ) ;
void smbldap_free_struct ( struct smbldap_state * * ldap_state ) ;
bool smbldap_has_control ( LDAP * ld , const char * control ) ;
bool smbldap_has_extension ( LDAP * ld , const char * extension ) ;
bool smbldap_has_naming_context ( LDAP * ld , const char * naming_context ) ;
bool smbldap_set_creds ( struct smbldap_state * ldap_state , bool anon , const char * dn , const char * secret ) ;
2011-10-10 18:46:53 +02:00
char * smbldap_talloc_single_attribute ( LDAP * ldap_struct , LDAPMessage * entry ,
const char * attribute ,
TALLOC_CTX * mem_ctx ) ;
char * smbldap_talloc_first_attribute ( LDAP * ldap_struct , LDAPMessage * entry ,
const char * attribute ,
TALLOC_CTX * mem_ctx ) ;
char * smbldap_talloc_smallest_attribute ( LDAP * ldap_struct , LDAPMessage * entry ,
const char * attribute ,
TALLOC_CTX * mem_ctx ) ;
bool smbldap_talloc_single_blob ( TALLOC_CTX * mem_ctx , LDAP * ld ,
LDAPMessage * msg , const char * attrib ,
DATA_BLOB * blob ) ;
bool smbldap_pull_sid ( LDAP * ld , LDAPMessage * msg , const char * attrib ,
struct dom_sid * sid ) ;
void talloc_autofree_ldapmsg ( TALLOC_CTX * mem_ctx , LDAPMessage * result ) ;
void talloc_autofree_ldapmod ( TALLOC_CTX * mem_ctx , LDAPMod * * mod ) ;
char * smbldap_talloc_dn ( TALLOC_CTX * mem_ctx , LDAP * ld ,
LDAPMessage * entry ) ;
2010-08-26 14:07:20 +02:00
2005-08-13 12:05:54 +00:00
# endif /* HAVE_LDAP */
2003-06-25 12:51:58 +00:00
2004-07-01 16:35:43 +00:00
# endif /* _SMBLDAP_H */