/* * Unix SMB/CIFS implementation. * NetGroup testsuite * Copyright (C) Guenther Deschner 2008 * * 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 #include #include #include #include #include #include "common.h" static NET_API_STATUS test_netgroupenum(const char *hostname, uint32_t level, const char *groupname) { NET_API_STATUS status; uint32_t entries_read = 0; uint32_t total_entries = 0; uint32_t resume_handle = 0; int found_group = 0; const char *current_name = NULL; uint8_t *buffer = NULL; int i; struct GROUP_INFO_0 *info0 = NULL; struct GROUP_INFO_1 *info1 = NULL; struct GROUP_INFO_2 *info2 = NULL; struct GROUP_INFO_3 *info3 = NULL; printf("testing NetGroupEnum level %d\n", level); do { status = NetGroupEnum(hostname, level, &buffer, 120, //(uint32_t)-1, &entries_read, &total_entries, &resume_handle); if (status == 0 || status == ERROR_MORE_DATA) { switch (level) { case 0: info0 = (struct GROUP_INFO_0 *)buffer; break; case 1: info1 = (struct GROUP_INFO_1 *)buffer; break; case 2: info2 = (struct GROUP_INFO_2 *)buffer; break; case 3: info3 = (struct GROUP_INFO_3 *)buffer; break; default: return -1; } for (i=0; igrpi0_name; break; case 1: current_name = info1->grpi1_name; break; case 2: current_name = info2->grpi2_name; break; case 3: current_name = info3->grpi3_name; break; default: break; } if (strcasecmp(current_name, groupname) == 0) { found_group = 1; } switch (level) { case 0: info0++; break; case 1: info1++; break; case 2: info2++; break; case 3: info3++; break; } } NetApiBufferFree(buffer); } } while (status == ERROR_MORE_DATA); if (status) { return status; } if (!found_group) { printf("failed to get group\n"); return -1; } return 0; } static NET_API_STATUS test_netgroupgetusers(const char *hostname, uint32_t level, const char *groupname, const char *username) { NET_API_STATUS status; uint32_t entries_read = 0; uint32_t total_entries = 0; uint32_t resume_handle = 0; int found_user = 0; const char *current_name = NULL; uint8_t *buffer = NULL; int i; struct GROUP_USERS_INFO_0 *info0 = NULL; struct GROUP_USERS_INFO_1 *info1 = NULL; printf("testing NetGroupGetUsers level %d\n", level); do { status = NetGroupGetUsers(hostname, groupname, level, &buffer, (uint32_t)-1, &entries_read, &total_entries, &resume_handle); if (status == 0 || status == ERROR_MORE_DATA) { switch (level) { case 0: info0 = (struct GROUP_USERS_INFO_0 *)buffer; break; case 1: info1 = (struct GROUP_USERS_INFO_1 *)buffer; break; default: break; } for (i=0; igrui0_name; break; case 1: current_name = info1->grui1_name; break; default: break; } if (username && strcasecmp(current_name, username) == 0) { found_user = 1; } switch (level) { case 0: info0++; break; case 1: info1++; break; } } NetApiBufferFree(buffer); } } while (status == ERROR_MORE_DATA); if (status) { return status; } if (username && !found_user) { printf("failed to get user\n"); return -1; } return 0; } static NET_API_STATUS test_netgroupsetusers(const char *hostname, const char *groupname, uint32_t level, size_t num_entries, const char **names) { NET_API_STATUS status; uint8_t *buffer = NULL; int i = 0; size_t buf_size = 0; struct GROUP_USERS_INFO_0 *g0 = NULL; struct GROUP_USERS_INFO_1 *g1 = NULL; printf("testing NetGroupSetUsers level %d\n", level); switch (level) { case 0: buf_size = sizeof(struct GROUP_USERS_INFO_0) * num_entries; status = NetApiBufferAllocate(buf_size, (void **)&g0); if (status) { goto out; } for (i=0; i