/* Samba Unix/Linux SMB client library net ads commands for Group Policy Copyright (C) 2005-2008 Guenther Deschner Copyright (C) 2009 Wilco Baan Hofman Based on Guenther's work in net_ads_gpo.h (samba 3) This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "includes.h" #include "utils/net/net.h" #include "lib/ldb/include/ldb.h" #include "auth/auth.h" #include "param/param.h" #include "libgpo/gpo.h" static int net_gpo_list_all_usage(struct net_context *ctx, int argc, const char **argv) { d_printf("Syntax: net gpo listall [options]\n"); d_printf("For a list of available options, please type net gpo listall --help\n"); return 0; } static int net_gpo_list_all(struct net_context *ctx, int argc, const char **argv) { struct gp_context *gp_ctx; struct gp_object **gpo; const char **gpo_flags; unsigned int i, j; NTSTATUS rv; rv = gp_init(ctx, ctx->lp_ctx, ctx->credentials, ctx->event_ctx, &gp_ctx); if (!NT_STATUS_IS_OK(rv)) { DEBUG(0, ("Failed to connect to DC's LDAP: %s\n", get_friendly_nt_error_msg(rv))); return 1; } rv = gp_list_all_gpos(gp_ctx, &gpo); if (!NT_STATUS_IS_OK(rv)) { DEBUG(0, ("Failed to list all GPO's: %s\n", get_friendly_nt_error_msg(rv))); return 1; } for (i = 0; gpo[i] != NULL; i++) { gp_get_gpo_flags(gp_ctx, gpo[i]->flags, &gpo_flags); d_printf("GPO : %s\n", gpo[i]->name); d_printf("display name : %s\n", gpo[i]->display_name); d_printf("path : %s\n", gpo[i]->file_sys_path); d_printf("dn : %s\n", gpo[i]->dn); d_printf("version : %d\n", gpo[i]->version); if (gpo_flags[0] == NULL) { d_printf("flags : NONE\n"); } else { d_printf("flags : %s\n", gpo_flags[0]); for (j = 1; gpo_flags[j] != NULL; j++) { d_printf(" %s\n", gpo_flags[i]); } } d_printf("\n"); talloc_free(gpo_flags); } talloc_free(gp_ctx); return 0; } static int net_gpo_get_gpo_usage(struct net_context *ctx, int argc, const char **argv) { d_printf("Syntax: net gpo getgpo [options]\n"); d_printf("For a list of available options, please type net gpo getgpo --help\n"); return 0; } static int net_gpo_get_gpo(struct net_context *ctx, int argc, const char **argv) { struct gp_context *gp_ctx; struct gp_object *gpo; const char **gpo_flags; int i; NTSTATUS rv; if (argc != 1) { return net_gpo_get_gpo_usage(ctx, argc, argv); } rv = gp_init(ctx, ctx->lp_ctx, ctx->credentials, ctx->event_ctx, &gp_ctx); if (!NT_STATUS_IS_OK(rv)) { DEBUG(0, ("Failed to connect to DC's LDAP: %s\n", get_friendly_nt_error_msg(rv))); return 1; } rv = gp_get_gpo_info(gp_ctx, argv[0], &gpo); if (!NT_STATUS_IS_OK(rv)) { DEBUG(0, ("Failed to get GPO: %s\n", get_friendly_nt_error_msg(rv))); return 1; } gp_get_gpo_flags(gp_ctx, gpo->flags, &gpo_flags); d_printf("GPO : %s\n", gpo->name); d_printf("display name : %s\n", gpo->display_name); d_printf("path : %s\n", gpo->file_sys_path); d_printf("dn : %s\n", gpo->dn); d_printf("version : %d\n", gpo->version); if (gpo_flags[0] == NULL) { d_printf("flags : NONE\n"); } else { d_printf("flags : %s\n", gpo_flags[0]); for (i = 1; gpo_flags[i] != NULL; i++) { d_printf(" %s\n", gpo_flags[i]); } } d_printf("\n"); talloc_free(gp_ctx); return 0; } static int net_gpo_link_get_usage(struct net_context *ctx, int argc, const char **argv) { d_printf("Syntax: net gpo linkget [options]\n"); d_printf("For a list of available options, please type net gpo linkget --help\n"); return 0; } static int net_gpo_link_get(struct net_context *ctx, int argc, const char **argv) { struct gp_context *gp_ctx; struct gp_link **links; NTSTATUS rv; unsigned int i,j; const char **options; if (argc != 1) { return net_gpo_link_get_usage(ctx, argc, argv); } rv = gp_init(ctx, ctx->lp_ctx, ctx->credentials, ctx->event_ctx, &gp_ctx); if (!NT_STATUS_IS_OK(rv)) { DEBUG(0, ("Failed to connect to DC's LDAP: %s\n", get_friendly_nt_error_msg(rv))); return 1; } rv = gp_get_gplinks(gp_ctx, argv[0], &links); if (!NT_STATUS_IS_OK(rv)) { DEBUG(0, ("Failed to get gplinks: %s\n", get_friendly_nt_error_msg(rv))); return 1; } for (i = 0; links[i] != NULL; i++) { gp_get_gplink_options(gp_ctx, links[i]->options, &options); d_printf("GPO DN : %s\n", links[i]->dn); if (options[0] == NULL) { d_printf("Options : NONE\n"); } else { d_printf("Options : %s\n", options[0]); for (j = 1; options[j] != NULL; j++) { d_printf(" : %s\n", options[j]); } } d_printf("\n"); talloc_free(options); } talloc_free(gp_ctx); return 0; } static int net_gpo_list_usage(struct net_context *ctx, int argc, const char **argv) { d_printf("Syntax: net gpo list [options]\n"); d_printf("For a list of available options, please type net gpo list --help\n"); return 0; } static int net_gpo_list(struct net_context *ctx, int argc, const char **argv) { struct gp_context *gp_ctx; struct ldb_result *result; struct auth_serversupplied_info *server_info; struct auth_session_info *session_info; DATA_BLOB dummy = { NULL, 0 }; const char **gpos; NTSTATUS status; int rv; unsigned int i; if (argc != 1) { return net_gpo_list_usage(ctx, argc, argv); } status = gp_init(ctx, ctx->lp_ctx, ctx->credentials, ctx->event_ctx, &gp_ctx); if (!NT_STATUS_IS_OK(status)) { DEBUG(0, ("Failed to connect to DC's LDAP: %s\n", get_friendly_nt_error_msg(status))); return 1; } rv = ldb_search(gp_ctx->ldb_ctx, gp_ctx, &result, ldb_get_default_basedn(gp_ctx->ldb_ctx), LDB_SCOPE_SUBTREE, NULL, "(&(objectClass=user)(sAMAccountName=%s))", argv[0]); if (rv != LDB_SUCCESS) { DEBUG(0, ("LDB search failed: %s\n%s\n", ldb_strerror(rv),ldb_errstring(gp_ctx->ldb_ctx))); talloc_free(gp_ctx); return 1; } /* We expect exactly one record */ if (result->count != 1) { DEBUG(0, ("Could not find SAM account with name %s\n", argv[0])); talloc_free(gp_ctx); return 1; } status = authsam_make_server_info(gp_ctx, gp_ctx->ldb_ctx, lp_netbios_name(gp_ctx->lp_ctx), lp_sam_name(gp_ctx->lp_ctx), ldb_get_default_basedn(gp_ctx->ldb_ctx), result->msgs[0], dummy, dummy, &server_info); if (!NT_STATUS_IS_OK(status)) { DEBUG(0, ("Failed to make server information: %s\n", get_friendly_nt_error_msg(status))); talloc_free(gp_ctx); return 1; } status = auth_generate_session_info2(gp_ctx, gp_ctx->ev_ctx, gp_ctx->lp_ctx, server_info, &session_info); if (!NT_STATUS_IS_OK(status)) { DEBUG(0, ("Failed to generate session information: %s\n", get_friendly_nt_error_msg(status))); talloc_free(gp_ctx); return 1; } status = gp_list_gpos(gp_ctx, session_info->security_token, &gpos); if (!NT_STATUS_IS_OK(status)) { DEBUG(0, ("Failed to list gpos for user %s: %s\n", argv[0], get_friendly_nt_error_msg(status))); talloc_free(gp_ctx); return 1; } d_printf("GPO's for user %s:\n", argv[0]); for (i = 0; gpos[i] != NULL; i++) { d_printf("\t%s\n", gpos[i]); } talloc_free(gp_ctx); return 0; } static const struct net_functable net_gpo_functable[] = { { "listall", "List all GPO's on a DC\n", net_gpo_list_all, net_gpo_list_all_usage }, { "getgpo", "List specificied GPO\n", net_gpo_get_gpo, net_gpo_get_gpo_usage }, { "linkget", "List gPLink of container\n", net_gpo_link_get, net_gpo_link_get_usage }, /* { "apply", "Apply GPO to container\n", net_gpo_apply, net_gpo_usage }, */ // { "linkadd", "Link a GPO to a container\n", net_gpo_link_add, net_gpo_usage }, /* { "linkdelete", "Delete GPO link from a container\n", net_gpo_link_delete, net_gpo_usage }, */ { "list", "List all GPO's for a machine/user\n", net_gpo_list, net_gpo_list_usage }, // { "refresh", "List all GPO's for machine/user and download them\n", net_gpo_refresh, net_gpo_refresh_usage }, { NULL, NULL } }; int net_gpo_usage(struct net_context *ctx, int argc, const char **argv) { d_printf("Syntax: net gpo [options]\n"); d_printf("For available commands, please type net gpo help\n"); return 0; } int net_gpo(struct net_context *ctx, int argc, const char **argv) { return net_run_function(ctx, argc, argv, net_gpo_functable, net_gpo_usage); }