9c73bd
From 53f7f75ebf2a5086d63989bdf1da0d42983d6448 Mon Sep 17 00:00:00 2001
9c73bd
From: Alexander Bokovoy <abokovoy@redhat.com>
9c73bd
Date: Fri, 3 Nov 2017 23:49:19 +0200
9c73bd
Subject: [PATCH 17/18] Fix nss_sss callers
9c73bd
9c73bd
---
9c73bd
 src/back-sch-nss_sss.c | 82 +++++++++++++++++++++++++++++++++++---------------
9c73bd
 1 file changed, 57 insertions(+), 25 deletions(-)
9c73bd
9c73bd
diff --git a/src/back-sch-nss_sss.c b/src/back-sch-nss_sss.c
9c73bd
index e3e6628..2b1b8b0 100644
9c73bd
--- a/src/back-sch-nss_sss.c
9c73bd
+++ b/src/back-sch-nss_sss.c
9c73bd
@@ -52,6 +52,20 @@ struct nss_ops_ctx {
9c73bd
 			      int *errnop);
9c73bd
 };
9c73bd
 
9c73bd
+void backend_nss_free_context(struct nss_ops_ctx **nss_context)
9c73bd
+{
9c73bd
+	if (nss_context == NULL) {
9c73bd
+		return;
9c73bd
+	}
9c73bd
+
9c73bd
+	if ((*nss_context)->dl_handle != NULL) {
9c73bd
+		dlclose((*nss_context)->dl_handle);
9c73bd
+	}
9c73bd
+
9c73bd
+	free((*nss_context));
9c73bd
+	*nss_context = NULL;
9c73bd
+}
9c73bd
+
9c73bd
 void backend_nss_init_context(struct nss_ops_ctx **nss_context)
9c73bd
 {
9c73bd
 	struct nss_ops_ctx *ctx = NULL;
9c73bd
@@ -105,21 +119,6 @@ fail:
9c73bd
 	return;
9c73bd
 }
9c73bd
 
9c73bd
-void
9c73bd
-backend_nss_free_context(struct nss_ops_ctx **nss_context)
9c73bd
-{
9c73bd
-	if (nss_context == NULL) {
9c73bd
-		return;
9c73bd
-	}
9c73bd
-
9c73bd
-	if ((*nss_context)->dl_handle != NULL) {
9c73bd
-		dlclose((*nss_context)->dl_handle);
9c73bd
-	}
9c73bd
-
9c73bd
-	free((*nss_context));
9c73bd
-	*nss_context = NULL;
9c73bd
-}
9c73bd
-
9c73bd
 
9c73bd
 /* Following three functions cannot be implemented with nss_sss.so.2
9c73bd
  * As result, we simply do nothing here */
9c73bd
@@ -144,15 +143,22 @@ enum nss_status backend_nss_getpwnam(struct nss_ops_ctx *nss_context,
9c73bd
 				     char *buffer, size_t buflen,
9c73bd
 				     struct passwd **result,
9c73bd
 				     int *lerrno) {
9c73bd
+	enum nss_status ret;
9c73bd
 
9c73bd
 	if (nss_context == NULL) {
9c73bd
 		return NSS_STATUS_UNAVAIL;
9c73bd
 	}
9c73bd
 
9c73bd
-	return (enum nss_status)
9c73bd
+	ret = (enum nss_status)
9c73bd
 		nss_context->getpwnam_r(name, pwd,
9c73bd
 					buffer, buflen,
9c73bd
-					result, lerrno);
9c73bd
+					lerrno);
9c73bd
+
9c73bd
+	if ((ret == NSS_STATUS_SUCCESS) && (result != NULL)) {
9c73bd
+		*result = pwd;
9c73bd
+	}
9c73bd
+
9c73bd
+	return ret;
9c73bd
 }
9c73bd
 
9c73bd
 enum nss_status backend_nss_getpwuid(struct nss_ops_ctx *nss_context,
9c73bd
@@ -160,15 +166,22 @@ enum nss_status backend_nss_getpwuid(struct nss_ops_ctx *nss_context,
9c73bd
 				     char *buffer, size_t buflen,
9c73bd
 				     struct passwd **result,
9c73bd
 				     int *lerrno) {
9c73bd
+	enum nss_status ret;
9c73bd
 
9c73bd
 	if (nss_context == NULL) {
9c73bd
 		return NSS_STATUS_UNAVAIL;
9c73bd
 	}
9c73bd
 
9c73bd
-	return (enum nss_status)
9c73bd
+	ret = (enum nss_status)
9c73bd
 		nss_context->getpwuid_r(uid, pwd,
9c73bd
 					buffer, buflen,
9c73bd
-					result, lerrno);
9c73bd
+					lerrno);
9c73bd
+
9c73bd
+	if ((ret == NSS_STATUS_SUCCESS) && (result != NULL)) {
9c73bd
+		*result = pwd;
9c73bd
+	}
9c73bd
+
9c73bd
+	return ret;
9c73bd
 }
