#include "user_ops.h"
#include "room_ops.h"
#include "control.h"
+#include "euidindex.h"
#define END_OF_MESSAGE "---eom---dbd---"
/* format of message list export is all message numbers output
* one per line terminated by a 0.
*/
- CtdlForEachMessage(MSGS_ALL, 0L, NULL, NULL,
+ CtdlForEachMessage(MSGS_ALL, 0L, NULL, NULL, NULL,
artv_export_room_msg, NULL);
cprintf("0\n");
struct ser_ret smr;
FILE *fp;
char buf[SIZ];
- char tempfile[SIZ];
+ char tempfile[PATH_MAX];
msg = CtdlFetchMessage(msgnum, 1);
if (msg == NULL) return; /* fail silently */
CtdlFreeMessage(msg);
/* write it in base64 */
- strcpy(tempfile, tmpnam(NULL));
+ CtdlMakeTempFileName(tempfile, sizeof tempfile);
snprintf(buf, sizeof buf, "./base64 -e >%s", tempfile);
fp = popen(buf, "w");
fwrite(smr.ser, smr.len, 1, fp);
cprintf("%s\n", config.c_fqdn);
cprintf("%s\n", config.c_humannode);
cprintf("%s\n", config.c_phonenum);
- cprintf("%ld\n", (long)config.c_bbsuid);
+ cprintf("%ld\n", (long)config.c_ctdluid);
cprintf("%d\n", config.c_creataide);
cprintf("%d\n", config.c_sleeping);
cprintf("%d\n", config.c_initax);
cprintf("%s\n", config.c_twitroom);
cprintf("%s\n", config.c_moreprompt);
cprintf("%d\n", config.c_restrict);
- cprintf("%s\n", config.c_bbs_city);
+ cprintf("%s\n", config.c_site_location);
cprintf("%s\n", config.c_sysadm);
cprintf("%d\n", config.c_setup_level);
cprintf("%d\n", config.c_maxsessions);
cprintf("%d\n", config.c_imaps_port);
cprintf("%d\n", config.c_pop3s_port);
cprintf("%d\n", config.c_smtps_port);
+ cprintf("%d\n", config.c_rfc822_strict_from);
+ cprintf("%d\n", config.c_aide_zap);
+ cprintf("%d\n", config.c_imap_port);
+ cprintf("%ld\n", config.c_net_freq);
+ cprintf("%d\n", config.c_disable_newu);
+ cprintf("%s\n", config.c_baseroom);
+ cprintf("%s\n", config.c_aideroom);
+ cprintf("%d\n", config.c_auto_cull);
+ cprintf("%d\n", config.c_instant_expunge);
+ cprintf("%d\n", config.c_allow_spoofing);
+ cprintf("%d\n", config.c_journal_email);
+ cprintf("%d\n", config.c_journal_pubmsgs);
+ cprintf("%s\n", config.c_journal_dest);
+ cprintf("%s\n", config.c_default_cal_zone);
+ cprintf("%d\n", config.c_pftcpdict_port);
+ cprintf("%d\n", config.c_managesieve_port);
+ cprintf("%d\n", config.c_auth_mode);
+ cprintf("%s\n", config.c_funambol_host);
+ cprintf("%d\n", config.c_funambol_port);
+ cprintf("%s\n", config.c_funambol_source);
+ cprintf("%s\n", config.c_funambol_auth);
/* Export the control file */
get_control();
client_getln(config.c_fqdn, sizeof config.c_fqdn);
client_getln(config.c_humannode, sizeof config.c_humannode);
client_getln(config.c_phonenum, sizeof config.c_phonenum);
- client_getln(buf, sizeof buf); config.c_bbsuid = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_ctdluid = atoi(buf);
client_getln(buf, sizeof buf); config.c_creataide = atoi(buf);
client_getln(buf, sizeof buf); config.c_sleeping = atoi(buf);
client_getln(buf, sizeof buf); config.c_initax = atoi(buf);
client_getln(config.c_twitroom, sizeof config.c_twitroom);
client_getln(config.c_moreprompt, sizeof config.c_moreprompt);
client_getln(buf, sizeof buf); config.c_restrict = atoi(buf);
- client_getln(config.c_bbs_city, sizeof config.c_bbs_city);
+ client_getln(config.c_site_location, sizeof config.c_site_location);
client_getln(config.c_sysadm, sizeof config.c_sysadm);
client_getln(buf, sizeof buf); config.c_setup_level = atoi(buf);
client_getln(buf, sizeof buf); config.c_maxsessions = atoi(buf);
client_getln(buf, sizeof buf); config.c_imaps_port = atoi(buf);
client_getln(buf, sizeof buf); config.c_pop3s_port = atoi(buf);
client_getln(buf, sizeof buf); config.c_smtps_port = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_rfc822_strict_from = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_aide_zap = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_imap_port = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_net_freq = atol(buf);
+ client_getln(buf, sizeof buf); config.c_disable_newu = atoi(buf);
+ client_getln(config.c_baseroom, sizeof config.c_baseroom);
+ client_getln(config.c_aideroom, sizeof config.c_aideroom);
+ client_getln(buf, sizeof buf); config.c_auto_cull = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_instant_expunge = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_allow_spoofing = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_journal_email = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_journal_pubmsgs = atoi(buf);
+ client_getln(config.c_journal_dest, sizeof config.c_journal_dest);
+ client_getln(config.c_default_cal_zone, sizeof config.c_default_cal_zone);
+ client_getln(buf, sizeof buf); config.c_pftcpdict_port = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_managesieve_port = atoi(buf);
+ client_getln(buf, sizeof buf); config.c_auth_mode = atoi(buf);
+ client_getln(config.c_funambol_host, sizeof config.c_funambol_host);
+ client_getln(buf, sizeof buf); config.c_funambol_port = atoi(buf);
+ client_getln(config.c_funambol_source, sizeof config.c_funambol_source);
+ client_getln(config.c_funambol_auth, sizeof config.c_funambol_auth);
+
+ config.c_enable_fulltext = 0; /* always disable */
put_config();
lprintf(CTDL_INFO, "Imported config file\n");
}
-
void artv_import_control(void) {
char buf[SIZ];
client_getln(buf, sizeof buf); CitControl.MMnextuser = atol(buf);
client_getln(buf, sizeof buf); CitControl.MMnextroom = atol(buf);
client_getln(buf, sizeof buf); CitControl.version = atoi(buf);
+ CitControl.MMfulltext = (-1L); /* always flush */
put_control();
lprintf(CTDL_INFO, "Imported control file\n");
}
* one per line terminated by a 0.
*/
while (client_getln(buf, sizeof buf), msgnum = atol(buf), msgnum > 0) {
- CtdlSaveMsgPointerInRoom(qrbuf.QRname, msgnum, 0);
+ CtdlSaveMsgPointerInRoom(qrbuf.QRname, msgnum, 0, NULL);
++msgcount;
}
lprintf(CTDL_INFO, "(%d messages)\n", msgcount);
long msglen;
FILE *fp;
char buf[SIZ];
- char tempfile[SIZ];
+ char tempfile[PATH_MAX];
char *mbuf;
memset(&smi, 0, sizeof(struct MetaData));
lprintf(CTDL_INFO, "message #%ld\n", msgnum);
/* decode base64 message text */
- strcpy(tempfile, tmpnam(NULL));
+ CtdlMakeTempFileName(tempfile, sizeof tempfile);
snprintf(buf, sizeof buf, "./base64 -d >%s", tempfile);
fp = popen(buf, "w");
while (client_getln(buf, sizeof buf), strcasecmp(buf, END_OF_MESSAGE)) {
}
lprintf(CTDL_INFO, "Invalid keyword <%s>. Flushing input.\n", buf);
while (client_getln(buf, sizeof buf), strcmp(buf, "000")) ;;
+ rebuild_euid_index();
}
void cmd_artv(char *cmdbuf) {
- char cmd[SIZ];
+ char cmd[32];
static int is_running = 0;
if (CtdlAccessCheck(ac_internal)) return;
}
is_running = 1;
- strcpy(artv_tempfilename1, tmpnam(NULL));
- strcpy(artv_tempfilename2, tmpnam(NULL));
+ CtdlMakeTempFileName(artv_tempfilename1, sizeof artv_tempfilename1);
+ CtdlMakeTempFileName(artv_tempfilename2, sizeof artv_tempfilename2);
- extract(cmd, cmdbuf, 0);
+ extract_token(cmd, cmdbuf, 0, '|', sizeof cmd);
if (!strcasecmp(cmd, "export")) artv_do_export();
else if (!strcasecmp(cmd, "import")) artv_do_import();
else cprintf("%d illegal command\n", ERROR + ILLEGAL_VALUE);