wbinfo: Improve the wording for --online-status
[sfrench/samba-autobuild/.git] / nsswitch / winbind_nss_solaris.c
index 5fb37643ce2c92cfe55a87d96f9bf114f4fba954..eb1ddb0f8b0f78458c9acdb81a9a7cf9caa1a5b2 100644 (file)
 
 #undef DEVELOPER
 
+
 #include "winbind_client.h"
 #include <stdlib.h>
 #include <sys/types.h>
 #include <sys/param.h>
 #include <string.h>
 #include <pwd.h>
-#include "includes.h"
 #include <syslog.h>
+
 #if !defined(HPUX)
 #include <sys/syslog.h>
 #endif /*hpux*/
 #define NSS_DEBUG(str) ;
 #endif
 
+#if !defined(SMB_MALLOC_P)
+#define SMB_MALLOC_P(type) (type *)malloc(sizeof(type))
+#endif
+
 #define NSS_ARGS(args) ((nss_XbyY_args_t *)args)
 
 #ifdef HPUX
@@ -72,17 +77,6 @@ struct nss_groupsbymem {
 
 #endif /* HPUX */
 
-#define make_pwent_str(dest, src)                                      \
-{                                                                      \
-  if((dest = get_static(buffer, buflen, strlen(src)+1)) == NULL)       \
-    {                                                                  \
-      *errnop = ERANGE;                                                        \
-      NSS_DEBUG("ERANGE error");                                       \
-      return NSS_STATUS_TRYAGAIN;                                      \
-    }                                                                  \
-  strcpy(dest, src);                                                   \
-}
-
 static NSS_STATUS _nss_winbind_setpwent_solwrap (nss_backend_t* be, void* args)
 {
        NSS_DEBUG("_nss_winbind_setpwent_solwrap");
@@ -254,6 +248,9 @@ _nss_winbind_getgrnam_solwrap(nss_backend_t* be, void* args)
        if(ret == NSS_STATUS_SUCCESS)
                NSS_ARGS(args)->returnval = (void*) result;
 
+       if (NSS_ARGS(args)->erange == ERANGE && ret == NSS_STATUS_TRYAGAIN)
+               return NSS_STATUS_UNAVAIL;
+
        return ret;
 }
 
@@ -273,6 +270,9 @@ _nss_winbind_getgrgid_solwrap(nss_backend_t* be, void* args)
        if(ret == NSS_STATUS_SUCCESS)
                NSS_ARGS(args)->returnval = (void*) result;
 
+       if (NSS_ARGS(args)->erange == ERANGE && ret == NSS_STATUS_TRYAGAIN)
+               return NSS_STATUS_UNAVAIL;
+
        return ret;
 }
 
@@ -510,7 +510,8 @@ _nss_winbind_ipnodes_getbyname(nss_backend_t* be, void *args)
        strncpy(request.data.winsreq, argp->key.name, sizeof(request.data.winsreq) - 1);
        request.data.winsreq[sizeof(request.data.winsreq) - 1] = '\0';
 
-       if( (ret = winbindd_request_response(WINBINDD_WINS_BYNAME, &request, &response))
+       if( (ret = winbindd_request_response(NULL, WINBINDD_WINS_BYNAME,
+                                            &request, &response))
                == NSS_STATUS_SUCCESS ) {
          ret = parse_response(af, argp, &response);
        }
@@ -533,7 +534,8 @@ _nss_winbind_hosts_getbyname(nss_backend_t* be, void *args)
        strncpy(request.data.winsreq, argp->key.name, sizeof(request.data.winsreq) - 1);
        request.data.winsreq[sizeof(request.data.winsreq) - 1] = '\0';
 
-       if( (ret = winbindd_request_response(WINBINDD_WINS_BYNAME, &request, &response))
+       if( (ret = winbindd_request_response(NULL, WINBINDD_WINS_BYNAME,
+                                            &request, &response))
                == NSS_STATUS_SUCCESS ) {
          ret = parse_response(AF_INET, argp, &response);
        }
@@ -572,7 +574,8 @@ _nss_winbind_hosts_getbyaddr(nss_backend_t* be, void *args)
                 ((unsigned char *)argp->key.hostaddr.addr)[3]);
 #endif
 
-       ret = winbindd_request_response(WINBINDD_WINS_BYIP, &request, &response);
+       ret = winbindd_request_response(NULL, WINBINDD_WINS_BYIP,
+                                       &request, &response);
 
        if( ret == NSS_STATUS_SUCCESS) {
          parse_response(argp->key.hostaddr.type, argp, &response);