Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 21 Aug 2006 02:32:30 GMT
From:      Michael Bushkov <bushman@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 104649 for review
Message-ID:  <200608210232.k7L2WUAO007427@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=104649

Change 104649 by bushman@bushman_nss_ldap_cached_make on 2006/08/21 02:31:48

	- Precaching implemented
	- Malloc style and some issues fixed
	- DUPLICATE_RUNTIME_ENV condition and duplicate_runtime_env function added

Affected files ...

.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/Makefile#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agent.c#6 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agent.h#6 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/Makefile.inc#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/group.c#6 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/group.h#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/hosts.c#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/hosts.h#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/net.c#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/net.h#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/passwd.c#6 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/passwd.h#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/proto.c#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/proto.h#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/rpc.c#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/rpc.h#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/services.c#6 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/services.h#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cached.8#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cached.c#6 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cached.conf.5#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cachedcli.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cachedcli.h#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cachelib.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cachelib.h#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cacheplcs.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cacheplcs.h#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/config.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/config.h#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/debug.c#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/debug.h#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/hashtable.h#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/log.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/log.h#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/mp_rs_query.c#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/mp_rs_query.h#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/mp_ws_query.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/mp_ws_query.h#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/parser.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/parser.h#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/protocol.c#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/protocol.h#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/query.c#5 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/query.h#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/singletons.c#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/singletons.h#3 edit

Differences ...

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/Makefile#4 (text) ====


==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agent.c#6 (text) ====

@@ -33,8 +33,14 @@
 #include <string.h>
 #include <stdlib.h>
 #include <stdarg.h>
+#include "cachelib.h"
+#include "config.h"
+#include "debug.h"
+#include "log.h"
+#include "singletons.h"
 #include "agent.h"
