The branch, master has been updated
       via  08223692c69963bdb47b1687dc5be760e0c7ad7b (commit)
       via  6e493fc631647c1c4d19f77dd9f625202bd889f2 (commit)
      from  717ef3867a22a5f7427a04083da6cc0b50353bd2 (commit)

http://gitweb.samba.org/?p=samba.git;a=shortlog;h=master


- Log -----------------------------------------------------------------
commit 08223692c69963bdb47b1687dc5be760e0c7ad7b
Author: Jelmer Vernooij <[EMAIL PROTECTED]>
Date:   Wed Oct 8 12:03:45 2008 +0200

    fix libclinbtsrcdir variable.

commit 6e493fc631647c1c4d19f77dd9f625202bd889f2
Author: Jelmer Vernooij <[EMAIL PROTECTED]>
Date:   Wed Oct 8 11:56:46 2008 +0200

    Add manpage for nmblookup, move nmblookup closer to nbt library.

-----------------------------------------------------------------------

Summary of changes:
 source3/samba4.mk                      |    2 +-
 source4/Makefile                       |    2 +-
 source4/libcli/config.mk               |   26 ++-
 source4/libcli/nbt/man/nmblookup.1.xml |  223 +++++++++++++++++++
 source4/libcli/nbt/tools/nmblookup.c   |  381 ++++++++++++++++++++++++++++++++
 source4/utils/config.mk                |   17 --
 source4/utils/nmblookup.c              |  381 --------------------------------
 7 files changed, 626 insertions(+), 406 deletions(-)
 create mode 100644 source4/libcli/nbt/man/nmblookup.1.xml
 create mode 100644 source4/libcli/nbt/tools/nmblookup.c
 delete mode 100644 source4/utils/nmblookup.c


Changeset truncated at 500 lines:

diff --git a/source3/samba4.mk b/source3/samba4.mk
index 3abcbe1..524fc9f 100644
--- a/source3/samba4.mk
+++ b/source3/samba4.mk
@@ -107,7 +107,7 @@ ntvfssrcdir := $(samba4srcdir)/ntvfs
 ntptrsrcdir := $(samba4srcdir)/ntptr
 clientsrcdir := $(samba4srcdir)/client
 libclisrcdir := $(samba4srcdir)/libcli
-libclinbtsrcdir := $(samba4srcdir)/../libcli
+libclinbtsrcdir := $(samba4srcdir)/../libcli/nbt
 pyscriptsrcdir := $(samba4srcdir)/scripting/python
 kdcsrcdir := $(samba4srcdir)/kdc
 smbreadlinesrcdir := $(samba4srcdir)/lib/smbreadline
diff --git a/source4/Makefile b/source4/Makefile
index 74383b1..cab8267 100644
--- a/source4/Makefile
+++ b/source4/Makefile
@@ -97,7 +97,7 @@ ntvfssrcdir := ntvfs
 ntptrsrcdir := ntptr
 librpcsrcdir := librpc
 libclisrcdir := libcli
-libclinbtsrcdir := ../libcli
+libclinbtsrcdir := ../libcli/nbt
 pyscriptsrcdir := $(srcdir)/scripting/python
 kdcsrcdir := kdc
 ntp_signdsrcdir := ntp_signd
