*/
if (flock(fileno(control_fp), (LOCK_EX | LOCK_NB))) {
- lprintf(CTDL_EMERG, "citserver: unable to lock %s.\n", file_citadel_control);
- lprintf(CTDL_EMERG, "Is another citserver already running?\n");
+ CtdlLogPrintf(CTDL_EMERG, "citserver: unable to lock %s.\n", file_citadel_control);
+ CtdlLogPrintf(CTDL_EMERG, "Is another citserver already running?\n");
exit(CTDLEXIT_CONTROL);
}
#endif
}
}
if (control_fp == NULL) {
- lprintf(CTDL_ALERT, "ERROR opening %s: %s\n",
+ CtdlLogPrintf(CTDL_ALERT, "ERROR opening %s: %s\n",
file_citadel_control,
strerror(errno));
return;
}
+/*
+ * CtdlGetCurrentMessageNumber() - Obtain the current highest message number in the system
+ * This provides a quick way to initialise a variable that might be used to indicate
+ * messages that should not be processed. EG. a new Sieve script will use this
+ * to record determine that messages older than this should not be processed.
+ */
+long CtdlGetCurrentMessageNumber(void)
+{
+ long retval = 0L;
+ begin_critical_section(S_CONTROL);
+ get_control();
+ retval = CitControl.MMhighest;
+ end_critical_section(S_CONTROL);
+ return(retval);
+}
+
+
/*
* get_new_user_number() - Obtain a new, unique ID to be used for a user.
*/
cprintf("%d\n", config.c_imap_keep_from);
cprintf("%d\n", config.c_xmpp_c2s_port);
cprintf("%d\n", config.c_xmpp_s2s_port);
+ cprintf("%ld\n", config.c_pop3_fetch);
+ cprintf("%ld\n", config.c_pop3_fastest);
cprintf("000\n");
}
unbuffer_output();
cprintf("%d Send configuration...\n", SEND_LISTING);
a = 0;
- while (client_getln(buf, sizeof buf), strcmp(buf, "000")) {
+ while (client_getln(buf, sizeof buf) >= 0 && strcmp(buf, "000")) {
switch (a) {
case 0:
safestrncpy(config.c_nodename, buf,
case 63:
config.c_xmpp_s2s_port = atoi(buf);
break;
+ case 64:
+ config.c_pop3_fetch = atol(buf);
+ break;
+ case 65:
+ config.c_pop3_fastest = atol(buf);
+ break;
}
++a;
}