Arthur de Jong

Open Source / Free Software developer

summaryrefslogtreecommitdiffstats
path: root/nss/passwd.c
diff options
context:
space:
mode:
authorArthur de Jong <arthur@arthurdejong.org>2006-11-16 13:50:27 +0100
committerArthur de Jong <arthur@arthurdejong.org>2006-11-16 13:50:27 +0100
commit4bbb60e380e068cf4bd49e8468957c55a5199259 (patch)
tree6c121042348f99ee3392c56c1e3ff72a2f3efe7f /nss/passwd.c
parentfc0578b5d55645ad060f3a64697a2ed79e88e8e6 (diff)
switch to a simpler and more compact framework to generate methods (one reader function to deserialize a struct from the stream and auto-generated functions)
git-svn-id: http://arthurdejong.org/svn/nss-pam-ldapd/libnss_ldapd@92 ef36b2f9-881f-0410-afb5-c4e39611909c
Diffstat (limited to 'nss/passwd.c')
-rw-r--r--nss/passwd.c43
1 files changed, 12 insertions, 31 deletions
diff --git a/nss/passwd.c b/nss/passwd.c
index 4862ad5..c544ec8 100644
--- a/nss/passwd.c
+++ b/nss/passwd.c
@@ -41,44 +41,25 @@
#define PASSWD_DIR result->pw_dir
#define PASSWD_SHELL result->pw_shell
-enum nss_status _nss_ldap_getpwnam_r(const char *name,struct passwd *result,char *buffer,size_t buflen,int *errnop)
+
+static enum nss_status read_passwd(
+ FILE *fp,struct passwd *result,
+ char *buffer,size_t buflen,int *errnop)
{
- FILE *fp;
- size_t bufptr=0;
int32_t tmpint32;
- /* open socket and write request */
- OPEN_SOCK(fp);
- WRITE_REQUEST(fp,NSLCD_ACTION_PASSWD_BYNAME);
- WRITE_STRING(fp,name);
- WRITE_FLUSH(fp);
- /* read response header */
- READ_RESPONSEHEADER(fp,NSLCD_ACTION_PASSWD_BYNAME);
- /* read response */
- READ_RESPONSE_CODE(fp);
+ size_t bufptr=0;
LDF_PASSWD;
- /* close socket and we're done */
- fclose(fp);
return NSS_STATUS_SUCCESS;
}
+enum nss_status _nss_ldap_getpwnam_r(const char *name,struct passwd *result,char *buffer,size_t buflen,int *errnop)
+{
+ NSS_BYNAME(NSLCD_ACTION_PASSWD_BYNAME,name,read_passwd);
+}
+
enum nss_status _nss_ldap_getpwuid_r(uid_t uid,struct passwd *result,char *buffer,size_t buflen,int *errnop)
{
- FILE *fp;
- size_t bufptr=0;
- int32_t tmpint32;
- /* open socket and write request */
- OPEN_SOCK(fp);
- WRITE_REQUEST(fp,NSLCD_ACTION_PASSWD_BYUID);
- WRITE_TYPE(fp,uid,uid_t);
- WRITE_FLUSH(fp);
- /* read response header */
- READ_RESPONSEHEADER(fp,NSLCD_ACTION_PASSWD_BYUID);
- /* read response */
- READ_RESPONSE_CODE(fp);
- LDF_PASSWD;
- /* close socket and we're done */
- fclose(fp);
- return NSS_STATUS_SUCCESS;
+ NSS_BYTYPE(NSLCD_ACTION_PASSWD_BYUID,uid,uid_t,read_passwd);
}
/* thread-local file pointer to an ongoing request */
@@ -94,7 +75,7 @@ enum nss_status _nss_ldap_setpwent(int stayopen)
/* read password data from an opened stream */
enum nss_status _nss_ldap_getpwent_r(struct passwd *result,char *buffer,size_t buflen,int *errnop)
{
- NSS_GETENT(LDF_PASSWD);
+ NSS_GETENT(read_passwd);
}
/* close the stream opened with setpwent() above */