From caa27bb165a69766585ec4a13a6c09fa774d3b48 Mon Sep 17 00:00:00 2001 From: Michael Adam Date: Fri, 26 Feb 2010 09:37:45 +0100 Subject: s3:net: add new subcommand "net registry getsd_sddl" to print secdesc in sddl format Michael --- source3/utils/net_registry.c | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) 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 \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 } }; -- cgit