Fix binkp overrides

This commit is contained in:
Alexey Khromov 2025-03-22 21:52:08 +03:00
parent 7fb8e32a9b
commit deaa8140f5
2 changed files with 16 additions and 10 deletions

View File

@ -717,14 +717,16 @@ case BPMSG_ADR: /* List of addresses */
bstate->extraislast = false;
sprintf(bstate->extracmd+1,"OPT MB CRYPT");
s_override ovr;
DEB((D_24554, "process adr overrides"));
for(i = 0; i < state.n_remoteaddr; i++) {
ovr.sFlags = "";
override_get (&ovr, state.remoteaddrs[i].addr, 0);
if (nodelist_checkflag (ovr.sFlags, "NR")==0) {
strcat (bstate->extracmd+1, " NR");
break;
}
strcat (bstate->extracmd+1, " NR");
break;
}
}
DEB((D_24554, "process adr overrides"));
}
// further use extracmd only for errors
@ -1217,13 +1219,15 @@ void binkp_process_ADR(char *buffer)
{
s_faddr addr;
char *p, *q;
DEB((D_24554, "process ADR: %s", buffer));
for( p = string_token(buffer, &q, NULL, 0); p; p = string_token(NULL, &q, NULL, 0) )
{
if( ftn_addrparse(&addr, p, FALSE) )
log("BinkP got unparsable address \"%s\"", string_printable(p));
else
else {
session_addrs_add(&state.remoteaddrs, &state.n_remoteaddr, addr);
DEB((D_24554, "process ADR complete"));
}
}
}

View File

@ -135,14 +135,16 @@ int override_get(s_override *dest, s_faddr addr, int line)
{
s_override *p;
int curline = 0;
p = conf_override(cf_override, addr);
curline = 0;
while( p && curline < line )
if (line > 0)
{
p = p->hidden;
++curline;
while( p && curline < line )
{
p = p->hidden;
++curline;
}
}
if( p && curline == line )
@ -152,7 +154,7 @@ int override_get(s_override *dest, s_faddr addr, int line)
}
else if( line == 0 )
return 0;
else
else
return 1;
}