mirror of
https://github.com/samba-team/samba.git
synced 2024-12-27 03:21:53 +03:00
9ec9df5fe4
Not strictly a bugfix, but it should considerably reduce the load we
put on LDAP servers given that at least nss_ldap on Linux keeps a
connection open.
And it should also stress our reconnect-code a bit more ;-)
Thanks to metze for this!
Volker
(This used to be commit e68d8eabeb
)
146 lines
4.2 KiB
C
146 lines
4.2 KiB
C
/*
|
|
Unix SMB/CIFS mplementation.
|
|
LDAP protocol helper functions for SAMBA
|
|
Copyright (C) Gerald Carter 2001-2003
|
|
|
|
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
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
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.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
*/
|
|
|
|
#ifndef _SMBLDAP_H
|
|
#define _SMBLDAP_H
|
|
|
|
#ifdef HAVE_LDAP
|
|
|
|
/* specify schema versions between 2.2. and 3.0 */
|
|
|
|
#define SCHEMAVER_SAMBAACCOUNT 1
|
|
#define SCHEMAVER_SAMBASAMACCOUNT 2
|
|
|
|
/* objectclass names */
|
|
|
|
#define LDAP_OBJ_SAMBASAMACCOUNT "sambaSamAccount"
|
|
#define LDAP_OBJ_SAMBAACCOUNT "sambaAccount"
|
|
#define LDAP_OBJ_GROUPMAP "sambaGroupMapping"
|
|
#define LDAP_OBJ_DOMINFO "sambaDomain"
|
|
#define LDAP_OBJ_IDPOOL "sambaUnixIdPool"
|
|
#define LDAP_OBJ_IDMAP_ENTRY "sambaIdmapEntry"
|
|
#define LDAP_OBJ_SID_ENTRY "sambaSidEntry"
|
|
|
|
#define LDAP_OBJ_ACCOUNT "account"
|
|
#define LDAP_OBJ_POSIXACCOUNT "posixAccount"
|
|
#define LDAP_OBJ_POSIXGROUP "posixGroup"
|
|
#define LDAP_OBJ_OU "organizationalUnit"
|
|
|
|
/* some generic attributes that get reused a lot */
|
|
|
|
#define LDAP_ATTRIBUTE_SID "sambaSID"
|
|
#define LDAP_ATTRIBUTE_UIDNUMBER "uidNumber"
|
|
#define LDAP_ATTRIBUTE_GIDNUMBER "gidNumber"
|
|
|
|
/* attribute map table indexes */
|
|
|
|
#define LDAP_ATTR_LIST_END 0
|
|
#define LDAP_ATTR_UID 1
|
|
#define LDAP_ATTR_UIDNUMBER 2
|
|
#define LDAP_ATTR_GIDNUMBER 3
|
|
#define LDAP_ATTR_UNIX_HOME 4
|
|
#define LDAP_ATTR_PWD_LAST_SET 5
|
|
#define LDAP_ATTR_PWD_CAN_CHANGE 6
|
|
#define LDAP_ATTR_PWD_MUST_CHANGE 7
|
|
#define LDAP_ATTR_LOGON_TIME 8
|
|
#define LDAP_ATTR_LOGOFF_TIME 9
|
|
#define LDAP_ATTR_KICKOFF_TIME 10
|
|
#define LDAP_ATTR_CN 11
|
|
#define LDAP_ATTR_DISPLAY_NAME 12
|
|
#define LDAP_ATTR_HOME_PATH 13
|
|
#define LDAP_ATTR_LOGON_SCRIPT 14
|
|
#define LDAP_ATTR_PROFILE_PATH 15
|
|
#define LDAP_ATTR_DESC 16
|
|
#define LDAP_ATTR_USER_WKS 17
|
|
#define LDAP_ATTR_USER_SID 18
|
|
#define LDAP_ATTR_USER_RID 18
|
|
#define LDAP_ATTR_PRIMARY_GROUP_SID 19
|
|
#define LDAP_ATTR_PRIMARY_GROUP_RID 20
|
|
#define LDAP_ATTR_LMPW 21
|
|
#define LDAP_ATTR_NTPW 22
|
|
#define LDAP_ATTR_DOMAIN 23
|
|
#define LDAP_ATTR_OBJCLASS 24
|
|
#define LDAP_ATTR_ACB_INFO 25
|
|
#define LDAP_ATTR_NEXT_USERRID 26
|
|
#define LDAP_ATTR_NEXT_GROUPRID 27
|
|
#define LDAP_ATTR_DOM_SID 28
|
|
#define LDAP_ATTR_HOME_DRIVE 29
|
|
#define LDAP_ATTR_GROUP_SID 30
|
|
#define LDAP_ATTR_GROUP_TYPE 31
|
|
#define LDAP_ATTR_SID 32
|
|
#define LDAP_ATTR_ALGORITHMIC_RID_BASE 33
|
|
#define LDAP_ATTR_NEXT_RID 34
|
|
|
|
typedef struct _attrib_map_entry {
|
|
int attrib;
|
|
const char *name;
|
|
} ATTRIB_MAP_ENTRY;
|
|
|
|
|
|
/* structures */
|
|
|
|
extern ATTRIB_MAP_ENTRY attrib_map_v22[];
|
|
extern ATTRIB_MAP_ENTRY attrib_map_v30[];
|
|
extern ATTRIB_MAP_ENTRY dominfo_attr_list[];
|
|
extern ATTRIB_MAP_ENTRY groupmap_attr_list[];
|
|
extern ATTRIB_MAP_ENTRY groupmap_attr_list_to_delete[];
|
|
extern ATTRIB_MAP_ENTRY idpool_attr_list[];
|
|
extern ATTRIB_MAP_ENTRY sidmap_attr_list[];
|
|
|
|
/* Function declarations -- not included in proto.h so we don't
|
|
have to worry about LDAP structure types */
|
|
|
|
const char* get_attr_key2string( ATTRIB_MAP_ENTRY table[], int key );
|
|
char** get_attr_list( ATTRIB_MAP_ENTRY table[] );
|
|
void free_attr_list( char **list );
|
|
void smbldap_set_mod (LDAPMod *** modlist, int modop, const char *attribute, const char *value);
|
|
void smbldap_make_mod(LDAP *ldap_struct, LDAPMessage *existing,
|
|
LDAPMod ***mods,
|
|
const char *attribute, const char *newval);
|
|
BOOL smbldap_get_single_attribute (LDAP * ldap_struct, LDAPMessage * entry,
|
|
const char *attribute, pstring value);
|
|
|
|
/**
|
|
* Struct to keep the state for all the ldap stuff
|
|
*
|
|
*/
|
|
|
|
struct smbldap_state {
|
|
LDAP *ldap_struct;
|
|
time_t last_ping;
|
|
/* retrive-once info */
|
|
const char *uri;
|
|
char *bind_dn;
|
|
char *bind_secret;
|
|
|
|
unsigned int num_failures;
|
|
|
|
time_t last_use;
|
|
smb_event_id_t event_id;
|
|
};
|
|
|
|
#endif /* HAVE_LDAP */
|
|
|
|
struct smbldap_state;
|
|
|
|
#endif /* _SMBLDAP_H */
|
|
|