diff options
author | Tim Potter <tpot@samba.org> | 2003-07-03 05:08:51 +0000 |
---|---|---|
committer | Tim Potter <tpot@samba.org> | 2003-07-03 05:08:51 +0000 |
commit | baf439cd55d79133e2fca598834e362a81a911a4 (patch) | |
tree | df8a6ebe54775fa945dd6be542379e3055ca96ae /source3/utils | |
parent | d304a61cc70af9bec3f630043f3e7e600352deea (diff) | |
download | samba-baf439cd55d79133e2fca598834e362a81a911a4.tar.gz samba-baf439cd55d79133e2fca598834e362a81a911a4.tar.bz2 samba-baf439cd55d79133e2fca598834e362a81a911a4.zip |
Implemented 'net ads printer search' which searches the directory for
published printers.
At the moment we don't search using any parameters but this can be
fixed by changing the LDAP search string. Also we should contact
the global catalog at SRV _gc._tcp instead of the ldap server we
get back from ads_startup().
(This used to be commit 814519c5de7f962623163b732c8589abd355d845)
Diffstat (limited to 'source3/utils')
-rw-r--r-- | source3/utils/net_ads.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/source3/utils/net_ads.c b/source3/utils/net_ads.c index 9454cbc9f5..84bec81434 100644 --- a/source3/utils/net_ads.c +++ b/source3/utils/net_ads.c @@ -726,6 +726,8 @@ int net_ads_join(int argc, const char **argv) int net_ads_printer_usage(int argc, const char **argv) { d_printf( +"\nnet ads printer search <printer>" +"\n\tsearch for a printer in the directory" "\nnet ads printer info <printer> <server>" "\n\tlookup info in directory for printer on server" "\n\t(note: printer defaults to \"*\", server defaults to local)\n" @@ -738,6 +740,35 @@ int net_ads_printer_usage(int argc, const char **argv) return -1; } +static int net_ads_printer_search(int argc, const char **argv) +{ + ADS_STRUCT *ads; + ADS_STATUS rc; + void *res = NULL; + + if (!(ads = ads_startup())) + return -1; + + rc = ads_find_printers(ads, &res); + + if (!ADS_ERR_OK(rc)) { + d_printf("ads_find_printer: %s\n", ads_errstr(rc)); + ads_msgfree(ads, res); + return -1; + } + + if (ads_count_replies(ads, res) == 0) { + d_printf("No results found\n"); + ads_msgfree(ads, res); + return -1; + } + + ads_dump(ads, res); + ads_msgfree(ads, res); + + return 0; +} + static int net_ads_printer_info(int argc, const char **argv) { ADS_STRUCT *ads; @@ -882,6 +913,7 @@ static int net_ads_printer_remove(int argc, const char **argv) static int net_ads_printer(int argc, const char **argv) { struct functable func[] = { + {"SEARCH", net_ads_printer_search}, {"INFO", net_ads_printer_info}, {"PUBLISH", net_ads_printer_publish}, {"REMOVE", net_ads_printer_remove}, |