diff options
author | Michael Adam <obnox@samba.org> | 2010-02-26 09:37:45 +0100 |
---|---|---|
committer | Michael Adam <obnox@samba.org> | 2010-03-03 09:16:37 +0100 |
commit | caa27bb165a69766585ec4a13a6c09fa774d3b48 (patch) | |
tree | 6b91068dbedf75618d2496f89f51212e829f63e4 /source3/utils | |
parent | 93d438d9709e8e6462721f010c9a484a92a6649a (diff) | |
download | samba-caa27bb165a69766585ec4a13a6c09fa774d3b48.tar.gz samba-caa27bb165a69766585ec4a13a6c09fa774d3b48.tar.bz2 samba-caa27bb165a69766585ec4a13a6c09fa774d3b48.zip |
s3:net: add new subcommand "net registry getsd_sddl" to print secdesc in sddl format
Michael
Diffstat (limited to 'source3/utils')
-rw-r--r-- | source3/utils/net_registry.c | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/source3/utils/net_registry.c b/source3/utils/net_registry.c index 2a13ebd6bd..bf65c4de38 100644 --- a/source3/utils/net_registry.c +++ b/source3/utils/net_registry.c @@ -502,6 +502,38 @@ done: return ret; } +static int net_registry_getsd_sddl(struct net_context *c, + int argc, const char **argv) +{ + WERROR werr; + int ret = -1; + struct security_descriptor *secdesc = NULL; + TALLOC_CTX *ctx = talloc_stackframe(); + + if (argc != 1 || c->display_usage) { + d_printf("%s\n%s", + _("Usage:"), + _("net registry getsd_sddl <path>\n")); + d_printf("%s\n%s", + _("Example:"), + _("net registry getsd_sddl 'HKLM\\Software\\Samba'\n")); + goto done; + } + + werr = net_registry_getsd_internal(c, ctx, argv[0], &secdesc); + if (!W_ERROR_IS_OK(werr)) { + goto done; + } + + d_printf("%s\n", sddl_encode(ctx, secdesc, get_global_sam_sid())); + + ret = 0; + +done: + TALLOC_FREE(ctx); + return ret; +} + int net_registry(struct net_context *c, int argc, const char **argv) { int ret = -1; @@ -571,6 +603,14 @@ int net_registry(struct net_context *c, int argc, const char **argv) N_("net registry getsd\n" " Get security descriptor") }, + { + "getsd_sddl", + net_registry_getsd_sddl, + NET_TRANSPORT_LOCAL, + N_("Get security descriptor in sddl format"), + N_("net registry getsd_sddl\n" + " Get security descriptor in sddl format") + }, { NULL, NULL, 0, NULL, NULL } }; |