This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.
deb-mbse/lib/attach.c
2004-07-18 10:00:34 +00:00

240 lines
6.0 KiB
C

/*****************************************************************************
*
* $Id$
* Purpose ...............: Attach files to outbound
*
*****************************************************************************
* Copyright (C) 1997-2004
*
* Michiel Broek FIDO: 2:280/2802
* Beekmansbos 10
* 1971 BV IJmuiden
* the Netherlands
*
* This file is part of MBSE BBS.
*
* This BBS 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, or (at your option) any
* later version.
*
* MBSE BBS 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 MBSE BBS; see the file COPYING. If not, write to the Free
* Software Foundation, 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*****************************************************************************/
#include "../config.h"
#include "mbselib.h"
/*
* Attach a file to the real outbound fo a given node.
* If fdn == TRUE, the the file is a forwarded tic file, then
* make sure to see if there was an old file with the same name
* that the old attach is removed including the .tic file so
* that we will send the new file with the right .tic file.
*/
int attach(faddr noden, char *ofile, int mode, char flavor, int fdn)
{
FILE *fp;
char *flofile, *thefile;
int rc;
if (ofile == NULL)
return FALSE;
if ((rc = file_exist(ofile, R_OK))) {
WriteError("attach: file %s failed, %s", ofile, strerror(rc));
return FALSE;
}
/*
* Check if we attach a file with the same name
*/
if ((fdn) && (un_attach(&noden, ofile) == FALSE)) {
WriteError("attach: can't un_attach %s, %s", ofile, strerror(rc));
return FALSE;
}
flofile = calloc(PATH_MAX, sizeof(char));
thefile = calloc(PATH_MAX, sizeof(char));
sprintf(flofile, "%s", floname(&noden, flavor));
/*
* Check if outbound directory exists and
* create if it doesn't exist.
*/
mkdirs(ofile, 0770);
/*
* Attach file to .flo
*
* Note that mbcico when connected to a node opens the file "r+",
* locks it with fcntl(F_SETLK), F_RDLCK, whence=0, start=0L, len=0L.
* It seems that this lock is released after the files in the .flo
* files are send. I don't know what will happen if we add entries
* to the .flo files, this must be tested!
*/
if ((fp = fopen(flofile, "a+")) == NULL) {
WriteError("$Can't open %s", flofile);
WriteError("May be locked by mbcico");
free(flofile);
free(thefile);
return FALSE;
}
switch (mode) {
case LEAVE:
if (strlen(CFG.dospath)) {
if (CFG.leavecase)
sprintf(thefile, "@%s", Unix2Dos(ofile));
else
sprintf(thefile, "@%s", tu(Unix2Dos(ofile)));
} else {
sprintf(thefile, "@%s", ofile);
}
break;
case KFS:
if (strlen(CFG.dospath)) {
if (CFG.leavecase)
sprintf(thefile, "^%s", Unix2Dos(ofile));
else
sprintf(thefile, "^%s", tu(Unix2Dos(ofile)));
} else {
sprintf(thefile, "^%s", ofile);
}
break;
case TFS:
if (strlen(CFG.dospath)) {
if (CFG.leavecase)
sprintf(thefile, "#%s", Unix2Dos(ofile));
else
sprintf(thefile, "#%s", tu(Unix2Dos(ofile)));
} else {
sprintf(thefile, "#%s", ofile);
}
break;
}
fseek(fp, 0, SEEK_END);
fprintf(fp, "%s\r\n", thefile);
fclose(fp);
free(flofile);
free(thefile);
return TRUE;
}
int is_my_tic(char *, char *);
int is_my_tic(char *filename, char *ticfile)
{
FILE *fp;
char *buf;
int Found = FALSE;
buf = calloc(81, sizeof(char));
if ((fp = fopen(ticfile, "r"))) {
while (fgets(buf, 80, fp)) {
if (strstr(buf, filename)) {
Found = TRUE;
break;
}
}
fclose(fp);
}
free(buf);
return Found;
}
/*
* The real unatach function, return 1 if a file is removed.
*/
int check_flo(faddr *, char *, char);
int check_flo(faddr *node, char *filename, char flavor)
{
char *flofile, *ticfile, *buf;
FILE *fp;
long filepos, newpos;
char tpl = '~';
int rc = 0;
buf = calloc(PATH_MAX+3, sizeof(char));
flofile = calloc(PATH_MAX, sizeof(char));
ticfile = calloc(PATH_MAX, sizeof(char));
sprintf(flofile, "%s", floname(node, flavor));
Syslog('p', "%s", flofile);
if ((fp = fopen(flofile, "r+"))) {
filepos = 0;
while (fgets(buf, PATH_MAX +2, fp)) {
newpos = ftell(fp);
Striplf(buf);
if (buf[strlen(buf)-1] == '\r')
buf[strlen(buf)-1] = '\0';
Syslog('p', "hlo: \"%s\"", printable(buf, 0));
if (((strcmp(buf, filename) == 0) || (strcmp(buf+1, filename) == 0)) && (buf[0] != '~')) {
Syslog('p', "Found");
fseek(fp, filepos, SEEK_SET);
fwrite(&tpl, 1, 1, fp);
fflush(fp);
fseek(fp, newpos, SEEK_SET);
filepos = newpos;
if (fgets(buf, PATH_MAX +2, fp)) {
Striplf(buf);
if (buf[strlen(buf)-1] == '\r')
buf[strlen(buf)-1] = '\0';
if (strstr(buf, ".tic") && is_my_tic(basename(filename), buf+1)) {
unlink(buf+1);
fseek(fp, filepos, SEEK_SET);
fwrite(&tpl, 1, 1, fp);
fflush(fp);
Syslog('p', "Removed old %s and %s for %s", basename(filename), basename(buf+1), ascfnode(node, 0x1f));
} else {
Syslog('p', "Removed old %s for %s", basename(filename), ascfnode(node, 0x1f));
}
}
rc = 1;
break;
}
filepos = ftell(fp);
}
fclose(fp);
}
free(ticfile);
free(flofile);
free(buf);
return rc;
}
/*
* Remove a file from the flofile, also search for a .tic file.
*/
int un_attach(faddr *node, char *filename)
{
Syslog('p', "un_attach: %s %s", ascfnode(node, 0x1f), filename);
if (check_flo(node, filename, 'h') == 0)
if (check_flo(node, filename, 'f') == 0)
check_flo(node, filename, 'c');
return TRUE;
}