#include "includes.h"
extern char **my_netbios_names;
extern fstring global_myworkgroup;
extern uint16 samba_nb_type;
static void my_name_register_failed(struct subnet_record *subrec,
struct response_record *rrec, struct nmb_name *nmbname)
{
DEBUG(0,("my_name_register_failed: Failed to register my name %s on subnet %s.\n",
nmb_namestr(nmbname), subrec->subnet_name));
}
void register_my_workgroup_one_subnet(struct subnet_record *subrec)
{
int i;
struct work_record *work;
if((work = create_workgroup_on_subnet(subrec, global_myworkgroup,
PERMANENT_TTL)) == NULL) {
DEBUG(0,("register_my_workgroup_and_names: Failed to create my workgroup %s on subnet %s. \
Exiting.\n", global_myworkgroup, subrec->subnet_name));
return;
}
add_samba_names_to_subnet(subrec);
for (i=0; my_netbios_names[i]; i++) {
register_name(subrec, my_netbios_names[i],0x20,samba_nb_type,
NULL,
my_name_register_failed, NULL);
register_name(subrec, my_netbios_names[i],0x03,samba_nb_type,
NULL,
my_name_register_failed, NULL);
register_name(subrec, my_netbios_names[i],0x00,samba_nb_type,
NULL,
my_name_register_failed, NULL);
}
initiate_myworkgroup_startup(subrec, work);
}
BOOL register_my_workgroup_and_names(void)
{
struct subnet_record *subrec;
int i;
for(subrec = FIRST_SUBNET;
subrec;
subrec = NEXT_SUBNET_INCLUDING_UNICAST(subrec))
{
register_my_workgroup_one_subnet(subrec);
}
add_samba_names_to_subnet(unicast_subnet);
for (i=0; my_netbios_names[i]; i++)
{
for(subrec = FIRST_SUBNET; subrec; subrec = NEXT_SUBNET_EXCLUDING_UNICAST(subrec))
{
struct nmb_name nmbname;
make_nmb_name(&nmbname, my_netbios_names[i],0x20);
insert_permanent_name_into_unicast(subrec, &nmbname, samba_nb_type);
make_nmb_name(&nmbname, my_netbios_names[i],0x3);
insert_permanent_name_into_unicast(subrec, &nmbname, samba_nb_type);
make_nmb_name(&nmbname, my_netbios_names[i],0x0);
insert_permanent_name_into_unicast(subrec, &nmbname, samba_nb_type);
}
}
for(subrec = FIRST_SUBNET; subrec; subrec = NEXT_SUBNET_EXCLUDING_UNICAST(subrec))
{
struct nmb_name nmbname;
make_nmb_name(&nmbname, global_myworkgroup, 0x0);
insert_permanent_name_into_unicast(subrec, &nmbname, samba_nb_type|NB_GROUP);
make_nmb_name(&nmbname, global_myworkgroup, 0x1e);
insert_permanent_name_into_unicast(subrec, &nmbname, samba_nb_type|NB_GROUP);
}
add_samba_names_to_subnet(remote_broadcast_subnet);
return True;
}
void release_my_names(void)
{
#if 0
struct subnet_record *subrec;
for (subrec = FIRST_SUBNET; subrec; subrec = NEXT_SUBNET_INCLUDING_UNICAST(subrec))
#else
struct subnet_record *subrec = unicast_subnet;
#endif
{
struct name_record *namerec, *nextnamerec;
for (namerec = (struct name_record *)ubi_trFirst( subrec->namelist );
namerec;
namerec = nextnamerec)
{
nextnamerec = (struct name_record *)ubi_trNext( namerec );
if( (namerec->data.source == SELF_NAME)
&& !NAME_IS_DEREGISTERING(namerec) )
release_name( subrec, namerec, standard_success_release,
NULL, NULL);
}
}
}
void refresh_my_names(time_t t)
{
struct subnet_record *subrec;
for (subrec = FIRST_SUBNET; subrec; subrec = NEXT_SUBNET_INCLUDING_UNICAST(subrec))
{
struct name_record *namerec;
if (subrec != unicast_subnet)
continue;
for( namerec = (struct name_record *)ubi_trFirst( subrec->namelist );
namerec;
namerec = (struct name_record *)ubi_trNext( namerec ) )
{
if( (namerec->data.source == SELF_NAME)
&& (namerec->data.refresh_time < t)
&& ( namerec->data.death_time != PERMANENT_TTL) )
{
if( !is_refresh_already_queued( subrec, namerec) )
refresh_name( subrec, namerec, NULL, NULL, NULL );
namerec->data.death_time = t + lp_max_ttl();
namerec->data.refresh_time = t + MIN(lp_max_ttl(), MAX_REFRESH_TIME);
}
}
}
}