mirror of
https://github.com/samba-team/samba.git
synced 2025-01-29 21:47:30 +03:00
88c6a00c3c
because the share must be browseable by a w95 client 2) send_mailslot_reply - unique or group datagram argument added. 3) netlogon.c - rewrote response packet to do the right thing for w95. 4) server.c reply_nt1() - added OEMDomainstring to the end. 5) (deep breath) reworked the nmbd-browsing code a little bit. i discovered two months ago that becoming a primary domain controller (and domain master browser) is done independently of becoming a backup domain controller (logon server) is done independently of becoming a local master browser. therefore, three sets of state-machines (instead of just one) are in place - each of which is responsible for taking samba through the required stages to become: a logon server; a domain master browser; and a local master browser. each of these three things can occur independently on each interface, _including_ the wins pseudo-interface. the only slight caveat is that the wins pseudo-interface, by virtue of _not_ being a broadcast interface, does _not_ register as a local master browser with the wins server, as this doesn't make sense. lkcl
-
155 lines
3.8 KiB
C
155 lines
3.8 KiB
C
/*
|
|
Unix SMB/Netbios implementation.
|
|
Version 1.9.
|
|
NBT netbios routines and daemon - version 2
|
|
Copyright (C) Andrew Tridgell 1994-1995
|
|
|
|
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
|
|
(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, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
Revision History:
|
|
|
|
14 jan 96: lkcl@pires.co.uk
|
|
added multiple workgroup domain master support
|
|
|
|
*/
|
|
|
|
#include "includes.h"
|
|
|
|
extern int ClientDGRAM;
|
|
|
|
#define TEST_CODE /* want to debug unknown browse packets */
|
|
|
|
extern int DEBUGLEVEL;
|
|
|
|
extern pstring myname;
|
|
|
|
|
|
/****************************************************************************
|
|
process a domain logon packet
|
|
|
|
08aug96 lkcl@pires.co.uk
|
|
reply_code == 0xC courtesy of jim@oxfordcc.co.uk forwarded by
|
|
lewis2@server.uwindsor.ca
|
|
**************************************************************************/
|
|
void process_logon_packet(struct packet_struct *p,char *buf,int len)
|
|
{
|
|
struct dgram_packet *dgram = &p->packet.dgram;
|
|
struct in_addr ip = dgram->header.source_ip;
|
|
struct subnet_record *d = find_subnet(ip);
|
|
char *logname,*q;
|
|
fstring reply_name;
|
|
BOOL add_slashes = False;
|
|
pstring outbuf;
|
|
int code,reply_code;
|
|
struct work_record *work;
|
|
char unknown_byte = 0;
|
|
uint16 request_count = 0;
|
|
uint16 token = 0;
|
|
|
|
if (!d) return;
|
|
|
|
if (!(work = find_workgroupstruct(d,dgram->dest_name.name, False))) return;
|
|
|
|
if (!lp_domain_logons())
|
|
{
|
|
DEBUG(3,("No domain logons\n"));
|
|
return;
|
|
}
|
|
|
|
code = SVAL(buf,0);
|
|
switch (code)
|
|
{
|
|
case 0:
|
|
{
|
|
char *machine = buf+2;
|
|
char *user = skip_string(machine,1);
|
|
char *tmp;
|
|
logname = skip_string(user,1);
|
|
tmp = skip_string(logname,1);
|
|
unknown_byte = CVAL(tmp,0);
|
|
request_count = SVAL(tmp,1);
|
|
token = SVAL(tmp,3);
|
|
|
|
reply_code = 0x6;
|
|
strcpy(reply_name,myname);
|
|
strupper(reply_name);
|
|
add_slashes = True;
|
|
DEBUG(3,("Domain login request from %s(%s) user=%s token=%x\n",
|
|
machine,inet_ntoa(p->ip),user,token));
|
|
break;
|
|
}
|
|
case 7:
|
|
{
|
|
char *machine = buf+2;
|
|
logname = skip_string(machine,1);
|
|
token = SVAL(skip_string(logname,1),0);
|
|
|
|
strcpy(reply_name,lp_domain_controller());
|
|
if (!*reply_name)
|
|
{
|
|
/* oo! no domain controller. must be us, then */
|
|
strcpy(reply_name,myname);
|
|
reply_code = 0xC;
|
|
}
|
|
else
|
|
{
|
|
/* refer logon request to the domain controller */
|
|
reply_code = 0x7;
|
|
}
|
|
|
|
strupper(reply_name);
|
|
DEBUG(3,("GETDC request from %s(%s), reporting %s 0x%x token=%x\n",
|
|
machine,inet_ntoa(p->ip), reply_name, reply_code,token));
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
DEBUG(3,("Unknown domain request %d\n",code));
|
|
return;
|
|
}
|
|
}
|
|
|
|
bzero(outbuf,sizeof(outbuf));
|
|
q = outbuf;
|
|
SSVAL(q,0,reply_code);
|
|
q += 2;
|
|
|
|
if (token == 0xffff || /* LM 2.0 or later */
|
|
token == 0xfffe) /* WfWg networking */
|
|
{
|
|
if (add_slashes)
|
|
{
|
|
strcpy(q,"\\\\");
|
|
q += 2;
|
|
}
|
|
strcpy(q, reply_name);
|
|
strupper(q);
|
|
q = skip_string(q,1);
|
|
|
|
if (token == 0xffff) /* LM 2.0 or later */
|
|
{
|
|
SSVAL(q,0,token);
|
|
q += 2;
|
|
}
|
|
}
|
|
|
|
SSVAL(q,0,0xFFFF);
|
|
q += 2;
|
|
|
|
send_mailslot_reply(True, logname,ClientDGRAM,outbuf,PTR_DIFF(q,outbuf),
|
|
myname,&dgram->source_name.name[0],0x20,0,p->ip,
|
|
*iface_ip(p->ip));
|
|
}
|