Hide the registry backend from libnet_smbconf_getparm().
authorMichael Adam <obnox@samba.org>
Sat, 29 Dec 2007 01:12:33 +0000 (02:12 +0100)
committerMichael Adam <obnox@samba.org>
Sat, 29 Dec 2007 01:12:33 +0000 (02:12 +0100)
Return a formatted string of the value instead.

Michael
(This used to be commit 7d0ec5bae155cda6620db04dcb7bd43db59241aa)

source3/libnet/libnet_conf.c
source3/utils/net_conf.c

index dfea7244977b6ee08b75b9a6830123cf4b060149..1e9e033205b9df2d04e3e7bf1bc0d7d6f2a41dda 100644 (file)
@@ -359,12 +359,17 @@ done:
 WERROR libnet_smbconf_getparm(TALLOC_CTX *mem_ctx,
                              const char *service,
                              const char *param,
-                             struct registry_value **value)
+                             char **valstr)
 {
-       WERROR werr;
+       WERROR werr = WERR_OK;
        struct registry_key *key = NULL;
        struct registry_value *value = NULL;
 
+       if (valstr == NULL) {
+               werr = WERR_INVALID_PARAM;
+               goto done;
+       }
+
        if (!libnet_smbconf_key_exists(service)) {
                werr = WERR_NO_SUCH_SERVICE;
                goto done;
@@ -381,10 +386,20 @@ WERROR libnet_smbconf_getparm(TALLOC_CTX *mem_ctx,
                goto done;
        }
 
-       werr = reg_queryvalue(mem_ctx, key, param, value);
+       werr = reg_queryvalue(mem_ctx, key, param, &value);
+       if (!W_ERROR_IS_OK(werr)) {
+               goto done;
+       }
+
+       *valstr = libnet_smbconf_format_registry_value(mem_ctx, value);
+
+       if (*valstr == NULL) {
+               werr = WERR_NOMEM;
+       }
 
 done:
        TALLOC_FREE(key);
+       TALLOC_FREE(value);
        return werr;
 }
 
index fb6cb58840810a7e625566a7e8333518d8736acb..e607d099dc85b1825dbf1c484360984422dde85a 100644 (file)
@@ -769,7 +769,7 @@ static int net_conf_getparm(int argc, const char **argv)
        WERROR werr = WERR_OK;
        char *service = NULL;
        char *param = NULL;
-       struct registry_value *value = NULL;
+       char *valstr = NULL;
        TALLOC_CTX *ctx;
 
        ctx = talloc_init("getparm");
@@ -781,7 +781,7 @@ static int net_conf_getparm(int argc, const char **argv)
        service = strdup_lower(argv[0]);
        param = strdup_lower(argv[1]);
 
-       werr = libnet_smbconf_getparm(ctx, service, param, &value);
+       werr = libnet_smbconf_getparm(ctx, service, param, &valstr);
 
        if (W_ERROR_EQUAL(werr, WERR_NO_SUCH_SERVICE)) {
                d_fprintf(stderr,
@@ -799,7 +799,7 @@ static int net_conf_getparm(int argc, const char **argv)
                goto done;
        }
 
-       d_printf("%s\n", libnet_smbconf_format_registry_value(ctx, value));
+       d_printf("%s\n", valstr);
 
        ret = 0;
 done: