Specify event_context to ldb_wrap_connect explicitly.
[ambi/samba-autobuild/.git] / source4 / nbt_server / nbt_server.c
index d05a31e42141b5802aa28662620a9425352c7d0a..832bbe0103924f30797face6553fee1f6125146c 100644 (file)
@@ -7,7 +7,7 @@
    
    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 2 of the License, or
+   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,
    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, write to the Free Software
-   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
 
 #include "includes.h"
-#include "events.h"
-#include "libcli/nbt/libnbt.h"
 #include "smbd/service_task.h"
+#include "smbd/service.h"
 #include "nbt_server/nbt_server.h"
-
-
-/*
-  receive an incoming request
-*/
-static void nbt_request_handler(struct nbt_name_socket *nbtsock, 
-                               struct nbt_name_packet *packet, 
-                               const char *src_address, int src_port)
-{
-       struct nbt_interface *iface = talloc_get_type(nbtsock->incoming.private, 
-                                                     struct nbt_interface);
-       DEBUG(0,("nbtd request from %s:%d\n", src_address, src_port));
-
-       NDR_PRINT_DEBUG(nbt_name_packet, packet);
-}
-
+#include "nbt_server/wins/winsserver.h"
+#include "system/network.h"
+#include "lib/socket/netif.h"
+#include "auth/auth.h"
+#include "dsdb/samdb/samdb.h"
+#include "param/param.h"
 
 /*
   startup the nbtd task
 */
 static void nbtd_task_init(struct task_server *task)
 {
-       struct nbt_server *nbtsrv;
-       struct nbt_interface *iface;
+       struct nbtd_server *nbtsrv;
        NTSTATUS status;
+       struct interface *ifaces;
+
+       load_interfaces(task, lp_interfaces(task->lp_ctx), &ifaces);
+
+       if (iface_count(ifaces) == 0) {
+               task_server_terminate(task, "nbtd: no network interfaces configured");
+               return;
+       }
+
+       task_server_set_title(task, "task[nbtd]");
 
-       nbtsrv = talloc(task, struct nbt_server);
+       nbtsrv = talloc(task, struct nbtd_server);
        if (nbtsrv == NULL) {
-               task_terminate(task, "nbtd: out of memory");
+               task_server_terminate(task, "nbtd: out of memory");
                return;
        }
 
-       nbtsrv->task = task;
-       nbtsrv->interfaces = NULL;
+       nbtsrv->task            = task;
+       nbtsrv->interfaces      = NULL;
+       nbtsrv->bcast_interface = NULL;
+       nbtsrv->wins_interface  = NULL;
 
        /* start listening on the configured network interfaces */
-       status = nbt_startup_interfaces(nbtsrv);
+       status = nbtd_startup_interfaces(nbtsrv, task->lp_ctx, ifaces);
        if (!NT_STATUS_IS_OK(status)) {
-               task_terminate(task, "nbtd failed to setup interfaces");
+               task_server_terminate(task, "nbtd failed to setup interfaces");
                return;
        }
 
-       /* setup the incoming request handler for all our interfaces */
-       for (iface=nbtsrv->interfaces;iface;iface=iface->next) {
-               nbt_set_incoming_handler(iface->nbtsock, nbt_request_handler, iface);
+       nbtsrv->sam_ctx = samdb_connect(nbtsrv, task->event_ctx, task->lp_ctx, anonymous_session(nbtsrv, task->event_ctx, task->lp_ctx));
+       if (nbtsrv->sam_ctx == NULL) {
+               task_server_terminate(task, "nbtd failed to open samdb");
+               return;
        }
-}
 
+       /* start the WINS server, if appropriate */
+       status = nbtd_winsserver_init(nbtsrv);
+       if (!NT_STATUS_IS_OK(status)) {
+               task_server_terminate(task, "nbtd failed to start WINS server");
+               return;
+       }
 
-/*
-  initialise the nbt server
- */
-static NTSTATUS nbtd_init(struct event_context *event_ctx, const struct model_ops *model_ops)
-{
-       return task_server_startup(event_ctx, model_ops, nbtd_task_init);
+       nbtd_register_irpc(nbtsrv);
+
      /* start the process of registering our names on all interfaces */
+       nbtd_register_names(nbtsrv);
+
+       irpc_add_name(task->msg_ctx, "nbt_server");
 }
 
 
@@ -88,5 +93,5 @@ static NTSTATUS nbtd_init(struct event_context *event_ctx, const struct model_op
 */
 NTSTATUS server_service_nbtd_init(void)
 {
-       return register_server_service("nbt", nbtd_init);
+       return register_server_service("nbt", nbtd_task_init);
 }