-#include "debug.h"
+
+#define EIDSTR_SIZE	(sizeof(uid_t) + sizeof(gid_t))
 
 const ns_dtab emptydtab[] = {
 	{ NULL, NULL, NULL }
@@ -82,7 +88,8 @@
 	if (rv == NS_RETURN) {
 		*bufsize = size;
 		if (*bufsize <= AGENT_BUFFER_STORAGE_MAX) {			
-			*buffer = (char *)realloc(*buffer, *bufsize);
+			free(*buffer);
+			*buffer = malloc(*bufsize);
 			if (*buffer == NULL)
 				return (NS_UNAVAIL);
 
@@ -96,6 +103,52 @@
 		free(*buffer);
 		*buffer = NULL;
 		*bufsize = 0;
+	} else
+		*bufsize = size;
+
+	va_end(ap);
+	return (rv);
+}
+
+int 
+agent_id_args(char **buffer, size_t *bufsize, 
+	agent_id_func id_func, void *cache_mdata, ...)
+{
+	va_list ap;
+	size_t size;
+	int rv;
+	
+	va_start(ap, cache_mdata);
+	if (*buffer == NULL) {
+		*buffer = malloc(AGENT_KEY_BUFFER_STORAGE_INITIAL);
+		if (*buffer == NULL)
+			return (NS_UNAVAIL);
+		*bufsize = AGENT_KEY_BUFFER_STORAGE_INITIAL;		
+	}
+		
+	size = *bufsize - EIDSTR_SIZE;
+	rv = id_func(*buffer + EIDSTR_SIZE, &size, ap, cache_mdata);
+	if (rv == NS_RETURN) {
+		*bufsize = size;
+		if (*bufsize <= AGENT_KEY_BUFFER_STORAGE_MAX) {
+			free(*buffer);
+			*buffer = malloc(*bufsize);
+			if (*buffer == NULL)
+				return (NS_UNAVAIL);
+
+			size = *bufsize - EIDSTR_SIZE;
+			rv = id_func(*buffer + EIDSTR_SIZE, &size, ap, 
+				cache_mdata);
+		}
+	}
+			
+	if (rv != NS_SUCCESS) {
+		free(*buffer);
+		*buffer = NULL;
+		*bufsize = 0;
+	} else {
+		*bufsize = size + EIDSTR_SIZE;
+		memset(*buffer, 0, EIDSTR_SIZE);
 	}
 	
 	va_end(ap);
@@ -108,7 +161,7 @@
    	struct agent_table	*retval;
 
 	TRACE_IN(init_agent_table);
-	retval = (struct agent_table *)malloc(sizeof(struct agent_table));
+	retval = malloc(sizeof(struct agent_table));
 	if (retval == NULL) {
 		TRACE_OUT(init_agent_table);
 		return (NULL);
@@ -134,8 +187,7 @@
 	}
 
 	new_agents_num = at->agents_num + 1;
-	new_agents = (struct agent **)malloc(sizeof(struct agent *) *
-		new_agents_num);
+	new_agents = malloc(sizeof(struct agent *) * new_agents_num);
 	if (new_agents == NULL) {
 		TRACE_OUT(register_agent);
 		return (-1);
@@ -187,3 +239,120 @@
 	free(at);
 	TRACE_OUT(destroy_agent_table);
 }
+
+int 
+agent_precache_results(struct configuration_entry *config_entry,
+	struct multipart_agent *mp_agent)
+{	
+	cache_mp_write_session ws;
+	char *buffer, *keybuf, *dec_name, *en_bkp;
+	size_t buffer_size, keybuf_size;
+	void *mdata, *keygen_mdata, *retval;
+	cache_entry	c_entry;
+	int res, res2;
+	
+	TRACE_IN(agent_precache_results);
+	
+	if (mp_agent->mp_keygen_func == NULL) {
+		LOG_ERR_2("agent_precache_results", 
+			"'%s' does not support precaching", config_entry->name);
+		TRACE_OUT(agent_precache_results);
+		return (NS_UNAVAIL);
+	}
+	
+	configuration_lock_rdlock(s_configuration);
+	c_entry = find_cache_entry(s_cache, 
+		config_entry->mp_cache_params.entry_name);
+	configuration_unlock(s_configuration);
+	
+	configuration_lock_entry(config_entry, CELT_MULTIPART);
+	if (c_entry == INVALID_CACHE) {
+		dec_name = strdup(config_entry->mp_cache_params.entry_name);
+		if (dec_name == NULL) {
+			configuration_unlock_entry(config_entry, CELT_MULTIPART);
+			TRACE_OUT(agent_precache_results);
+			return (NS_UNAVAIL);
+		}		
+
+		en_bkp = config_entry->mp_cache_params.entry_name;
+		config_entry->mp_cache_params.entry_name = dec_name;
+		register_cache_entry(s_cache, (struct cache_entry_params *)
+			&config_entry->mp_cache_params);
+		config_entry->mp_cache_params.entry_name = en_bkp;
+			
+		configuration_lock_rdlock(s_configuration);
+		c_entry = find_cache_entry(s_cache,
+			config_entry->mp_cache_params.entry_name);
+		configuration_unlock(s_configuration);
+
+		if (c_entry == INVALID_CACHE) {
+			configuration_unlock_entry(config_entry, CELT_MULTIPART);
+			LOG_ERR_2("agent_precache_results", 
+				"can't register multipart cache entry'%s'", 
+				config_entry->name);
+			TRACE_OUT(agent_precache_results);
+			return (NS_UNAVAIL);
+		}
+		configuration_entry_add_mp_cache_entry(config_entry,
+			c_entry);		
+	}
+
+	ws = open_cache_mp_write_session(c_entry);
+	configuration_unlock_entry(config_entry, CELT_MULTIPART);
+	
+	keygen_mdata = NULL;
+	mdata = mp_agent->mp_init_func();
+	if (ws != NULL) {
+	    do {
+		buffer = NULL;
+		    
+		res = mp_agent->mp_lookup_func(&buffer, &buffer_size, &retval,
+		    mdata);
+		if ((res & NS_TERMINATE) && (buffer != NULL)) {
+			configuration_lock_entry(config_entry, CELT_MULTIPART);
+			if (cache_mp_write(ws, buffer, buffer_size) != 0) {
+				abandon_cache_mp_write_session(ws);
+				ws = NULL;
+			}
+			configuration_unlock_entry(config_entry, 
+				CELT_MULTIPART);
+			
+			configuration_lock_entry(config_entry, CELT_POSITIVE);			
+			
+			keybuf = NULL;
+			keybuf_size = 0;
+			while ((res2 = mp_agent->mp_keygen_func(&keybuf, 
+				&keybuf_size, retval, &keygen_mdata)) == 
+				NS_SUCCESS) {
+				if (keybuf == NULL)
+					break;
+				
+				cache_write(config_entry->positive_cache_entry,
+					keybuf, keybuf_size, buffer,
+					buffer_size);
+				
+				free(keybuf);
+				keybuf = NULL;
+				keybuf_size = 0;
+			}
+			configuration_unlock_entry(config_entry, CELT_POSITIVE);
+
+			free(buffer);
+			buffer = NULL;
+		} else {
+			configuration_lock_entry(config_entry,
+				CELT_MULTIPART);
+			close_cache_mp_write_session(ws);						
+			ws = NULL;
+			configuration_unlock_entry(config_entry,
+				CELT_MULTIPART);
+
+			buffer = NULL;
+		}
+	    } while ((res & NS_TERMINATE) && (ws != NULL));
+	    mp_agent->mp_keygen_func(NULL, NULL, NULL, &keygen_mdata);
+	}
+	
+	TRACE_OUT(agent_precache_results);
+	return (NS_SUCCESS);
+}

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agent.h#6 (text) ====

@@ -76,6 +76,7 @@
 
 #define AGENT_DECLARE_BUFFER_TLS_HANDLING(name)			\
 struct name##_state {						\
+	struct name inst;					\
 	char *buffer;						\
 	size_t bufsize;						\
 };								\
@@ -94,6 +95,12 @@
 	AGENT_BUFFER_STORAGE_MAX	= 1 << 20, /* 1 MByte */
 };
 
