diff options
author | Luke Leighton <lkcl@samba.org> | 1998-05-15 14:50:35 +0000 |
---|---|---|
committer | Luke Leighton <lkcl@samba.org> | 1998-05-15 14:50:35 +0000 |
commit | c230ee1ef64e88c475497ea94894ac67fc11246b (patch) | |
tree | 17f49e2dbeaef3ec3a93ed5f3ba7829fdeaa4ace /source3 | |
parent | 1f94f636538c7c38adfb9c80093b5449630f8a3d (diff) | |
download | samba-c230ee1ef64e88c475497ea94894ac67fc11246b.tar.gz samba-c230ee1ef64e88c475497ea94894ac67fc11246b.tar.bz2 samba-c230ee1ef64e88c475497ea94894ac67fc11246b.zip |
some databases have search capabilities. acknowledging this in design
of passdb.c api.
(This used to be commit 2dd01b7c70f7e1f3158bd4bc75459892007e5418)
Diffstat (limited to 'source3')
-rw-r--r-- | source3/passdb/passdb.c | 79 |
1 files changed, 60 insertions, 19 deletions
diff --git a/source3/passdb/passdb.c b/source3/passdb/passdb.c index 4847149a00..a31f54582a 100644 --- a/source3/passdb/passdb.c +++ b/source3/passdb/passdb.c @@ -207,9 +207,10 @@ BOOL mod_sam21pwd_entry(struct sam_passwd* pwd, BOOL override) **********************************************************/ /************************************************************************ - Routine to search sam passwd by name. + Routine to search sam passwd by name. use this if your database + does not have search facilities. *************************************************************************/ -struct smb_passwd *getsampwnam(char *name) +static struct smb_passwd *_getsampwnam(char *name) { struct smb_passwd *pwd = NULL; void *fp = NULL; @@ -239,7 +240,20 @@ struct smb_passwd *getsampwnam(char *name) /************************************************************************ Routine to search sam passwd by name. *************************************************************************/ -struct sam_passwd *getsam21pwnam(char *name) +struct smb_passwd *getsampwnam(char *name) +{ +#ifdef USE_LDAP + return _getsampwnam(name); +#else + return _getsampwnam(name); +#endif /* USE_LDAP */ +} + +/************************************************************************ + Routine to search sam passwd by name. use this if your database + does not have search facilities. +*************************************************************************/ +static struct sam_passwd *_getsam21pwnam(char *name) { struct sam_passwd *pwd = NULL; void *fp = NULL; @@ -267,9 +281,22 @@ struct sam_passwd *getsam21pwnam(char *name) } /************************************************************************ - Routine to search sam passwd by uid. + Routine to search sam passwd by name. *************************************************************************/ -struct smb_passwd *getsampwuid(uid_t smb_userid) +struct sam_passwd *getsam21pwnam(char *name) +{ +#ifdef USE_LDAP + return _getsam21pwnam(name); +#else + return _getsam21pwnam(name); +#endif /* USE_LDAP */ +} + +/************************************************************************ + Routine to search sam passwd by uid. use this if your database + does not have search facilities. +*************************************************************************/ +static struct smb_passwd *_getsampwuid(uid_t smb_userid) { struct smb_passwd *pwd = NULL; void *fp = NULL; @@ -297,9 +324,23 @@ struct smb_passwd *getsampwuid(uid_t smb_userid) } /************************************************************************ - Routine to search sam passwd by rid. + Routine to search sam passwd by uid. *************************************************************************/ -struct sam_passwd *getsam21pwrid(uint32 rid) +struct smb_passwd *getsampwuid(uid_t smb_userid) +{ +#ifdef USE_LDAP + return _getsampwuid(smb_userid); +#else + return _getsampwuid(smb_userid); +#endif /* USE_LDAP */ +} + + +/************************************************************************ + Routine to search sam passwd by rid. use this if your database + does not have search facilities. +*************************************************************************/ +struct sam_passwd *_getsam21pwrid(uint32 rid) { struct sam_passwd *pwd = NULL; void *fp = NULL; @@ -326,6 +367,18 @@ struct sam_passwd *getsam21pwrid(uint32 rid) return pwd; } +/************************************************************************ + Routine to search sam passwd by rid. +*************************************************************************/ +struct sam_passwd *getsam21pwrid(uint32 rid) +{ +#ifdef USE_LDAP + return _getsam21pwrid(rid); +#else + return _getsam21pwrid(rid); +#endif /* USE_LDAP */ +} + /********************************************************** ********************************************************** @@ -667,9 +720,6 @@ Error was %s\n", sid_file, strerror(errno) )); } /******************************************************************* - XXXX THIS FUNCTION SHOULD NOT BE HERE: IT SHOULD BE A STATIC FUNCTION - INSIDE smbpass.c - converts NT User RID to a UNIX uid. ********************************************************************/ uid_t user_rid_to_uid(uint32 u_rid) @@ -678,9 +728,6 @@ uid_t user_rid_to_uid(uint32 u_rid) } /******************************************************************* - XXXX THIS FUNCTION SHOULD NOT BE HERE: IT SHOULD BE A STATIC FUNCTION - INSIDE smbpass.c - converts NT Group RID to a UNIX uid. ********************************************************************/ uid_t group_rid_to_uid(uint32 u_gid) @@ -689,9 +736,6 @@ uid_t group_rid_to_uid(uint32 u_gid) } /******************************************************************* - XXXX THIS FUNCTION SHOULD NOT BE HERE: IT SHOULD BE A STATIC FUNCTION - INSIDE smbpass.c - converts UNIX uid to an NT User RID. ********************************************************************/ uint32 uid_to_user_rid(uint32 uid) @@ -700,9 +744,6 @@ uint32 uid_to_user_rid(uint32 uid) } /******************************************************************* - XXXX THIS FUNCTION SHOULD NOT BE HERE: IT SHOULD BE A STATIC FUNCTION - INSIDE smbpass.c - converts NT Group RID to a UNIX uid. ********************************************************************/ uint32 gid_to_group_rid(uint32 gid) |