svn commit: samba r13005 - in
branches/SAMBA_4_0/source/nbt_server/wins: .
metze at samba.org
metze at samba.org
Wed Jan 18 16:27:31 GMT 2006
Author: metze
Date: 2006-01-18 16:27:29 +0000 (Wed, 18 Jan 2006)
New Revision: 13005
WebSVN: http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=13005
Log:
- use nbtd:max_refresh_time=12345 also for name refresh with a wins server
metze
Modified:
branches/SAMBA_4_0/source/nbt_server/wins/winsclient.c
Changeset:
Modified: branches/SAMBA_4_0/source/nbt_server/wins/winsclient.c
===================================================================
--- branches/SAMBA_4_0/source/nbt_server/wins/winsclient.c 2006-01-18 16:20:33 UTC (rev 13004)
+++ branches/SAMBA_4_0/source/nbt_server/wins/winsclient.c 2006-01-18 16:27:29 UTC (rev 13005)
@@ -27,6 +27,7 @@
#include "lib/events/events.h"
#include "smbd/service_task.h"
+static void nbtd_wins_refresh_handler(struct composite_context *c);
/* we send WINS client requests using our primary network interface
*/
@@ -50,7 +51,22 @@
nbtd_winsclient_register(iname);
}
+/*
+ start a timer to refresh this name
+*/
+static void nbtd_wins_start_refresh_timer(struct nbtd_iface_name *iname)
+{
+ uint32_t refresh_time;
+ uint32_t max_refresh_time = lp_parm_int(-1, "nbtd", "max_refresh_time", 7200);
+ refresh_time = MIN(max_refresh_time, iname->ttl/2);
+
+ event_add_timed(iname->iface->nbtsrv->task->event_ctx,
+ iname,
+ timeval_add(&iname->registration_time, refresh_time, 0),
+ nbtd_wins_refresh, iname);
+}
+
/*
called when a wins name refresh has completed
*/
@@ -99,11 +115,7 @@
iname->wins_server = talloc_steal(iname, io.out.wins_server);
iname->registration_time = timeval_current();
- event_add_timed(iname->iface->nbtsrv->task->event_ctx,
- iname,
- timeval_add(&iname->registration_time, iname->ttl/2, 0),
- nbtd_wins_refresh,
- iname);
+ nbtd_wins_start_refresh_timer(iname);
talloc_free(tmp_ctx);
}
@@ -196,11 +208,7 @@
iname->wins_server = talloc_steal(iname, io.out.wins_server);
iname->registration_time = timeval_current();
- event_add_timed(iname->iface->nbtsrv->task->event_ctx,
- iname,
- timeval_add(&iname->registration_time, iname->ttl/2, 0),
- nbtd_wins_refresh,
- iname);
+ nbtd_wins_start_refresh_timer(iname);
DEBUG(3,("Registered %s with WINS server %s\n",
nbt_name_string(tmp_ctx, &iname->name), iname->wins_server));
More information about the samba-cvs
mailing list