diff options
author | Stefan Metzmacher <metze@samba.org> | 2005-12-22 08:27:10 +0000 |
---|---|---|
committer | Stefan Metzmacher <metze@samba.org> | 2005-12-22 08:27:10 +0000 |
commit | a658f7857b6e5ca2295d3ef5b47821ac782e375d (patch) | |
tree | f2ce474b11d166ad844b547f0225fe71211afea7 /source/nbt_server | |
parent | 8f3e2ba602fac4a3e4273e08a1f5e102b57969d6 (diff) | |
download | samba-a658f7857b6e5ca2295d3ef5b47821ac782e375d.tar.gz samba-a658f7857b6e5ca2295d3ef5b47821ac782e375d.tar.xz samba-a658f7857b6e5ca2295d3ef5b47821ac782e375d.zip |
r12425: match w2k3 and store 0x1D names when they're registered as group name,
but queries still give not found
metze
Diffstat (limited to 'source/nbt_server')
-rw-r--r-- | source/nbt_server/wins/winsserver.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/source/nbt_server/wins/winsserver.c b/source/nbt_server/wins/winsserver.c index 4c4619b5c8d..6e2d470a1e2 100644 --- a/source/nbt_server/wins/winsserver.c +++ b/source/nbt_server/wins/winsserver.c @@ -183,9 +183,12 @@ static void nbtd_winsserver_register(struct nbt_name_socket *nbtsock, enum wrepl_name_type new_type = wrepl_type(nb_flags, name, mhomed); struct winsdb_addr *winsdb_addr = NULL; - /* as a special case, the local master browser name is always accepted - for registration, but never stored */ - if (name->type == NBT_NAME_MASTER) { + /* + * as a special case, the local master browser name is always accepted + * for registration, but never stored, but w2k3 stores it if it's registered + * as a group name, (but a query for the 0x1D name still returns not found!) + */ + if (name->type == NBT_NAME_MASTER && !(nb_flags & NBT_NM_GROUP)) { rcode = NBT_RCODE_OK; goto done; } @@ -328,6 +331,10 @@ static void nbtd_winsserver_query(struct nbt_name_socket *nbtsock, const char **addresses; uint16_t nb_flags = 0; /* TODO: ... */ + if (name->type == NBT_NAME_MASTER) { + goto notfound; + } + status = winsdb_lookup(winssrv->wins_db, name, packet, &rec); if (!NT_STATUS_IS_OK(status)) { goto notfound; |