2 Unix SMB/CIFS implementation.
5 Copyright (C) Guenther Deschner 2008
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>.
22 #include "rpcclient.h"
24 static WERROR
cmd_drsuapi_cracknames(struct rpc_pipe_client
*cli
,
25 TALLOC_CTX
*mem_ctx
, int argc
,
32 struct GUID bind_guid
;
33 struct policy_handle bind_handle
;
36 union drsuapi_DsNameRequest req
;
38 union drsuapi_DsNameCtr ctr
;
39 struct drsuapi_DsNameString names
[1];
42 printf("usage: %s name\n", argv
[0]);
46 GUID_from_string(DRSUAPI_DS_BIND_GUID
, &bind_guid
);
48 status
= rpccli_drsuapi_DsBind(cli
, mem_ctx
,
54 if (!NT_STATUS_IS_OK(status
)) {
55 return ntstatus_to_werror(status
);
58 names
[0].str
= argv
[1];
60 req
.req1
.codepage
= 1252; /* german */
61 req
.req1
.language
= 0x00000407; /* german */
63 req
.req1
.names
= names
;
64 req
.req1
.format_flags
= DRSUAPI_DS_NAME_FLAG_NO_FLAGS
;
65 req
.req1
.format_offered
= DRSUAPI_DS_NAME_FORMAT_UKNOWN
;
66 req
.req1
.format_desired
= DRSUAPI_DS_NAME_FORMAT_FQDN_1779
;
68 status
= rpccli_drsuapi_DsCrackNames(cli
, mem_ctx
,
76 if (!NT_STATUS_IS_OK(status
)) {
77 werr
= ntstatus_to_werror(status
);
81 if (!W_ERROR_IS_OK(werr
)) {
85 for (i
=0; i
< ctr
.ctr1
->count
; i
++) {
86 printf("status: %d\n",
87 ctr
.ctr1
->array
[i
].status
);
88 printf("dns_domain_name: %s\n",
89 ctr
.ctr1
->array
[i
].dns_domain_name
);
90 printf("result_name: %s\n",
91 ctr
.ctr1
->array
[i
].result_name
);
95 if (is_valid_policy_hnd(&bind_handle
)) {
96 rpccli_drsuapi_DsUnbind(cli
, mem_ctx
, &bind_handle
, &werr
);
102 static void display_domain_controller_info_01(struct drsuapi_DsGetDCConnection01
*r
)
104 printf("client_ip_address:\t%s\n", r
->client_ip_address
);
105 printf("unknown2:\t%d\n", r
->unknown2
);
106 printf("connection_time:\t%d\n", r
->connection_time
);
107 printf("unknown4:\t%d\n", r
->unknown4
);
108 printf("unknown5:\t%d\n", r
->unknown5
);
109 printf("unknown6:\t%d\n", r
->unknown6
);
110 printf("client_account:\t%s\n", r
->client_account
);
113 static void display_domain_controller_info_1(struct drsuapi_DsGetDCInfo1
*r
)
115 printf("netbios_name:\t%s\n", r
->netbios_name
);
116 printf("dns_name:\t%s\n", r
->dns_name
);
117 printf("site_name:\t%s\n", r
->site_name
);
118 printf("computer_dn:\t%s\n", r
->computer_dn
);
119 printf("server_dn:\t%s\n", r
->server_dn
);
120 printf("is_pdc:\t\t%s\n", r
->is_pdc
? "true" : "false");
121 printf("is_enabled:\t%s\n", r
->is_enabled
? "true" : "false");
124 static void display_domain_controller_info_2(struct drsuapi_DsGetDCInfo2
*r
)
126 printf("netbios_name:\t%s\n", r
->netbios_name
);
127 printf("dns_name:\t%s\n", r
->dns_name
);
128 printf("site_name:\t%s\n", r
->site_name
);
129 printf("site_dn:\t%s\n", r
->site_dn
);
130 printf("computer_dn:\t%s\n", r
->computer_dn
);
131 printf("server_dn:\t%s\n", r
->server_dn
);
132 printf("ntds_dn:\t%s\n", r
->ntds_dn
);
133 printf("is_pdc:\t\t%s\n", r
->is_pdc
? "true" : "false");
134 printf("is_enabled:\t%s\n", r
->is_enabled
? "true" : "false");
135 printf("is_gc:\t\t%s\n", r
->is_gc
? "true" : "false");
136 printf("site_guid:\t%s\n", GUID_string(talloc_tos(), &r
->site_guid
));
137 printf("computer_guid:\t%s\n", GUID_string(talloc_tos(), &r
->computer_guid
));
138 printf("server_guid:\t%s\n", GUID_string(talloc_tos(), &r
->server_guid
));
139 printf("ntds_guid:\t%s\n", GUID_string(talloc_tos(), &r
->ntds_guid
));
142 static void display_domain_controller_info_3(struct drsuapi_DsGetDCInfo3
*r
)
144 printf("netbios_name:\t%s\n", r
->netbios_name
);
145 printf("dns_name:\t%s\n", r
->dns_name
);
146 printf("site_name:\t%s\n", r
->site_name
);
147 printf("site_dn:\t%s\n", r
->site_dn
);
148 printf("computer_dn:\t%s\n", r
->computer_dn
);
149 printf("server_dn:\t%s\n", r
->server_dn
);
150 printf("ntds_dn:\t%s\n", r
->ntds_dn
);
151 printf("is_pdc:\t\t%s\n", r
->is_pdc
? "true" : "false");
152 printf("is_enabled:\t%s\n", r
->is_enabled
? "true" : "false");
153 printf("is_gc:\t\t%s\n", r
->is_gc
? "true" : "false");
154 printf("is_rodc:\t%s\n", r
->is_rodc
? "true" : "false");
155 printf("site_guid:\t%s\n", GUID_string(talloc_tos(), &r
->site_guid
));
156 printf("computer_guid:\t%s\n", GUID_string(talloc_tos(), &r
->computer_guid
));
157 printf("server_guid:\t%s\n", GUID_string(talloc_tos(), &r
->server_guid
));
158 printf("ntds_guid:\t%s\n", GUID_string(talloc_tos(), &r
->ntds_guid
));
161 static void display_domain_controller_info(int32_t level
,
162 union drsuapi_DsGetDCInfoCtr
*ctr
)
167 case DRSUAPI_DC_CONNECTION_CTR_01
:
168 for (i
=0; i
<ctr
->ctr01
.count
; i
++) {
169 printf("----------\n");
170 display_domain_controller_info_01(&ctr
->ctr01
.array
[i
]);
173 case DRSUAPI_DC_INFO_CTR_1
:
174 for (i
=0; i
<ctr
->ctr1
.count
; i
++) {
175 printf("----------\n");
176 display_domain_controller_info_1(&ctr
->ctr1
.array
[i
]);
179 case DRSUAPI_DC_INFO_CTR_2
:
180 for (i
=0; i
<ctr
->ctr2
.count
; i
++) {
181 printf("----------\n");
182 display_domain_controller_info_2(&ctr
->ctr2
.array
[i
]);
185 case DRSUAPI_DC_INFO_CTR_3
:
186 for (i
=0; i
<ctr
->ctr3
.count
; i
++) {
187 printf("----------\n");
188 display_domain_controller_info_3(&ctr
->ctr3
.array
[i
]);
196 static WERROR
cmd_drsuapi_getdcinfo(struct rpc_pipe_client
*cli
,
197 TALLOC_CTX
*mem_ctx
, int argc
,
203 struct GUID bind_guid
;
204 struct policy_handle bind_handle
;
206 const char *domain
= NULL
;
209 union drsuapi_DsGetDCInfoRequest req
;
210 union drsuapi_DsGetDCInfoCtr ctr
;
213 printf("usage: %s domain [level]\n", argv
[0]);
219 level
= atoi(argv
[2]);
222 GUID_from_string(DRSUAPI_DS_BIND_GUID
, &bind_guid
);
224 status
= rpccli_drsuapi_DsBind(cli
, mem_ctx
,
230 if (!NT_STATUS_IS_OK(status
)) {
231 return ntstatus_to_werror(status
);
234 req
.req1
.domain_name
= domain
;
235 req
.req1
.level
= level
;
237 status
= rpccli_drsuapi_DsGetDomainControllerInfo(cli
, mem_ctx
,
244 if (!NT_STATUS_IS_OK(status
)) {
245 werr
= ntstatus_to_werror(status
);
249 if (!W_ERROR_IS_OK(werr
)) {
253 display_domain_controller_info(level_out
, &ctr
);
255 if (is_valid_policy_hnd(&bind_handle
)) {
256 rpccli_drsuapi_DsUnbind(cli
, mem_ctx
, &bind_handle
, &werr
);
262 /* List of commands exported by this module */
264 struct cmd_set drsuapi_commands
[] = {
267 { "dscracknames", RPC_RTYPE_WERROR
, NULL
, cmd_drsuapi_cracknames
, PI_DRSUAPI
, NULL
, "Crack Name", "" },
268 { "dsgetdcinfo", RPC_RTYPE_WERROR
, NULL
, cmd_drsuapi_getdcinfo
, PI_DRSUAPI
, NULL
, "Get Domain Controller Info", "" },