char buf[1024];
char fromline[1024];
FILE *fp;
+ int i;
+ struct passwd *pw;
get_config();
+ pw = getpwuid(getuid());
+
fp = tmpfile();
if (fp == NULL) return(errno);
- snprintf(fromline, sizeof fromline, "From: someone@somewhere.org");
+ snprintf(fromline, sizeof fromline, "From: %s@%s",
+ pw->pw_name,
+ config.c_fqdn
+ );
while (fgets(buf, 1024, stdin) != NULL) {
fprintf(fp, "%s", buf);
- if (!strncasecmp(buf, "From:", 5)) strcpy(fromline, buf);
+ if (!strncasecmp(buf, "From:", 5)) {
+ strcpy(fromline, buf);
+ }
}
strip_trailing_nonprint(fromline);
serv_gets(buf);
if (buf[0]!='2') cleanup(1);
- snprintf(buf, sizeof buf, "RCPT To: %s", argv[1]);
- serv_puts(buf);
- serv_gets(buf);
- if (buf[0]!='2') cleanup(1);
+ for (i=1; i<argc; ++i) {
+ if (argv[i][0] != '-') {
+ snprintf(buf, sizeof buf, "RCPT To: %s", argv[i]);
+ serv_puts(buf);
+ serv_gets(buf);
+ /* if (buf[0]!='2') cleanup(1); */
+ }
+ }
serv_puts("DATA");
serv_gets(buf);
#include "database.h"
#include "msgbase.h"
#include "sysdep_decls.h"
-#include "tools.h"
#include "config.h"
static DB *dbp[MAXCDB]; /* One DB handle for each Citadel database */
char dbfilename[SIZ];
u_int32_t flags = 0;
char dbdirname[PATH_MAX];
- char dblogname[PATH_MAX];
DIR *dp;
struct dirent *d;
char filename[PATH_MAX];
getcwd(dbdirname, sizeof dbdirname);
strcat(dbdirname, "/data");
- getcwd(dblogname, sizeof dblogname);
- strcat(dblogname, "/data_logs");
lprintf(CTDL_DEBUG, "cdb_*: open_databases() starting\n");
lprintf(CTDL_DEBUG, "Compiled db: %s\n", DB_VERSION_STRING);
chmod(dbdirname, 0700);
chown(dbdirname, BBSUID, (-1) );
- /*
- * By default, keep database logs in the same directory. A savvy
- * system administrator will know what to do if he/she wants to put
- * them elsewhere.
- */
- symlink("data", dblogname);
-
lprintf(CTDL_DEBUG, "cdb_*: Setting up DB environment\n");
db_env_set_func_yield(sched_yield);
ret = db_env_create(&dbenv, 0);
exit(ret);
}
- if ((ret = dbenv->set_data_dir(dbenv, dbdirname))) {
- lprintf(CTDL_EMERG, "cdb_*: set_data_dir: %s\n", db_strerror(ret));
- dbenv->close(dbenv, 0);
- exit(ret);
- }
-
- if ((ret = dbenv->set_lg_dir(dbenv, dblogname))) {
- lprintf(CTDL_EMERG, "cdb_*: set_lg_dir: %s\n", db_strerror(ret));
- dbenv->close(dbenv, 0);
- exit(ret);
- }
-
flags = DB_CREATE|DB_RECOVER|DB_INIT_MPOOL|DB_PRIVATE|DB_INIT_TXN|
DB_INIT_LOCK|DB_THREAD;
- lprintf(CTDL_DEBUG, "dbenv->open(dbenv, NULL, %d, 0)\n", flags);
- ret = dbenv->open(dbenv, NULL, flags, 0);
+ lprintf(CTDL_DEBUG, "dbenv->open(dbenv, %s, %d, 0)\n", dbdirname, flags);
+ ret = dbenv->open(dbenv, dbdirname, flags, 0);
if (ret) {
lprintf(CTDL_DEBUG, "cdb_*: dbenv->open: %s\n", db_strerror(ret));
dbenv->close(dbenv, 0);