diff options
author | Michael Adam <obnox@samba.org> | 2009-03-04 22:02:07 +0100 |
---|---|---|
committer | Michael Adam <obnox@samba.org> | 2009-03-04 22:49:24 +0100 |
commit | 9d798494a90c13d605a52644a1a386a9fb109063 (patch) | |
tree | ee0c8e49be78055f14b26b135c842029c9cfe758 /source3/lib | |
parent | 094578903184e2702d2a5000bf448a89954acf95 (diff) | |
download | samba-9d798494a90c13d605a52644a1a386a9fb109063.tar.gz samba-9d798494a90c13d605a52644a1a386a9fb109063.tar.bz2 samba-9d798494a90c13d605a52644a1a386a9fb109063.zip |
s3:smbconf: move smbconf_share_exists checks into backend
Michael
Diffstat (limited to 'source3/lib')
-rw-r--r-- | source3/lib/smbconf/smbconf_reg.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/source3/lib/smbconf/smbconf_reg.c b/source3/lib/smbconf/smbconf_reg.c index 5a5c0ead65..ae6a41151d 100644 --- a/source3/lib/smbconf/smbconf_reg.c +++ b/source3/lib/smbconf/smbconf_reg.c @@ -80,12 +80,20 @@ static WERROR smbconf_reg_open_service_key(TALLOC_CTX *mem_ctx, uint32 desired_access, struct registry_key **key) { + WERROR werr; + if (servicename == NULL) { *key = rpd(ctx)->base_key; return WERR_OK; } - return reg_openkey(mem_ctx, rpd(ctx)->base_key, servicename, + werr = reg_openkey(mem_ctx, rpd(ctx)->base_key, servicename, desired_access, key); + + if (W_ERROR_EQUAL(werr, WERR_BADFILE)) { + werr = WERR_NO_SUCH_SERVICE; + } + + return werr; } /** @@ -828,9 +836,6 @@ static WERROR smbconf_reg_get_share(struct smbconf_ctx *ctx, werr = smbconf_reg_open_service_key(tmp_ctx, ctx, servicename, REG_KEY_READ, &key); if (!W_ERROR_IS_OK(werr)) { - if (W_ERROR_EQUAL(werr, WERR_BADFILE)) { - werr = WERR_NO_SUCH_SERVICE; - } goto done; } |