mirror of
https://github.com/samba-team/samba.git
synced 2024-12-25 23:21:54 +03:00
Add netsessenum command to rpcclient.
Guenther
(This used to be commit f90306bd24
)
This commit is contained in:
parent
4c67f6c542
commit
28d5307034
@ -661,6 +661,89 @@ static WERROR cmd_srvsvc_net_sess_del(struct rpc_pipe_client *cli,
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static WERROR cmd_srvsvc_net_sess_enum(struct rpc_pipe_client *cli,
|
||||||
|
TALLOC_CTX *mem_ctx,
|
||||||
|
int argc, const char **argv)
|
||||||
|
{
|
||||||
|
WERROR result;
|
||||||
|
NTSTATUS status;
|
||||||
|
struct srvsvc_NetSessInfoCtr info_ctr;
|
||||||
|
struct srvsvc_NetSessCtr0 ctr0;
|
||||||
|
struct srvsvc_NetSessCtr1 ctr1;
|
||||||
|
struct srvsvc_NetSessCtr2 ctr2;
|
||||||
|
struct srvsvc_NetSessCtr10 ctr10;
|
||||||
|
struct srvsvc_NetSessCtr502 ctr502;
|
||||||
|
uint32_t total_entries = 0;
|
||||||
|
uint32_t resume_handle = 0;
|
||||||
|
uint32_t level = 1;
|
||||||
|
const char *client = NULL;
|
||||||
|
const char *user = NULL;
|
||||||
|
|
||||||
|
if (argc > 5) {
|
||||||
|
printf("Usage: %s [client] [user]\n", argv[0]);
|
||||||
|
return WERR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argc >= 2) {
|
||||||
|
client = argv[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argc >= 3) {
|
||||||
|
user = argv[2];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argc >= 4) {
|
||||||
|
level = atoi(argv[3]);
|
||||||
|
}
|
||||||
|
|
||||||
|
ZERO_STRUCT(info_ctr);
|
||||||
|
|
||||||
|
info_ctr.level = level;
|
||||||
|
|
||||||
|
d_printf("trying level: %d\n", level);
|
||||||
|
|
||||||
|
switch (level) {
|
||||||
|
case 0:
|
||||||
|
ZERO_STRUCT(ctr0);
|
||||||
|
info_ctr.ctr.ctr0 = &ctr0;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
ZERO_STRUCT(ctr1);
|
||||||
|
info_ctr.ctr.ctr1 = &ctr1;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
ZERO_STRUCT(ctr2);
|
||||||
|
info_ctr.ctr.ctr2 = &ctr2;
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
ZERO_STRUCT(ctr10);
|
||||||
|
info_ctr.ctr.ctr10 = &ctr10;
|
||||||
|
break;
|
||||||
|
case 502:
|
||||||
|
ZERO_STRUCT(ctr502);
|
||||||
|
info_ctr.ctr.ctr502 = &ctr502;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
status = rpccli_srvsvc_NetSessEnum(cli, mem_ctx,
|
||||||
|
cli->cli->desthost,
|
||||||
|
client,
|
||||||
|
user,
|
||||||
|
&info_ctr,
|
||||||
|
0xffffffff,
|
||||||
|
&total_entries,
|
||||||
|
&resume_handle,
|
||||||
|
&result);
|
||||||
|
|
||||||
|
if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
done:
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* List of commands exported by this module */
|
/* List of commands exported by this module */
|
||||||
|
|
||||||
@ -678,6 +761,7 @@ struct cmd_set srvsvc_commands[] = {
|
|||||||
{ "netnamevalidate", RPC_RTYPE_WERROR, NULL, cmd_srvsvc_net_name_validate, PI_SRVSVC, NULL, "Validate sharename", "" },
|
{ "netnamevalidate", RPC_RTYPE_WERROR, NULL, cmd_srvsvc_net_name_validate, PI_SRVSVC, NULL, "Validate sharename", "" },
|
||||||
{ "netfilegetsec", RPC_RTYPE_WERROR, NULL, cmd_srvsvc_net_file_get_sec, PI_SRVSVC, NULL, "Get File security", "" },
|
{ "netfilegetsec", RPC_RTYPE_WERROR, NULL, cmd_srvsvc_net_file_get_sec, PI_SRVSVC, NULL, "Get File security", "" },
|
||||||
{ "netsessdel", RPC_RTYPE_WERROR, NULL, cmd_srvsvc_net_sess_del, PI_SRVSVC, NULL, "Delete Session", "" },
|
{ "netsessdel", RPC_RTYPE_WERROR, NULL, cmd_srvsvc_net_sess_del, PI_SRVSVC, NULL, "Delete Session", "" },
|
||||||
|
{ "netsessenum", RPC_RTYPE_WERROR, NULL, cmd_srvsvc_net_sess_enum, PI_SRVSVC, NULL, "Enumerate Sessions", "" },
|
||||||
|
|
||||||
{ NULL }
|
{ NULL }
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user