diff options
Diffstat (limited to 'source/lib/netapi/examples/user/user_enum.c')
-rw-r--r-- | source/lib/netapi/examples/user/user_enum.c | 71 |
1 files changed, 7 insertions, 64 deletions
diff --git a/source/lib/netapi/examples/user/user_enum.c b/source/lib/netapi/examples/user/user_enum.c index cf77bf2d54..e1f6bda10b 100644 --- a/source/lib/netapi/examples/user/user_enum.c +++ b/source/lib/netapi/examples/user/user_enum.c @@ -32,18 +32,13 @@ int main(int argc, const char **argv) NET_API_STATUS status; struct libnetapi_ctx *ctx = NULL; const char *hostname = NULL; - uint32_t level = 0; uint8_t *buffer = NULL; uint32_t entries_read = 0; uint32_t total_entries = 0; uint32_t resume_handle = 0; - char *sid_str = NULL; int i; - struct USER_INFO_0 *info0 = NULL; - struct USER_INFO_10 *info10 = NULL; - struct USER_INFO_20 *info20 = NULL; - struct USER_INFO_23 *info23 = NULL; + struct USER_INFO_0 *info0; poptContext pc; int opt; @@ -61,7 +56,7 @@ int main(int argc, const char **argv) pc = poptGetContext("user_enum", argc, argv, long_options, 0); - poptSetOtherOptionHelp(pc, "hostname level"); + poptSetOtherOptionHelp(pc, "hostname"); while((opt = poptGetNextOpt(pc)) != -1) { } @@ -71,74 +66,22 @@ int main(int argc, const char **argv) } hostname = poptGetArg(pc); - if (poptPeekArg(pc)) { - level = atoi(poptGetArg(pc)); - } - /* NetUserEnum */ do { status = NetUserEnum(hostname, - level, - FILTER_NORMAL_ACCOUNT, + 0, + 0, &buffer, (uint32_t)-1, &entries_read, &total_entries, &resume_handle); if (status == 0 || status == ERROR_MORE_DATA) { - - switch (level) { - case 0: - info0 = (struct USER_INFO_0 *)buffer; - break; - case 10: - info10 = (struct USER_INFO_10 *)buffer; - break; - case 20: - info20 = (struct USER_INFO_20 *)buffer; - break; - case 23: - info23 = (struct USER_INFO_23 *)buffer; - break; - default: - break; - } - + info0 = (struct USER_INFO_0 *)buffer; for (i=0; i<entries_read; i++) { - switch (level) { - case 0: - printf("#%d user: %s\n", i, info0->usri0_name); - info0++; - break; - case 10: - printf("#%d user: %s\n", i, info10->usri10_name); - printf("#%d comment: %s\n", i, info10->usri10_comment); - printf("#%d usr_comment: %s\n", i, info10->usri10_usr_comment); - printf("#%d full_name: %s\n", i, info10->usri10_full_name); - info10++; - break; - case 20: - printf("#%d user: %s\n", i, info20->usri20_name); - printf("#%d comment: %s\n", i, info20->usri20_comment); - printf("#%d flags: 0x%08x\n", i, info20->usri20_flags); - printf("#%d rid: %d\n", i, info20->usri20_user_id); - info20++; - break; - case 23: - printf("#%d user: %s\n", i, info23->usri23_name); - printf("#%d comment: %s\n", i, info23->usri23_comment); - printf("#%d flags: 0x%08x\n", i, info23->usri23_flags); - if (ConvertSidToStringSid(info23->usri23_user_sid, - &sid_str)) { - printf("#%d sid: %s\n", i, sid_str); - free(sid_str); - } - info23++; - break; - default: - break; - } + printf("user %d: %s\n", i, info0->usri0_name); + info0++; } NetApiBufferFree(buffer); } |