diff --git a/source4/libcli/config.mk b/source4/libcli/config.mk
index d68a2a2..8d9a1f5 100644
--- a/source4/libcli/config.mk
+++ b/source4/libcli/config.mk
@@ -40,38 +40,52 @@ $(eval $(call 
proto_header_template,$(libclisrcdir)/smb_composite/proto.h,$(LIBC
 
 [SUBSYSTEM::NDR_NBT_BUF]
 
-NDR_NBT_BUF_OBJ_FILES = $(libclinbtsrcdir)/nbt/nbtname.o
+NDR_NBT_BUF_OBJ_FILES = $(libclinbtsrcdir)/nbtname.o
 
-$(eval $(call 
proto_header_template,$(libclinbtsrcdir)/nbt/nbtname.h,$(NDR_NBT_BUF_OBJ_FILES:.o=.c)))
+$(eval $(call 
proto_header_template,$(libclinbtsrcdir)/nbtname.h,$(NDR_NBT_BUF_OBJ_FILES:.o=.c)))
 
 [SUBSYSTEM::LIBCLI_NBT]
 PUBLIC_DEPENDENCIES = LIBNDR NDR_NBT LIBCLI_COMPOSITE LIBEVENTS \
        NDR_SECURITY samba-socket LIBSAMBA-UTIL
 
-LIBCLI_NBT_OBJ_FILES = $(addprefix $(libclinbtsrcdir)/nbt/, \
+LIBCLI_NBT_OBJ_FILES = $(addprefix $(libclinbtsrcdir)/, \
        nbtsocket.o \
        namequery.o \
        nameregister.o \
        namerefresh.o \
        namerelease.o)
 
+[BINARY::nmblookup]
+INSTALLDIR = BINDIR
+PRIVATE_DEPENDENCIES = \
+               LIBSAMBA-HOSTCONFIG \
+               LIBSAMBA-UTIL \
+               LIBCLI_NBT \
+               LIBPOPT \
+               POPT_SAMBA \
+               LIBNETIF \
+               LIBCLI_RESOLVE
+
+nmblookup_OBJ_FILES = $(libclinbtsrcdir)/tools/nmblookup.o
+MANPAGES += $(libclinbtsrcdir)/man/nmblookup.1
+
 [SUBSYSTEM::LIBCLI_NDR_NETLOGON]
 PUBLIC_DEPENDENCIES = LIBNDR  \
        NDR_SECURITY    
 
-LIBCLI_NDR_NETLOGON_OBJ_FILES = $(addprefix $(libclinbtsrcdir)/, 
ndr_netlogon.o)
+LIBCLI_NDR_NETLOGON_OBJ_FILES = $(addprefix $(libclinbtsrcdir)/../, 
ndr_netlogon.o)
 
 [SUBSYSTEM::LIBCLI_NETLOGON]
 PUBLIC_DEPENDENCIES = LIBSAMBA-UTIL LIBCLI_NDR_NETLOGON
 
 LIBCLI_NETLOGON_OBJ_FILES = $(addprefix $(libclinbtsrcdir)/, \
-       netlogon.o)
+       ../netlogon.o)
 
 [PYTHON::python_netbios]
 LIBRARY_REALNAME = samba/netbios.$(SHLIBEXT)
 PUBLIC_DEPENDENCIES = LIBCLI_NBT DYNCONFIG LIBSAMBA-HOSTCONFIG
 
-python_netbios_OBJ_FILES = $(libclinbtsrcdir)/nbt/pynbt.o
+python_netbios_OBJ_FILES = $(libclinbtsrcdir)/pynbt.o
 
 $(python_libcli_nbt_OBJ_FILES): CFLAGS+=$(CFLAG_NO_UNUSED_MACROS) 
$(CFLAG_NO_CAST_QUAL)
 
diff --git a/source4/libcli/nbt/man/nmblookup.1.xml 
b/source4/libcli/nbt/man/nmblookup.1.xml
new file mode 100644
index 0000000..85640da
--- /dev/null
+++ b/source4/libcli/nbt/man/nmblookup.1.xml
@@ -0,0 +1,223 @@
+<?xml version="1.0" encoding="iso-8859-1"?>
+<!DOCTYPE refentry PUBLIC "-//Samba-Team//DTD DocBook V4.2-Based Variant 
V1.0//EN" "http://www.samba.org/samba/DTD/samba-doc";>
+<refentry id="nmblookup">
+
+<refmeta>
+       <refentrytitle>nmblookup</refentrytitle>
+       <manvolnum>1</manvolnum>
+       <refmiscinfo class="source">Samba</refmiscinfo>
+       <refmiscinfo class="manual">User Commands</refmiscinfo>
+       <refmiscinfo class="version">3.2</refmiscinfo>
+</refmeta>
+
+
+<refnamediv>
+       <refname>nmblookup</refname>
+       <refpurpose>NetBIOS over TCP/IP client used to lookup NetBIOS 
+       names</refpurpose>
+</refnamediv>
+
+<refsynopsisdiv>
+       <cmdsynopsis>
+               <command>nmblookup</command>
+               <arg choice="opt">-M</arg>
+               <arg choice="opt">-R</arg>
+               <arg choice="opt">-S</arg>
+               <arg choice="opt">-r</arg>
+               <arg choice="opt">-A</arg>
+               <arg choice="opt">-h</arg>
+               <arg choice="opt">-B &lt;broadcast address&gt;</arg>
+               <arg choice="opt">-U &lt;unicast address&gt;</arg>
+               <arg choice="opt">-d &lt;debug level&gt;</arg>
+               <arg choice="opt">-s &lt;smb config file&gt;</arg>
+               <arg choice="opt">-i &lt;NetBIOS scope&gt;</arg>
+               <arg choice="opt">-T</arg>
+               <arg choice="opt">-f</arg>
+               <arg choice="req">name</arg>
+       </cmdsynopsis>
+</refsynopsisdiv>
+
+<refsect1>
+       <title>DESCRIPTION</title>
+
+       <para>This tool is part of the 
<citerefentry><refentrytitle>samba</refentrytitle>
+       <manvolnum>7</manvolnum></citerefentry> suite.</para>
+
+       <para><command>nmblookup</command> is used to query NetBIOS names 
+       and map them to IP addresses in a network using NetBIOS over TCP/IP 
+       queries. The options allow the name queries to be directed at a 
+       particular IP broadcast area or to a particular machine. All queries 
+       are done over UDP.</para>
+</refsect1>
+
+<refsect1>
+       <title>OPTIONS</title>
+
+       <variablelist>
+               <varlistentry>
+               <term>-M</term>
+               <listitem><para>Searches for a master browser by looking 
+               up the  NetBIOS name <replaceable>name</replaceable> with a 
+               type of <constant>0x1d</constant>. If <replaceable>
+               name</replaceable> is "-" then it does a lookup on the special 
name 
+               <constant>__MSBROWSE__</constant>. Please note that in order to 
+               use the name "-", you need to make sure "-" isn't parsed as an 
+               argument, e.g. use : 
+               <userinput>nmblookup -M -- -</userinput>.</para></listitem> 
+               </varlistentry>
+               
+               <varlistentry>
+               <term>-R</term>
+               <listitem><para>Set the recursion desired bit in the packet 
+               to do a recursive lookup. This is used when sending a name 
+               query to a machine running a WINS server and the user wishes 
+               to query the names in the WINS server.  If this bit is unset 
+               the normal (broadcast responding) NetBIOS processing code 
+               on a machine is used instead. See RFC1001, RFC1002 for details.
+               </para></listitem>
+               </varlistentry>
+               
+               <varlistentry>
+               <term>-S</term>
+               <listitem><para>Once the name query has returned an IP 
+               address then do a node status query as well. A node status 
+               query returns the NetBIOS names registered by a host.
+               </para></listitem>
+               </varlistentry>
+
+
+               <varlistentry>
+               <term>-r</term> 
+               <listitem><para>Try and bind to UDP port 137 to send and 
receive UDP
+               datagrams. The reason for this option is a bug in Windows 95 
+               where it ignores the source port of the requesting packet 
+               and only replies to UDP port 137. Unfortunately, on most UNIX 
+               systems root privilege is needed to bind to this port, and 
+               in addition, if the 
<citerefentry><refentrytitle>nmbd</refentrytitle>
+               <manvolnum>8</manvolnum></citerefentry> daemon is running on 
this machine it also binds to this port.
+               </para></listitem>
+               </varlistentry>
+
+
+               <varlistentry>
+               <term>-A</term>
+               <listitem><para>Interpret <replaceable>name</replaceable> as 
+               an IP Address and do a node status query on this address.</para>
+               </listitem>
+               </varlistentry>
+
+
+
+               &popt.common.connection;
+               &stdarg.help;
+
+               <varlistentry>
+               <term>-B &lt;broadcast address&gt;</term> 
+               <listitem><para>Send the query to the given broadcast address. 
Without 
+               this option the default behavior of nmblookup is to send the 
+               query to the broadcast address of the network interfaces as 
+               either auto-detected or defined in the <ulink 
+               
url="smb.conf.5.html#INTERFACES"><parameter>interfaces</parameter>
+               </ulink> parameter of the 
<citerefentry><refentrytitle>smb.conf</refentrytitle>
+       <manvolnum>5</manvolnum></citerefentry> file.
+               </para></listitem>
+               </varlistentry>
+
+
+
+               <varlistentry>
+               <term>-U &lt;unicast address&gt;</term>
+               <listitem><para>Do a unicast query to the specified address or 
+               host <replaceable>unicast address</replaceable>. This option 
+               (along with the <parameter>-R</parameter> option) is needed to 
+               query a WINS server.</para></listitem>
+               </varlistentry>
+               
+               &stdarg.server.debug;   
+               &popt.common.samba;
+
+               <varlistentry>
+               <term>-T</term> 
+               <listitem><para>This causes any IP addresses found in the 
+               lookup to be looked up via a reverse DNS lookup into a 
+               DNS name, and printed out before each</para>
+               
+               <para><emphasis>IP address .... NetBIOS name</emphasis></para>
+               
+               <para> pair that is the normal output.</para></listitem>
+               </varlistentry>
+
+               <varlistentry>
+               <term>-f</term>
+               <listitem><para>
+               Show which flags apply to the name that has been looked up. 
Possible 
+               answers are zero or more of: Response, Authoritative, 
+               Truncated, Recursion_Desired, Recursion_Available, Broadcast.
+               </para></listitem>
+               </varlistentry>
+
+
+               <varlistentry>
+               <term>name</term>
+               <listitem><para>This is the NetBIOS name being queried. 
Depending 
+               upon the previous options this may be a NetBIOS name or IP 
address. 
+               If a NetBIOS name then the different name types may be 
specified 
+               by appending '#&lt;type&gt;' to the name. This name may also be
+               '*', which will return all registered names within a broadcast 
+               area.</para></listitem>
+               </varlistentry>
+       </variablelist>
+</refsect1>
+
+
+<refsect1>
+       <title>EXAMPLES</title>
+
+               <para><command>nmblookup</command> can be used to query 
+               a WINS server (in the same way <command>nslookup</command> is 
+               used to query DNS servers). To query a WINS server, 
<command>nmblookup</command> 
+               must be called like this:</para>
+
+               <para><command>nmblookup -U server -R 'name'</command></para>
+
+               <para>For example, running :</para>
+
+               <para><command>nmblookup -U samba.org -R 
'IRIX#1B'</command></para>
+
+               <para>would query the WINS server samba.org for the domain 
+               master browser (1B name type) for the IRIX workgroup.</para>
+</refsect1>
+
+<refsect1>
+       <title>VERSION</title>
+
+       <para>This man page is correct for version 3 of 
+       the Samba suite.</para>
+</refsect1>
+
+<refsect1>
+       <title>SEE ALSO</title>
+       <para><citerefentry><refentrytitle>nmbd</refentrytitle>
+       <manvolnum>8</manvolnum></citerefentry>, 
<citerefentry><refentrytitle>samba</refentrytitle>
+       <manvolnum>7</manvolnum></citerefentry>, and 
<citerefentry><refentrytitle>smb.conf</refentrytitle>
+       <manvolnum>5</manvolnum></citerefentry>.</para>
+</refsect1>
+
+<refsect1>
+       <title>AUTHOR</title>
+       
+       <para>The original Samba software and related utilities 
+       were created by Andrew Tridgell. Samba is now developed
+       by the Samba Team as an Open Source project similar 
+       to the way the Linux kernel is developed.</para>
+       
+       <para>The original Samba man pages were written by Karl Auer. 
+       The man page sources were converted to YODL format (another 
+       excellent piece of Open Source software, available at <ulink 
url="ftp://ftp.icce.rug.nl/pub/unix/";>
+       ftp://ftp.icce.rug.nl/pub/unix/</ulink>) and updated for the Samba 2.0 
+       release by Jeremy Allison.  The conversion to DocBook for 
+       Samba 2.2 was done by Gerald Carter. The conversion to DocBook
+       XML 4.2 for Samba 3.0 was done by Alexander Bokovoy.</para>
+</refsect1>
+
+</refentry>
diff --git a/source4/libcli/nbt/tools/nmblookup.c 
b/source4/libcli/nbt/tools/nmblookup.c
new file mode 100644
index 0000000..0d98cb9
--- /dev/null
+++ b/source4/libcli/nbt/tools/nmblookup.c
@@ -0,0 +1,381 @@
+/* 
+   Unix SMB/CIFS implementation.
+
+   NBT client - used to lookup netbios names
+
+   Copyright (C) Andrew Tridgell 1994-2005
+   Copyright (C) Jelmer Vernooij 2003 (Conversion to popt)
+   
+   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 "includes.h"
+#include "lib/cmdline/popt_common.h"
+#include "lib/socket/socket.h"
+#include "lib/events/events.h"
+#include "system/network.h"
+#include "system/locale.h"
+#include "lib/socket/netif.h"
+#include "librpc/gen_ndr/nbt.h"
+#include "../libcli/nbt/libnbt.h"
+#include "param/param.h"
+
+/* command line options */
+static struct {
+       const char *broadcast_address;
+       const char *unicast_address;
+       bool find_master;
+       bool wins_lookup;
+       bool node_status;
+       bool root_port;
+       bool lookup_by_ip;
+       bool case_sensitive;
+} options;
+
+/*
+  clean any binary from a node name
+*/
+static const char *clean_name(TALLOC_CTX *mem_ctx, const char *name)
+{
+       char *ret = talloc_strdup(mem_ctx, name);
+       int i;
+       for (i=0;ret[i];i++) {
+               if (!isprint((unsigned char)ret[i])) ret[i] = '.';
+       }
+       return ret;
+}
+
+/*
+  turn a node status flags field into a string
+*/
+static char *node_status_flags(TALLOC_CTX *mem_ctx, uint16_t flags)
+{
+       char *ret;
+       const char *group = "       ";
+       const char *type = "B";
+
+       if (flags & NBT_NM_GROUP) {
+               group = "<GROUP>";
+       }
+
+       switch (flags & NBT_NM_OWNER_TYPE) {
+       case NBT_NODE_B: 
+               type = "B";
+               break;
+       case NBT_NODE_P: 
+               type = "P";
+               break;
+       case NBT_NODE_M: 
+               type = "M";
+               break;
+       case NBT_NODE_H: 
+               type = "H";
+               break;
+       }
+
+       ret = talloc_asprintf(mem_ctx, "%s %s", group, type);
+
+       if (flags & NBT_NM_DEREGISTER) {
+               ret = talloc_asprintf_append_buffer(ret, " <DEREGISTERING>");
+       }
+       if (flags & NBT_NM_CONFLICT) {
+               ret = talloc_asprintf_append_buffer(ret, " <CONFLICT>");
+       }
+       if (flags & NBT_NM_ACTIVE) {
+               ret = talloc_asprintf_append_buffer(ret, " <ACTIVE>");
+       }
+       if (flags & NBT_NM_PERMANENT) {
+               ret = talloc_asprintf_append_buffer(ret, " <PERMANENT>");
+       }
+       
+       return ret;
+}
+
+/* do a single node status */
+static bool do_node_status(struct nbt_name_socket *nbtsock,
+                          const char *addr, uint16_t port)
+{
+       struct nbt_name_status io;
+       NTSTATUS status;
+
+       io.in.name.name = "*";
+       io.in.name.type = NBT_NAME_CLIENT;
+       io.in.name.scope = NULL;
+       io.in.dest_addr = addr;
+       io.in.dest_port = port;
+       io.in.timeout = 1;
+       io.in.retries = 2;
+
+       status = nbt_name_status(nbtsock, nbtsock, &io);
+       if (NT_STATUS_IS_OK(status)) {
+               int i;
+               printf("Node status reply from %s\n",
+                      io.out.reply_from);
+               for (i=0;i<io.out.status.num_names;i++) {
+                       d_printf("\t%-16s <%02x>  %s\n", 
+                                clean_name(nbtsock, 
io.out.status.names[i].name),
+                                io.out.status.names[i].type,
+                                node_status_flags(nbtsock, 
io.out.status.names[i].nb_flags));
+               }
+               printf("\n\tMAC Address = %02X-%02X-%02X-%02X-%02X-%02X\n",
+                      io.out.status.statistics.unit_id[0],
+                      io.out.status.statistics.unit_id[1],
+                      io.out.status.statistics.unit_id[2],
+                      io.out.status.statistics.unit_id[3],
+                      io.out.status.statistics.unit_id[4],
+                      io.out.status.statistics.unit_id[5]);
+               return true;
+       }
+
+       return false;
+}
+
+/* do a single node query */
+static NTSTATUS do_node_query(struct nbt_name_socket *nbtsock,
+                             const char *addr, 
+                             uint16_t port,
+                             const char *node_name, 
+                             enum nbt_name_type node_type,
+                             bool broadcast)
+{
+       struct nbt_name_query io;
+       NTSTATUS status;
+       int i;
+
+       io.in.name.name = node_name;
+       io.in.name.type = node_type;
+       io.in.name.scope = NULL;
+       io.in.dest_addr = addr;
+       io.in.dest_port = port;
+       io.in.broadcast = broadcast;
+       io.in.wins_lookup = options.wins_lookup;
+       io.in.timeout = 1;
+       io.in.retries = 2;
+
+       status = nbt_name_query(nbtsock, nbtsock, &io);
+       NT_STATUS_NOT_OK_RETURN(status);
+
+       for (i=0;i<io.out.num_addrs;i++) {
+               printf("%s %s<%02x>\n",
+                      io.out.reply_addrs[i],
+                      io.out.name.name,
+                      io.out.name.type);
+       }
+       if (options.node_status && io.out.num_addrs > 0) {


-- 
Samba Shared Repository

Reply via email to