diff options
| author | Günther Deschner <gd@samba.org> | 2008-04-09 13:50:30 +0200 | 
|---|---|---|
| committer | Günther Deschner <gd@samba.org> | 2008-04-09 13:50:30 +0200 | 
| commit | c12bf374fe4b7e1eb1a4f121f21495b4c5cb6725 (patch) | |
| tree | 5d52b787947fd394774cf5f1a113d7d9c5dbaa33 /source3/lib/netapi | |
| parent | 4801d0c6f3cd08cbbfc0d68d36632044356e9d12 (diff) | |
| download | samba-c12bf374fe4b7e1eb1a4f121f21495b4c5cb6725.tar.gz samba-c12bf374fe4b7e1eb1a4f121f21495b4c5cb6725.tar.bz2 samba-c12bf374fe4b7e1eb1a4f121f21495b4c5cb6725.zip | |
Add NetUserEnum example.
Guenther
(This used to be commit 7d9f64fd8401f8abb938757b4f092e25fd6b154f)
Diffstat (limited to 'source3/lib/netapi')
| -rw-r--r-- | source3/lib/netapi/examples/Makefile.in | 8 | ||||
| -rw-r--r-- | source3/lib/netapi/examples/user/user_enum.c | 100 | 
2 files changed, 107 insertions, 1 deletions
| diff --git a/source3/lib/netapi/examples/Makefile.in b/source3/lib/netapi/examples/Makefile.in index c00c505a3a..84a8ecf075 100644 --- a/source3/lib/netapi/examples/Makefile.in +++ b/source3/lib/netapi/examples/Makefile.in @@ -23,7 +23,8 @@ PROGS = bin/getdc@EXEEXT@ \  	bin/netdomjoin-gui@EXEEXT@ \  	bin/getjoinableous@EXEEXT@ \  	bin/user_add@EXEEXT@ \ -	bin/user_del@EXEEXT@ +	bin/user_del@EXEEXT@ \ +	bin/user_enum@EXEEXT@  all: $(PROGS) @@ -59,6 +60,7 @@ NETDOMJOIN_GUI_OBJ = netdomjoin-gui/netdomjoin-gui.o  GETJOINABLEOUS_OBJ = getjoinableous/getjoinableous.o $(CMDLINE_OBJ)  USERADD_OBJ = user/user_add.o $(CMDLINE_OBJ)  USERDEL_OBJ = user/user_del.o $(CMDLINE_OBJ) +USERENUM_OBJ = user/user_enum.o $(CMDLINE_OBJ)  bin/getdc@EXEEXT@: $(BINARY_PREREQS) $(GETDC_OBJ)  	@echo Linking $@ @@ -88,6 +90,10 @@ bin/user_del@EXEEXT@: $(BINARY_PREREQS) $(USERDEL_OBJ)  	@echo Linking $@  	@$(CC) $(FLAGS) -o $@ $(USERDEL_OBJ) $(LDFLAGS) $(DYNEXP) $(CMDLINE_LIBS) +bin/user_enum@EXEEXT@: $(BINARY_PREREQS) $(USERENUM_OBJ) +	@echo Linking $@ +	@$(CC) $(FLAGS) -o $@ $(USERENUM_OBJ) $(LDFLAGS) $(DYNEXP) $(CMDLINE_LIBS) +  clean:  	-rm -f $(PROGS)  	-rm -f core */*~ *~ \ diff --git a/source3/lib/netapi/examples/user/user_enum.c b/source3/lib/netapi/examples/user/user_enum.c new file mode 100644 index 0000000000..e1f6bda10b --- /dev/null +++ b/source3/lib/netapi/examples/user/user_enum.c @@ -0,0 +1,100 @@ +/* + *  Unix SMB/CIFS implementation. + *  NetUserEnum query + *  Copyright (C) Guenther Deschner 2007 + * + *  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 <http://www.gnu.org/licenses/>. + */ + +#include <sys/types.h> +#include <inttypes.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#include <netapi.h> + +#include "common.h" + +int main(int argc, const char **argv) +{ +	NET_API_STATUS status; +	struct libnetapi_ctx *ctx = NULL; +	const char *hostname = NULL; +	uint8_t *buffer = NULL; +	uint32_t entries_read = 0; +	uint32_t total_entries = 0; +	uint32_t resume_handle = 0; +	int i; + +	struct USER_INFO_0 *info0; + +	poptContext pc; +	int opt; + +	struct poptOption long_options[] = { +		POPT_AUTOHELP +		POPT_COMMON_LIBNETAPI_EXAMPLES +		POPT_TABLEEND +	}; + +	status = libnetapi_init(&ctx); +	if (status != 0) { +		return status; +	} + +	pc = poptGetContext("user_enum", argc, argv, long_options, 0); + +	poptSetOtherOptionHelp(pc, "hostname"); +	while((opt = poptGetNextOpt(pc)) != -1) { +	} + +	if (!poptPeekArg(pc)) { +		poptPrintHelp(pc, stderr, 0); +		goto out; +	} +	hostname = poptGetArg(pc); + +	/* NetUserEnum */ + +	do { +		status = NetUserEnum(hostname, +				     0, +				     0, +				     &buffer, +				     (uint32_t)-1, +				     &entries_read, +				     &total_entries, +				     &resume_handle); +		if (status == 0 || status == ERROR_MORE_DATA) { +			info0 = (struct USER_INFO_0 *)buffer; +			for (i=0; i<entries_read; i++) { +				printf("user %d: %s\n", i, info0->usri0_name); +				info0++; +			} +			NetApiBufferFree(buffer); +		} +	} while (status == ERROR_MORE_DATA); + +	if (status != 0) { +		printf("NetUserEnum failed with: %s\n", +			libnetapi_get_error_string(ctx, status)); +	} + + out: +	libnetapi_free(ctx); +	poptFreeContext(pc); + +	return status; +} | 
