Blame SOURCES/autofs-5.0.9-amd-lookup-add-lookup-vars.patch

4d476f
autofs-5.0.9 - amd lookup add lookup vars
4d476f
4d476f
From: Ian Kent <raven@themaw.net>
4d476f
4d476f
4d476f
---
4d476f
 modules/parse_amd.c |  157 ++++++++++++++++++++++++++++++++++++++++++++++-----
4d476f
 1 file changed, 141 insertions(+), 16 deletions(-)
4d476f
4d476f
diff --git a/modules/parse_amd.c b/modules/parse_amd.c
4d476f
index 295a10f..35cc5dc 100644
4d476f
--- a/modules/parse_amd.c
4d476f
+++ b/modules/parse_amd.c
4d476f
@@ -129,6 +129,100 @@ int parse_init(int argc, const char *const *argv, void **context)
4d476f
 	return 0;
4d476f
 }
4d476f
 
4d476f
+static struct substvar *add_lookup_vars(struct autofs_point *ap,
4d476f
+					const char *key, int key_len,
4d476f
+					struct map_source *source,
4d476f
+					struct substvar *sv)
4d476f
+{
4d476f
+	struct substvar *list = sv;
4d476f
+	struct thread_stdenv_vars *tsv;
4d476f
+	char lkp_key[PATH_MAX + 1];
4d476f
+	char path[PATH_MAX + 1];
4d476f
+	struct mapent *me;
4d476f
+	int len;
4d476f
+
4d476f
+	len = strlen(ap->path) + 1 + key_len + 1;
4d476f
+	if (len > PATH_MAX) {
4d476f
+		error(ap->logopt, MODPREFIX
4d476f
+		      "error: lookup key is greater than PATH_MAX");
4d476f
+		return NULL;
4d476f
+	}
4d476f
+
4d476f
+	if (ap->pref) {
4d476f
+		if (snprintf(lkp_key, sizeof(lkp_key), "%s%s",
4d476f
+			     ap->pref, key) >= sizeof(lkp_key)) {
4d476f
+			error(ap->logopt, MODPREFIX "key too long");
4d476f
+			return NULL;
4d476f
+		}
4d476f
+	} else {
4d476f
+		if (snprintf(lkp_key, sizeof(lkp_key), "%s",
4d476f
+			     key) >= sizeof(lkp_key)) {
4d476f
+			error(ap->logopt, MODPREFIX "key too long");
4d476f
+			return NULL;
4d476f
+		}
4d476f
+	}
4d476f
+
4d476f
+	if (*key == '/')
4d476f
+		strcpy(path, key);
4d476f
+	else {
4d476f
+		strcpy(path, ap->path);
4d476f
+		strcat(path, "/");
4d476f
+		strcat(path, key);
4d476f
+	}
4d476f
+	list = macro_addvar(list, "path", 4, path);
4d476f
+
4d476f
+	me = cache_lookup_distinct(source->mc, lkp_key);
4d476f
+	if (me)
4d476f
+		list = macro_addvar(list, "key", 3, me->key);
4d476f
+
4d476f
+	while (!me) {
4d476f
+		char match[PATH_MAX + 1];
4d476f
+		char *prefix;
4d476f
+
4d476f
+		strcpy(match, lkp_key);
4d476f
+		while ((prefix = strrchr(match, '/'))) {
4d476f
+			*prefix = '\0';
4d476f
+			me = cache_partial_match_wild(source->mc, match);
4d476f
+			if (me) {
4d476f
+				list = macro_addvar(list, "key", 3, lkp_key);
4d476f
+				break;
4d476f
+			}
4d476f
+		}
4d476f
+
4d476f
+		if (!me) {
4d476f
+			me = cache_lookup_distinct(source->mc, "*");
4d476f
+			if (me)
4d476f
+				list = macro_addvar(list, "key", 3, lkp_key);
4d476f
+		}
4d476f
+
4d476f
+		break;
4d476f
+	}
4d476f
+
4d476f
+	if (source->argv[0][0])
4d476f
+		list = macro_addvar(list, "map", 3, source->argv[0]);
4d476f
+
4d476f
+	tsv = pthread_getspecific(key_thread_stdenv_vars);
4d476f
+	if (tsv) {
4d476f
+		char numbuf[16];
4d476f
+		long num;
4d476f
+		int ret;
4d476f
+
4d476f
+		num = (long) tsv->uid;
4d476f
+		ret = sprintf(numbuf, "%ld", num);
4d476f
+		if (ret > 0)
4d476f
+			list = macro_addvar(list, "uid", 3, numbuf);
4d476f
+		num = (long) tsv->gid;
4d476f
+		ret = sprintf(numbuf, "%ld", num);
4d476f
+		if (ret > 0)
4d476f
+			list = macro_addvar(list, "gid", 3, numbuf);
4d476f
+	}
4d476f
+
4d476f
+	list = macro_addvar(list, "fs", 2, "${autodir}/${rhost}${rfs}");
4d476f
+	list = macro_addvar(list, "rfs", 3, path);
4d476f
+
4d476f
+	return list;
4d476f
+}
4d476f
+
4d476f
 static void update_with_defaults(struct amd_entry *defaults,
4d476f
 				 struct amd_entry *entry,
4d476f
 				 struct substvar *sv)