+enum agent_key_buffer_constants
+{
+	AGENT_KEY_BUFFER_STORAGE_INITIAL	= 1 << 8,
+	AGENT_KEY_BUFFER_STORAGE_MAX		= 1 << 20,
+};
+
 #define AGENT_BUFFER_TLS_HANDLING_INIT(st)				\
 	{								\
 		if (st->buffer == NULL) {				\
@@ -125,9 +132,11 @@
 };
 
 typedef int (*agent_marshal_func)(char *, size_t *, void *, va_list, void *);
+typedef int (*agent_id_func)(char *, size_t *, va_list, void *);
 typedef int (*agent_lookup_func)(const char *, size_t, char **, size_t *);
 typedef void *(*agent_mp_init_func)();
-typedef int (*agent_mp_lookup_func)(char **, size_t *, void *);
+typedef int (*agent_mp_lookup_func)(char **, size_t *, void *, void *);
+typedef int (*agent_mp_keygen_func)(char **, size_t *, void *, void *);
 typedef void (*agent_mp_destroy_func)(void *);
 
 struct agent {
@@ -145,6 +154,7 @@
 	
 	agent_mp_init_func mp_init_func;
 	agent_mp_lookup_func mp_lookup_func;
+	agent_mp_keygen_func mp_keygen_func;
 	agent_mp_destroy_func mp_destroy_func;
 };
 
@@ -157,10 +167,15 @@
 
 extern int agent_marshal_results(char **, size_t *, agent_marshal_func, 
 	void *, void *, ...);
+extern int agent_id_args(char **, size_t *, agent_id_func,
+	void *, ...);
 extern struct agent_table *init_agent_table();
 extern int register_agent(struct agent_table *, struct agent *);
 extern struct agent *find_agent(struct agent_table *, const char *,
 	enum agent_type);
 extern void destroy_agent_table(struct agent_table *);
+	
+extern int agent_precache_results(struct configuration_entry *, 
+	struct multipart_agent *);
 
 #endif

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/Makefile.inc#5 (text) ====


==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/group.c#6 (text) ====

@@ -40,20 +40,30 @@
 #include <string.h>
 #include <stdlib.h>
 #include <unistd.h>
+#include "../debug.h"
+#include "../cachelib.h"
+#include "../config.h"
+#include "../debug.h"
+#include "../log.h"
+#include "../singletons.h"
 #include "../agent.h"
-#include "../debug.h"
 #include "group.h"
 
+#define GROUP_KEYGEN_BYNAME	(0)
+#define GROUP_KEYGEN_BYGID	(1)
+#define GROUP_KEYGEN_END	(2)
+
 static const ns_src defaultsrc[] = {
 	{ NSSRC_COMPAT, NS_SUCCESS },
 	{ NULL, 0 }
 };
 
-
+static int group_id_func(char *, size_t *, va_list, void *);
 static int group_marshal_func(char *, size_t *, void *, va_list, void *);
 static int group_lookup_func(const char *, size_t, char **, size_t *);
 static void *group_mp_init_func();
-static int group_mp_lookup_func(char **out_buffer, size_t *out_size, void *mdata);
+static int group_mp_lookup_func(char **, size_t *, void *, void *);
+static int group_mp_keygen_func(char **, size_t *, void *, void *);
 static void group_mp_destroy_func(void *mdata);
 
 AGENT_DECLARE_BUFFER_TLS_HANDLING(group);
@@ -67,6 +77,58 @@
 #endif
 
 static int
+group_id_func(char *buffer, size_t *buffer_size, va_list ap, void *cache_mdata)
+{
+	char	*name;
+	gid_t	gid;
+
+	size_t	desired_size, size;
+	int	res = NS_UNAVAIL;
+	enum nss_lookup_type lookup_type;
+
+
+	lookup_type = (enum nss_lookup_type)cache_mdata;
+	switch (lookup_type) {
+	case nss_lt_name:
+		name = va_arg(ap, char *);
+		size = strlen(name);
+		desired_size = sizeof(enum nss_lookup_type) + size + 1;
+		if (desired_size > *buffer_size) {
+			res = NS_RETURN;
+			goto fin;
+		}
+
+		memcpy(buffer, &lookup_type, sizeof(enum nss_lookup_type));
+		memcpy(buffer + sizeof(enum nss_lookup_type), name, size + 1);
+
+		res = NS_SUCCESS;
+		break;
+	case nss_lt_id:
+		gid = va_arg(ap, gid_t);
+		desired_size = sizeof(enum nss_lookup_type) + sizeof(gid_t);
+		if (desired_size > *buffer_size) {
+			res = NS_RETURN;
+			goto fin;
+		}
+
+		memcpy(buffer, &lookup_type, sizeof(enum nss_lookup_type));
+		memcpy(buffer + sizeof(enum nss_lookup_type), &gid,
+		    sizeof(gid_t));
+
+		res = NS_SUCCESS;
+		break;
+	default:
+		/* should be unreachable */
+		return (NS_UNAVAIL);
+	}
+
+fin:
+	*buffer_size = desired_size;
+	return (res);
+}
+
+
+static int
 group_marshal_func(char *buffer, size_t *buffer_size, void *retval, va_list ap,
     void *cache_mdata)
 {
@@ -122,7 +184,7 @@
 	}
 
 	memcpy(&new_grp, grp, sizeof(struct group));
-	//memset(buffer, 0, desired_size);
+	memset(buffer, 0, desired_size);
 
 	*buffer_size = desired_size;
 	p = buffer + sizeof(struct group) + sizeof(char *);
@@ -166,7 +228,7 @@
 	size_t *out_size)
 {
 	struct group_state *st;
-	struct group grp, *retval;	
+	struct group *retval;	
 	enum nss_lookup_type lookup_type;
 	char *name;
 	gid_t	gid;
@@ -187,12 +249,11 @@
 	switch (lookup_type) {
 	case nss_lt_name:
 		size = key_size - sizeof(enum nss_lookup_type)  + 1;
-		name = (char *)malloc(size);
+		name = malloc(size);
 		if (name == NULL) {
 			TRACE_OUT(group_lookup_func);
 			return (NS_UNAVAIL);
 		}
-		//memset(name, 0, size);
 		name[size - 1] = '\0';
 		memcpy(name, key + sizeof(enum nss_lookup_type), size - 1);
                 break;
@@ -223,7 +284,7 @@
 		do {
 			result = nsdispatch(&retval, emptydtab, NSDB_GROUP, 
 				"getgrnam_r", defaultsrc, name,
-				&grp, st->buffer, st->bufsize, &error);
+				&st->inst, st->buffer, st->bufsize, &error);
 			
 			if ((result == NS_RETURN) && (error == ERANGE)) {
 				AGENT_BUFFER_TLS_HANDLING_RESIZE(st);
@@ -237,7 +298,7 @@
 		if (result == NS_SUCCESS)
 			result = agent_marshal_results(out_buffer, out_size,
 				group_marshal_func, (void *)nss_lt_name, 
-				retval, name, &grp,
+				retval, name, &st->inst,
 				st->buffer, st->bufsize, &error);
 
 		break;
@@ -245,7 +306,7 @@
 		do {
 			result = nsdispatch(&retval, emptydtab, NSDB_GROUP, 
 				"getgrgid_r", defaultsrc, gid,
-				&grp, st->buffer, st->bufsize, &error);
+				&st->inst, st->buffer, st->bufsize, &error);
 			
 			if ((result == NS_RETURN) && (error == ERANGE)) {
 				AGENT_BUFFER_TLS_HANDLING_RESIZE(st);
@@ -260,7 +321,7 @@
 			result = agent_marshal_results(out_buffer, out_size,
 				group_marshal_func,
 				(void *)nss_lt_id, retval, gid,
-				&grp, st->buffer, st->bufsize, &error);
+				&st->inst, st->buffer, st->bufsize, &error);
 		break;
 	default:
 		/* SHOULD NOT BE REACHED */
@@ -283,10 +344,10 @@
 }
 
 static int
-group_mp_lookup_func(char **out_buffer, size_t *out_size, void *mdata)
+group_mp_lookup_func(char **out_buffer, size_t *out_size, void *retval,
+	void *mdata)
 {
 	struct group_state *st;
-	struct group grp, *retval;
 	int result, error;
 
 	TRACE_IN(group_mp_lookup_func);
@@ -297,8 +358,8 @@
 		return (NS_UNAVAIL);
 	
 	do {
-		result = nsdispatch(&retval, emptydtab, NSDB_GROUP, 
-			"getgrent_r", defaultsrc, &grp, st->buffer, 
+		result = nsdispatch(retval, emptydtab, NSDB_GROUP, 
+			"getgrent_r", defaultsrc, &st->inst, st->buffer,
 			st->bufsize, &error);
 			
 		if ((result == NS_RETURN) && (error == ERANGE)) {
@@ -311,14 +372,59 @@
 	if (result == NS_SUCCESS) {
 		result = agent_marshal_results(out_buffer,
 			out_size, group_marshal_func, 
-			(void *)nss_lt_all, retval, &grp,
-			 st->buffer, st->bufsize, &error);
+			(void *)nss_lt_all, *((void **)retval), 
+			&st->inst, st->buffer, st->bufsize, &error);
 	}
 
 	TRACE_OUT(group_mp_lookup_func);
 	return (result);
 }
 
+int 
+group_mp_keygen_func(char **out_buffer, size_t *out_size,
+	void *result, void *mdata)
+{
+	struct group *grp;
+	int rv, *conv_type;
+
+	TRACE_IN(group_mp_keygen_func);
+	grp = (struct group *)result;
+	conv_type = *((int **)mdata);
+
+	if (grp == NULL) {
+		free(conv_type);
+		*((int **)mdata) = NULL;
+		return (NS_UNAVAIL);
+	}
+
+	if (conv_type == NULL) {
+		conv_type = malloc(sizeof(int));
+		*conv_type = GROUP_KEYGEN_BYNAME;
+		*((int **)mdata) = conv_type;
+	}
+
+	switch (*conv_type) {
+	case GROUP_KEYGEN_BYNAME:
+		rv = agent_id_args(out_buffer, out_size, group_id_func,
+			(void *)nss_lt_name, grp->gr_name);
+		*conv_type = GROUP_KEYGEN_BYGID;
+		break;
+	case GROUP_KEYGEN_BYGID:
+		rv = agent_id_args(out_buffer, out_size, group_id_func,
+			(void *)nss_lt_id, grp->gr_gid);
+		*conv_type = GROUP_KEYGEN_END;
+		break;
+	case GROUP_KEYGEN_END:
+	default:
+		*conv_type = GROUP_KEYGEN_BYNAME;
+		rv = NS_NOTFOUND;
+		break;
+	}
+
+	TRACE_OUT(group_mp_keygen_func);
+	return (rv);
+}
+
 static void
 group_mp_destroy_func(void *mdata)
 {
@@ -333,7 +439,7 @@
 	struct common_agent	*retval;
 
 	TRACE_IN(init_group_agent);
-	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
+	retval = malloc(sizeof(struct common_agent));
 	if (retval == NULL) {
 		TRACE_OUT(init_group_agent);
 		return (NULL);
@@ -360,8 +466,7 @@
 	struct multipart_agent	*retval;
 
 	TRACE_IN(init_group_mp_agent);
-	retval = (struct multipart_agent *)malloc(
-		sizeof(struct multipart_agent));
+	retval = malloc(sizeof(struct multipart_agent));
 	if (retval == NULL) {
 		TRACE_OUT(init_group_mp_agent);
 		return (NULL);
@@ -377,6 +482,7 @@
 	retval->parent.type = MULTIPART_AGENT;
 	retval->mp_init_func = group_mp_init_func;
 	retval->mp_lookup_func = group_mp_lookup_func;
+	retval->mp_keygen_func = group_mp_keygen_func;
 	retval->mp_destroy_func = group_mp_destroy_func;	
 
 	TRACE_OUT(init_group_mp_agent);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/group.h#5 (text) ====


==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/hosts.c#5 (text+ko) ====

@@ -45,8 +45,13 @@
 #include <string.h>
 #include <stdlib.h>
 #include <stdio.h>
+#include "../debug.h"
+#include "../cachelib.h"
+#include "../config.h"
+#include "../debug.h"
+#include "../log.h"
+#include "../singletons.h"
 #include "../agent.h"
-#include "../debug.h"
 #include "hosts.h"
 
 static const ns_src defaultsrc[] = {
@@ -133,7 +138,7 @@
 	}
 
 	memcpy(&new_ht, ht, sizeof(struct hostent));
-	//memset(buffer, 0, desired_size);
+	memset(buffer, 0, desired_size);
 
 	*buffer_size = desired_size;
 	p = buffer + sizeof(struct hostent) + sizeof(char *);
@@ -205,7 +210,7 @@
 		return (NS_RETURN);
 	}
 
-	//memset(buffer, 0, desired_size);
+	memset(buffer, 0, desired_size);
 	p = buffer;
 
 	memcpy(p, &ai_size, sizeof(size_t));
@@ -301,12 +306,11 @@
 		key_size -= sizeof(int);
 		
 		size = key_size + 1;
-		str = (char *)malloc(size);
+		str = malloc(size);
 		if (str == NULL) {
 			TRACE_OUT(hosts_lookup_func);
 			return (NS_UNAVAIL);
 		}
-		//memset(str, 0, size);
 		str[size - 1] = '\0';
 		memcpy(str, key, key_size);
 		
@@ -339,12 +343,11 @@
 		switch (lookup_type) {
 		case nss_lt_name:					
 			size = key_size + 1;
-			str = (char *)malloc(size);
+			str = malloc(size);
 			if (str == NULL) {
 				TRACE_OUT(hosts_lookup_func);
 				return (NS_UNAVAIL);
 			}
-			//memset(str, 0, size);
 			str[size - 1] = '\0';
 			memcpy(str, key, key_size);
 			break;
@@ -447,7 +450,7 @@
 	struct common_agent	*retval;
 
 	TRACE_IN(init_hosts_agent);
-	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
+	retval = malloc(sizeof(struct common_agent));
 	if (retval == NULL) {
 		TRACE_OUT(init_hosts_agent);
 		return (NULL);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/hosts.h#4 (text+ko) ====


==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/net.c#5 (text+ko) ====

@@ -44,8 +44,13 @@
 #include <string.h>
 #include <stdarg.h>
 #include <nsswitch.h>
+#include "../debug.h"
+#include "../cachelib.h"
+#include "../config.h"
+#include "../debug.h"
+#include "../log.h"
+#include "../singletons.h"
 #include "../agent.h"
-#include "../debug.h"
 #include "net.h"
 
 static const ns_src defaultsrc[] = {
@@ -126,7 +131,7 @@
 	memcpy(&new_ne, ne, sizeof(struct netent));
 
 	*buffer_size = desired_size;
-	//memset(buffer, 0, desired_size);
+	memset(buffer, 0, desired_size);
 	p = buffer + sizeof(struct netent) + sizeof(char *);
 	memcpy(buffer + sizeof(struct netent), &p, sizeof(char *));
 	p = (char *)_ALIGN(p);
@@ -183,12 +188,11 @@
 	switch (lookup_type) {
 	case nss_lt_name:
 		size = key_size - sizeof(enum nss_lookup_type)  + 1;
-		name = (char *)malloc(size);
+		name = malloc(size);
 		if (name == NULL) {
 			TRACE_OUT(networks_lookup_func);
 			return (NS_UNAVAIL);
 		}
-		//memset(name, 0, size);
 		name[size - 1] = '\0';
 		memcpy(name, key + sizeof(enum nss_lookup_type), size - 1);
 		break;
@@ -277,7 +281,7 @@
 	struct common_agent	*retval;
 
 	TRACE_IN(init_networks_agent);
-	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
+	retval = malloc(sizeof(struct common_agent));
 	if (retval == NULL) {
 		TRACE_OUT(init_networks_agent);
 		return (NULL);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/net.h#4 (text+ko) ====


==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/passwd.c#6 (text) ====

@@ -38,25 +38,84 @@
 #include <pwd.h>
 #include <string.h>
 #include <stdlib.h>
+#include "../debug.h"
+#include "../cachelib.h"
+#include "../config.h"
+#include "../debug.h"
+#include "../log.h"
+#include "../singletons.h"
 #include "../agent.h"
-#include "../debug.h"
 #include "passwd.h"
 
+#define PASSWD_KEYGEN_BYNAME		(0)
+#define PASSWD_KEYGEN_BYUID		(1)
+#define PASSWD_KEYGEN_END		(2)
+
 static const ns_src defaultsrc[] = {
 	{ NSSRC_COMPAT, NS_SUCCESS },
 	{ NULL, 0 }
 };
 
-
+static int passwd_id_func(char *, size_t *, va_list, void *);
 static int passwd_marshal_func(char *, size_t *, void *, va_list, void *);
 static int passwd_lookup_func(const char *, size_t, char **, size_t *);
 static void *passwd_mp_init_func();
-static int passwd_mp_lookup_func(char **out_buffer, size_t *out_size, void *mdata);
-static void passwd_mp_destroy_func(void *mdata);
+static int passwd_mp_lookup_func(char **, size_t *, void *, void *);
+static int passwd_mp_keygen_func(char **, size_t *, void *, void *);
+static void passwd_mp_destroy_func(void *);
 
 AGENT_DECLARE_BUFFER_TLS_HANDLING(passwd);
 
 static int
+passwd_id_func(char *buffer, size_t *buffer_size, va_list ap, void *cache_mdata)
+{
+	char	*name;
+	uid_t	uid;
+	size_t	size, desired_size;
+	int	res = NS_UNAVAIL;
+	enum nss_lookup_type lookup_type;
+
+	lookup_type = (enum nss_lookup_type)cache_mdata;
+	switch (lookup_type) {
+	case nss_lt_name:
+		name = va_arg(ap, char *);
+		size = strlen(name);
+		desired_size = sizeof(enum nss_lookup_type) + size + 1;
+		if (desired_size > *buffer_size) {
+			res = NS_RETURN;
+			goto fin;
+		}
+
+		memcpy(buffer, &lookup_type, sizeof(enum nss_lookup_type));
+		memcpy(buffer + sizeof(enum nss_lookup_type), name, size + 1);
+
+		res = NS_SUCCESS;
+		break;
+	case nss_lt_id:
+		uid = va_arg(ap, uid_t);
+		desired_size = sizeof(enum nss_lookup_type) + sizeof(uid_t);
+		if (desired_size > *buffer_size) {
+			res = NS_RETURN;
+			goto fin;
+		}
+
+		memcpy(buffer, &lookup_type, sizeof(enum nss_lookup_type));
+		memcpy(buffer + sizeof(enum nss_lookup_type), &uid,
+		    sizeof(uid_t));
+
+		res = NS_SUCCESS;
+		break;
+	default:
+		/* should be unreachable */
+		return (NS_UNAVAIL);
+	}
+
+fin:
+	*buffer_size = desired_size;
+	return (res);
+}
+
+static int
 passwd_marshal_func(char *buffer, size_t *buffer_size, void *retval, va_list ap,
     void *cache_mdata)
 {
@@ -108,7 +167,7 @@
 	}
 
 	memcpy(&new_pwd, pwd, sizeof(struct passwd));
-	//memset(buffer, 0, desired_size);
+	memset(buffer, 0, desired_size);
 
 	*buffer_size = desired_size;
 	p = buffer + sizeof(struct passwd) + sizeof(char *);
@@ -165,7 +224,7 @@
 	size_t *out_size)
 {
 	struct passwd_state *st;
-	struct passwd pwd, *retval;	
+	struct passwd *retval;	
 	enum nss_lookup_type lookup_type;
 	char *login;
 	uid_t	uid;
@@ -186,12 +245,11 @@
 	switch (lookup_type) {
 	case nss_lt_name:
 		size = key_size - sizeof(enum nss_lookup_type)  + 1;
-		login = (char *)malloc(size);
+		login = malloc(size);
 		if (login == NULL) {
 			TRACE_OUT(passwd_lookup_func);
 			return (NS_UNAVAIL);
 		}
-		//memset(login, 0, size);
 		login[size - 1] ='\0';
 		memcpy(login, key + sizeof(enum nss_lookup_type), size - 1);
 		break;
@@ -222,7 +280,7 @@
 		do {
 			result = nsdispatch(&retval, emptydtab, NSDB_PASSWD, 
 				"getpwnam_r", defaultsrc, login,
-				&pwd, st->buffer, st->bufsize, &error);
+				&st->inst, st->buffer, st->bufsize, &error);
 			
 			if ((result == NS_RETURN) && (error == ERANGE)) {
 				AGENT_BUFFER_TLS_HANDLING_RESIZE(st);
@@ -236,7 +294,7 @@
 		if (result == NS_SUCCESS)
 			result = agent_marshal_results(out_buffer, out_size,
 				passwd_marshal_func, (void *)nss_lt_name, 
-				retval, login, &pwd,
+				retval, login, &st->inst,
 				st->buffer, st->bufsize, &error);
 
 		break;
@@ -244,7 +302,7 @@
 		do {
 			result = nsdispatch(&retval, emptydtab, NSDB_PASSWD, 
 				"getpwuid_r", defaultsrc, uid,
-				&pwd, st->buffer, st->bufsize, &error);
+				&st->inst, st->buffer, st->bufsize, &error);
 			
 			if ((result == NS_RETURN) && (error == ERANGE)) {
 				AGENT_BUFFER_TLS_HANDLING_RESIZE(st);
@@ -259,7 +317,7 @@
 			result = agent_marshal_results(out_buffer, out_size,
 				passwd_marshal_func,
 				(void *)nss_lt_id, retval, uid,
-				&pwd, st->buffer, st->bufsize, &error);
+				&st->inst, st->buffer, st->bufsize, &error);
 		break;
 	default:
 		/* SHOULD NOT BE REACHED */
@@ -282,10 +340,10 @@
 }
 
 static int
-passwd_mp_lookup_func(char **out_buffer, size_t *out_size, void *mdata)
+passwd_mp_lookup_func(char **out_buffer, size_t *out_size, void *retval,
+	void *mdata)
 {
 	struct passwd_state *st;
-	struct passwd pwd, *retval;
 	int result, error;
 
 	TRACE_IN(passwd_mp_lookup_func);
@@ -296,8 +354,8 @@
 		return (NS_UNAVAIL);
 	
 	do {
-		result = nsdispatch(&retval, emptydtab, NSDB_PASSWD, 
-			"getpwent_r", defaultsrc, &pwd, st->buffer, 
+		result = nsdispatch(retval, emptydtab, NSDB_PASSWD, 
+			"getpwent_r", defaultsrc, &st->inst, st->buffer, 
 			st->bufsize, &error);
 			
 		if ((result == NS_RETURN) && (error == ERANGE)) {
@@ -309,15 +367,60 @@
 		
 	if (result == NS_SUCCESS) {
 		result = agent_marshal_results(out_buffer,
-			out_size, passwd_marshal_func, 
-			(void *)nss_lt_all, retval, &pwd,
-			 st->buffer, st->bufsize, &error);
+			out_size, passwd_marshal_func, (void *)nss_lt_all,
+			*((void **)retval), &st->inst, st->buffer, 
+			st->bufsize, &error);
 	}
 
 	TRACE_OUT(passwd_mp_lookup_func);
 	return (result);
 }
 
+static int
+passwd_mp_keygen_func(char **out_buffer, size_t *out_size,
+	void *result, void *mdata)
+{
+	struct passwd *pwd;
+	int rv, *conv_type;
+
+	TRACE_IN(passwd_mp_keygen_type);
+	pwd = (struct passwd *)result;
+	conv_type = *((int **)mdata);
+
+	if (pwd == NULL) {
+		free(conv_type);
+		*((int **)mdata) = NULL;
+		return (NS_UNAVAIL);
+	}
+
+	if (conv_type == NULL) {
+		conv_type = malloc(sizeof(int));
+		*conv_type = PASSWD_KEYGEN_BYNAME;
+		*((int **)mdata) = conv_type;
+	}
+
+	switch (*conv_type) {
+	case PASSWD_KEYGEN_BYNAME:
+		rv = agent_id_args(out_buffer, out_size, passwd_id_func,
+			(void *)nss_lt_name, pwd->pw_name);
+		*conv_type = PASSWD_KEYGEN_BYUID;
+		break;
+	case PASSWD_KEYGEN_BYUID:
+		rv = agent_id_args(out_buffer, out_size, passwd_id_func,
+			(void *)nss_lt_id, pwd->pw_uid);
+		*conv_type = PASSWD_KEYGEN_END;
+		break;
+	case PASSWD_KEYGEN_END:
+	default:
+		*conv_type = PASSWD_KEYGEN_BYNAME;
+		rv = NS_NOTFOUND;
+		break;
+	}
+
+	TRACE_OUT(passwd_mp_keygen_type);
+	return (rv);
+}
+
 static void

>>> TRUNCATED FOR MAIL (1000 lines) <<<



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200608210232.k7L2WUAO007427>