binkp start for CRC support
This commit is contained in:
parent
899a73b4de
commit
2af1d25bdf
@ -21,6 +21,8 @@ v0.35.01 05-Jun-2002
|
|||||||
mbcico:
|
mbcico:
|
||||||
Now uses the new session password field for session handshake.
|
Now uses the new session password field for session handshake.
|
||||||
The binkd version string now includes the OS and CPU type.
|
The binkd version string now includes the OS and CPU type.
|
||||||
|
If a transmitted file via binkp is skipped by the remote it
|
||||||
|
will stay in the queue for the next session.
|
||||||
|
|
||||||
mbfile:
|
mbfile:
|
||||||
Added -v commandline switch to supress virus checking for the
|
Added -v commandline switch to supress virus checking for the
|
||||||
|
3
TODO
3
TODO
@ -143,3 +143,6 @@ mbsetup:
|
|||||||
Fileecho groups <=> Newfile reports
|
Fileecho groups <=> Newfile reports
|
||||||
Fileecho groups <=> BBS Areas
|
Fileecho groups <=> BBS Areas
|
||||||
|
|
||||||
|
install:
|
||||||
|
U: On RedHat 7.3 the big-endian menus are installed.
|
||||||
|
|
||||||
|
@ -84,6 +84,7 @@ static int MBflag = FALSE;
|
|||||||
static int NDflag = FALSE;
|
static int NDflag = FALSE;
|
||||||
static int CRYPTflag = FALSE;
|
static int CRYPTflag = FALSE;
|
||||||
static int CRAMflag = FALSE;
|
static int CRAMflag = FALSE;
|
||||||
|
static int CRCflag = FALSE;
|
||||||
unsigned long nethold, mailhold;
|
unsigned long nethold, mailhold;
|
||||||
int transferred = FALSE;
|
int transferred = FALSE;
|
||||||
int batchnr = 0;
|
int batchnr = 0;
|
||||||
@ -368,9 +369,10 @@ void b_nul(char *msg)
|
|||||||
NDflag = TRUE;
|
NDflag = TRUE;
|
||||||
if (strstr(msg, (char *)"CRYPT") != NULL)
|
if (strstr(msg, (char *)"CRYPT") != NULL)
|
||||||
CRYPTflag = TRUE;
|
CRYPTflag = TRUE;
|
||||||
if (strstr(msg, (char *)"CRAM-") != NULL) {
|
if (strstr(msg, (char *)"CRAM-") != NULL)
|
||||||
CRAMflag = TRUE;
|
CRAMflag = TRUE;
|
||||||
}
|
if (strstr(msg, (char *)"CRC") != NULL)
|
||||||
|
CRCflag = TRUE;
|
||||||
} else
|
} else
|
||||||
Syslog('+', "M_NUL \"%s\"", msg);
|
Syslog('+', "M_NUL \"%s\"", msg);
|
||||||
}
|
}
|
||||||
@ -799,7 +801,7 @@ int binkp_batch(file_list *to_send)
|
|||||||
int sverr, cmd = FALSE, GotFrame = FALSE;
|
int sverr, cmd = FALSE, GotFrame = FALSE;
|
||||||
int blklen = 0, c, Found = FALSE;
|
int blklen = 0, c, Found = FALSE;
|
||||||
unsigned short header = 0;
|
unsigned short header = 0;
|
||||||
char *rname, *lname, *gname;
|
char *rname, *lname, *gname, *rcrc;
|
||||||
long rsize, roffs, lsize, gsize, goffset;
|
long rsize, roffs, lsize, gsize, goffset;
|
||||||
time_t rtime, ltime, gtime;
|
time_t rtime, ltime, gtime;
|
||||||
off_t rxbytes;
|
off_t rxbytes;
|
||||||
@ -821,6 +823,7 @@ int binkp_batch(file_list *to_send)
|
|||||||
txbuf = calloc(MAX_BLKSIZE + 3, sizeof(unsigned char));
|
txbuf = calloc(MAX_BLKSIZE + 3, sizeof(unsigned char));
|
||||||
rxbuf = calloc(MAX_BLKSIZE + 3, sizeof(unsigned char));
|
rxbuf = calloc(MAX_BLKSIZE + 3, sizeof(unsigned char));
|
||||||
rname = calloc(512, sizeof(char));
|
rname = calloc(512, sizeof(char));
|
||||||
|
rcrc = calloc(512, sizeof(char));
|
||||||
lname = calloc(512, sizeof(char));
|
lname = calloc(512, sizeof(char));
|
||||||
gname = calloc(512, sizeof(char));
|
gname = calloc(512, sizeof(char));
|
||||||
TfState = Switch;
|
TfState = Switch;
|
||||||
@ -1090,7 +1093,18 @@ int binkp_batch(file_list *to_send)
|
|||||||
|
|
||||||
case MM_FILE: if ((RxState == RxWaitFile) || (RxState == RxEndOfBatch)) {
|
case MM_FILE: if ((RxState == RxWaitFile) || (RxState == RxEndOfBatch)) {
|
||||||
RxState = RxAcceptFile;
|
RxState = RxAcceptFile;
|
||||||
sscanf(rxbuf+1, "%s %ld %ld %ld", rname, &rsize, &rtime, &roffs);
|
Syslog('b', "MM_FILE %s", rxbuf+1);
|
||||||
|
if (strlen(rxbuf) < 512) {
|
||||||
|
/*
|
||||||
|
* Check against buffer overflow
|
||||||
|
*/
|
||||||
|
if (CRCflag)
|
||||||
|
sscanf(rxbuf+1, "%s %ld %ld %ld %s", rname, &rsize, &rtime, &roffs, rcrc);
|
||||||
|
else
|
||||||
|
sscanf(rxbuf+1, "%s %ld %ld %ld", rname, &rsize, &rtime, &roffs);
|
||||||
|
} else {
|
||||||
|
Syslog('+', "Got corrupted FILE frame, size %d bytes", strlen(rxbuf));
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
Syslog('+', "Binkp: got unexpected FILE frame %s", rxbuf+1);
|
Syslog('+', "Binkp: got unexpected FILE frame %s", rxbuf+1);
|
||||||
}
|
}
|
||||||
@ -1190,8 +1204,7 @@ int binkp_batch(file_list *to_send)
|
|||||||
execute_disposition(tsl);
|
execute_disposition(tsl);
|
||||||
} else {
|
} else {
|
||||||
for (tmp = bll; tmp; tmp = tmp->next) {
|
for (tmp = bll; tmp; tmp = tmp->next) {
|
||||||
if ((strcmp(tmp->local, tsl->local) == 0) &&
|
if ((strcmp(tmp->local, tsl->local) == 0) && (tmp->state == Got)) {
|
||||||
((tmp->state == Got) || (tmp->state == Skipped))) {
|
|
||||||
execute_disposition(tsl);
|
execute_disposition(tsl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1210,6 +1223,7 @@ int binkp_batch(file_list *to_send)
|
|||||||
free(txbuf);
|
free(txbuf);
|
||||||
free(rxbuf);
|
free(rxbuf);
|
||||||
free(rname);
|
free(rname);
|
||||||
|
free(rcrc);
|
||||||
free(lname);
|
free(lname);
|
||||||
free(gname);
|
free(gname);
|
||||||
Syslog('+', "Binkp: batch %d completed rc=%d", batchnr, rc);
|
Syslog('+', "Binkp: batch %d completed rc=%d", batchnr, rc);
|
||||||
|
Reference in New Issue
Block a user