9c73bd
 
9c73bd
 enum nss_status backend_nss_getgrnam(struct nss_ops_ctx *nss_context,
9c73bd
@@ -176,15 +189,22 @@ enum nss_status backend_nss_getgrnam(struct nss_ops_ctx *nss_context,
9c73bd
 				     char *buffer, size_t buflen,
9c73bd
 				     struct group **result,
9c73bd
 				     int *lerrno) {
9c73bd
+	enum nss_status ret;
9c73bd
 
9c73bd
 	if (nss_context == NULL) {
9c73bd
 		return NSS_STATUS_UNAVAIL;
9c73bd
 	}
9c73bd
 
9c73bd
-	return (enum nss_status)
9c73bd
+	ret = (enum nss_status)
9c73bd
 		nss_context->getgrnam_r(name, grp,
9c73bd
 					buffer, buflen,
9c73bd
-					result, lerrno);
9c73bd
+					lerrno);
9c73bd
+
9c73bd
+	if ((ret == NSS_STATUS_SUCCESS) && (result != NULL)) {
9c73bd
+		*result = grp;
9c73bd
+	}
9c73bd
+
9c73bd
+	return ret;
9c73bd
 }
9c73bd
 
9c73bd
 enum nss_status backend_nss_getgrgid(struct nss_ops_ctx *nss_context,
9c73bd
@@ -193,21 +213,31 @@ enum nss_status backend_nss_getgrgid(struct nss_ops_ctx *nss_context,
9c73bd
 				     struct group **result,
9c73bd
 				     int *lerrno) {
9c73bd
 
9c73bd
+	enum nss_status ret;
9c73bd
+
9c73bd
 	if (nss_context == NULL) {
9c73bd
 		return NSS_STATUS_UNAVAIL;
9c73bd
 	}
9c73bd
 
9c73bd
-	return (enum nss_status)
9c73bd
+	ret = (enum nss_status)
9c73bd
 		nss_context->getgrgid_r(gid, grp,
9c73bd
 					buffer, buflen,
9c73bd
-					result, lerrno);
9c73bd
+					lerrno);
9c73bd
+
9c73bd
+	if ((ret == NSS_STATUS_SUCCESS) && (result != NULL)) {
9c73bd
+		*result = grp;
9c73bd
+	}
9c73bd
+
9c73bd
+	return ret;
9c73bd
 }
9c73bd
 
9c73bd
 enum nss_status backend_nss_getgrouplist(struct nss_ops_ctx *nss_context,
9c73bd
 					 const char *name, gid_t group,
9c73bd
 					 gid_t *groups, int *ngroups,
9c73bd
 					 int *lerrno) {
9c73bd
+
9c73bd
 	enum nss_status ret = NSS_STATUS_UNAVAIL;
9c73bd
+	long int size = 0;
9c73bd
 
9c73bd
 	if (nss_context == NULL) {
9c73bd
 		return NSS_STATUS_UNAVAIL;
9c73bd
@@ -220,12 +250,14 @@ enum nss_status backend_nss_getgrouplist(struct nss_ops_ctx *nss_context,
9c73bd
 
9c73bd
 	ret = nss_context->initgroups_dyn(name, group,
9c73bd
 					  &nss_context->initgroups_start,
9c73bd
-					  &ngroups, &groups,
9c73bd
-					  -1, &lerrno);
9c73bd
+					  &size, &groups,
9c73bd
+					  -1, lerrno);
9c73bd
 	if (ret == NSS_STATUS_SUCCESS) {
9c73bd
 		nss_context->initgroups_start = 0;
9c73bd
 	}
9c73bd
 
9c73bd
+	*ngroups = (int) size;
9c73bd
+
9c73bd
 	return ret;
9c73bd
 }
9c73bd
 
9c73bd
-- 
9c73bd
2.13.6
9c73bd