Move logic of net_conf_getparm() to libnet_conf.c.
authorMichael Adam <obnox@samba.org>
Sun, 23 Dec 2007 14:07:20 +0000 (15:07 +0100)
committerMichael Adam <obnox@samba.org>
Sun, 23 Dec 2007 23:18:35 +0000 (00:18 +0100)
Michael
(This used to be commit d3a20c4d5a8109334cd3ed665ba60cfcc4425059)

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

index 69a105f8f53da4e2f6d426dcfaa4f0f0b611a78f..121ec3546896a24635210d9de6f3cf72190293b5 100644 (file)
@@ -271,6 +271,30 @@ WERROR libnet_smbconf_setparm(TALLOC_CTX *mem_ctx,
        return werr;
 }
 
+WERROR libnet_smbconf_getparm(TALLOC_CTX *mem_ctx,
+                             const char *service,
+                             const char *param,
+                             struct registry_value **value)
+{
+       WERROR werr;
+       struct registry_key *key = NULL;
+
+       if (!libnet_smbconf_key_exists(mem_ctx, service)) {
+               return WERR_NO_SUCH_SERVICE;
+       }
+
+       werr = libnet_smbconf_open_path(mem_ctx, service, REG_KEY_READ, &key);
+       W_ERROR_NOT_OK_RETURN(werr);
+
+       if (!libnet_smbconf_value_exists(mem_ctx, key, param)) {
+               return WERR_INVALID_PARAM;
+       }
+
+       werr = reg_queryvalue(mem_ctx, key, param, value);
+
+       return werr;
+}
+
 WERROR libnet_smbconf_delparm(TALLOC_CTX *mem_ctx,
                              const char *service,
                              const char *param)
index 673d37317789a079b605d06f046006675ce1e937..f3f2321643160b0feada5661aa02ac9db2dbdde8 100644 (file)
@@ -869,7 +869,6 @@ static int net_conf_getparm(int argc, const char **argv)
 {
        int ret = -1;
        WERROR werr = WERR_OK;
-       struct registry_key *key = NULL;
        char *service = NULL;
        char *param = NULL;
        struct registry_value *value = NULL;
@@ -884,21 +883,20 @@ static int net_conf_getparm(int argc, const char **argv)
        service = strdup_lower(argv[0]);
        param = strdup_lower(argv[1]);
 
-       if (!libnet_smbconf_key_exists(ctx, service)) {
+       werr = libnet_smbconf_getparm(ctx, service, param, &value);
+
+       if (W_ERROR_EQUAL(werr, WERR_NO_SUCH_SERVICE)) {
                d_fprintf(stderr,
-                         "ERROR: given service '%s' does not exist.\n",
+                         "Error: given service '%s' does not exist.\n",
                          service);
                goto done;
-       }
-
-       werr = libnet_smbconf_open_path(ctx, service, REG_KEY_READ, &key);
-       if (!W_ERROR_IS_OK(werr)) {
+       } else if (W_ERROR_EQUAL(werr, WERR_INVALID_PARAM)) {
+               d_fprintf(stderr,
+                         "Error: given parameter '%s' is not set.\n",
+                         param);
                goto done;
-       }
-
-       werr = reg_queryvalue(ctx, key, param, &value);
-       if (!W_ERROR_IS_OK(werr)) {
-               d_fprintf(stderr, "Error querying value '%s': %s.\n",
+       } else if (!W_ERROR_IS_OK(werr)) {
+               d_fprintf(stderr, "Error getting value '%s': %s.\n",
                          param, dos_errstr(werr));
                goto done;
        }