diff options
author | Arthur de Jong <arthur@arthurdejong.org> | 2006-11-16 13:50:27 +0100 |
---|---|---|
committer | Arthur de Jong <arthur@arthurdejong.org> | 2006-11-16 13:50:27 +0100 |
commit | 4bbb60e380e068cf4bd49e8468957c55a5199259 (patch) | |
tree | 6c121042348f99ee3392c56c1e3ff72a2f3efe7f /nss/passwd.c | |
parent | fc0578b5d55645ad060f3a64697a2ed79e88e8e6 (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.c | 43 |
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 */ |