4d476f
@@ -167,22 +261,40 @@ static void update_with_defaults(struct amd_entry *defaults,
4d476f
 			entry->pref = tmp;
4d476f
 	}
4d476f
 
4d476f
-	if (!entry->fs && defaults->fs) {
4d476f
-		tmp = strdup(defaults->fs);
4d476f
-		if (tmp)
4d476f
-			entry->fs = tmp;
4d476f
+	if (!entry->fs) {
4d476f
+		if (defaults->fs) {
4d476f
+			tmp = strdup(defaults->fs);
4d476f
+			if (tmp)
4d476f
+				entry->fs = tmp;
4d476f
+		} else {
4d476f
+			v = macro_findvar(sv, "fs", 2);
4d476f
+			if (v)
4d476f
+				entry->fs = strdup(v->val);
4d476f
+		}
4d476f
 	}
4d476f
 
4d476f
-	if (!entry->rfs && defaults->rfs) {
4d476f
-		tmp = strdup(defaults->rfs);
4d476f
-		if (tmp)
4d476f
-			entry->rfs = tmp;
4d476f
+	if (!entry->rfs) {
4d476f
+		if (defaults->rfs) {
4d476f
+			tmp = strdup(defaults->rfs);
4d476f
+			if (tmp)
4d476f
+				entry->rfs = tmp;
4d476f
+		} else {
4d476f
+			v = macro_findvar(sv, "rfs", 3);
4d476f
+			if (v)
4d476f
+				entry->rfs = strdup(v->val);
4d476f
+		}
4d476f
 	}
4d476f
 
4d476f
-	if (!entry->rhost && defaults->rhost) {
4d476f
-		tmp = strdup(defaults->rhost);
4d476f
-		if (tmp)
4d476f
-			entry->rhost = tmp;
4d476f
+	if (!entry->rhost) {
4d476f
+		if (defaults->rhost) {
4d476f
+			tmp = strdup(defaults->rhost);
4d476f
+			if (tmp)
4d476f
+				entry->rhost = tmp;
4d476f
+		} else {
4d476f
+			v = macro_findvar(sv, "host", 4);
4d476f
+			if (v)
4d476f
+				entry->rhost = strdup(v->val);
4d476f
+		}
4d476f
 	}
4d476f
 
4d476f
 	if (!entry->opts && defaults->opts) {
4d476f
@@ -197,10 +309,16 @@ static void update_with_defaults(struct amd_entry *defaults,
4d476f
 			entry->addopts = tmp;
4d476f
 	}
4d476f
 
4d476f
-	if (!entry->remopts && defaults->remopts) {
4d476f
-		tmp = merge_options(defaults->remopts, entry->remopts);
4d476f
-		if (tmp)
4d476f
-			entry->remopts = tmp;
4d476f
+	if (!entry->remopts) {
4d476f
+		if (defaults->remopts) {
4d476f
+			tmp = strdup(defaults->remopts);
4d476f
+			if (tmp)
4d476f
+				entry->remopts = tmp;
4d476f
+		} else {
4d476f
+			v = macro_findvar(sv, "remopts", 7);
4d476f
+			if (v)
4d476f
+				entry->remopts = strdup(v->val);
4d476f
+		}
4d476f
 	}
4d476f
 
4d476f
 	return;
4d476f
@@ -984,6 +1102,13 @@ int parse_mount(struct autofs_point *ap, const char *name,
4d476f
 
4d476f
 	pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, &cur_state);
4d476f
 
4d476f
+	sv = add_lookup_vars(ap, name, name_len, source, sv);
4d476f
+	if (!sv) {
4d476f
+		macro_free_table(sv);
4d476f
+		pthread_setcancelstate(cur_state, NULL);
4d476f
+		return 1;
4d476f
+	}
4d476f
+
4d476f
 	len = expand_selectors(ap, mapent, &pmapent, sv);
4d476f
 	if (!len) {
4d476f
 		macro_free_table(sv);