diff options
author | Andrew Tridgell <tridge@samba.org> | 1998-08-31 09:38:50 +0000 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 1998-08-31 09:38:50 +0000 |
commit | 07f825fc9491bb5adac047854e67c63f7757143b (patch) | |
tree | 8738b4ee128aec1c7ed664687e5f773e847a8038 /source/nmbd | |
parent | 222b6d90e09288091028f5e0435f1d4a74153f66 (diff) | |
download | samba-07f825fc9491bb5adac047854e67c63f7757143b.tar.gz samba-07f825fc9491bb5adac047854e67c63f7757143b.tar.xz samba-07f825fc9491bb5adac047854e67c63f7757143b.zip |
I looked at the refresh issue a bit more and discovered that Samba
also doesn't switch to a registration if a refresh fails, instead the
name is removed! This makes it even more imortant that a Samba WINS
server accepts refresh requests as registration requests if the name
is not registered. I've gone ahead and implemented this.
Diffstat (limited to 'source/nmbd')
-rw-r--r-- | source/nmbd/nmbd_winsserver.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/source/nmbd/nmbd_winsserver.c b/source/nmbd/nmbd_winsserver.c index 2fcc95e1d69..48d27f7bae9 100644 --- a/source/nmbd/nmbd_winsserver.c +++ b/source/nmbd/nmbd_winsserver.c @@ -420,14 +420,15 @@ IP %s\n", namestr(question), inet_ntoa(from_ip) )); /* * If this is a refresh request and the name doesn't exist then - * fail it. + * treat it like a registration request. This allows us to recover + * from errors (tridge) */ if(namerec == NULL) { DEBUG(3,("wins_process_name_refresh_request: Name refresh for name %s and \ -the name does not exist.\n", namestr(question) )); - send_wins_name_registration_response(NAM_ERR, 0, p); +the name does not exist. Treating as registration.\n", namestr(question) )); + wins_process_name_registration_request(subrec,p); return; } |