*
*/
-#include "sysdep.h"
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <pwd.h>
#include <errno.h>
#include <stdarg.h>
+#include "sysdep.h"
#include "citadel.h"
#include "citadel_ipc.h"
#include "citadel_decls.h"
{ /* register with name and address */
char buf[SIZ];
- char tmpname[SIZ];
- char tmpaddr[SIZ];
- char tmpcity[SIZ];
- char tmpstate[SIZ];
- char tmpzip[SIZ];
- char tmpphone[SIZ];
+ char tmpname[30];
+ char tmpaddr[25];
+ char tmpcity[15];
+ char tmpstate[3];
+ char tmpzip[11];
+ char tmpphone[15];
char tmpemail[SIZ];
- char tmpcountry[SIZ];
- char diruser[SIZ];
- char dirnode[SIZ];
+ char tmpcountry[32];
+ char diruser[256];
+ char dirnode[256];
char holdemail[SIZ];
char *reg = NULL;
int ok = 0;
while (reg && strlen(reg) > 0) {
- extract_token(buf, reg, 0, '\n');
+ extract_token(buf, reg, 0, '\n', sizeof buf);
remove_token(reg, 0, '\n');
if (a == 2)
- strcpy(tmpname, buf);
+ safestrncpy(tmpname, buf, sizeof tmpname);
else if (a == 3)
- strcpy(tmpaddr, buf);
+ safestrncpy(tmpaddr, buf, sizeof tmpaddr);
else if (a == 4)
- strcpy(tmpcity, buf);
+ safestrncpy(tmpcity, buf, sizeof tmpcity);
else if (a == 5)
- strcpy(tmpstate, buf);
+ safestrncpy(tmpstate, buf, sizeof tmpstate);
else if (a == 6)
- strcpy(tmpzip, buf);
+ safestrncpy(tmpzip, buf, sizeof tmpzip);
else if (a == 7)
- strcpy(tmpphone, buf);
+ safestrncpy(tmpphone, buf, sizeof tmpphone);
else if (a == 9)
- strcpy(tmpemail, buf);
+ safestrncpy(tmpemail, buf, sizeof tmpemail);
else if (a == 10)
- strcpy(tmpcountry, buf);
+ safestrncpy(tmpcountry, buf, sizeof tmpcountry);
++a;
}
}
do {
ok = 1;
- strcpy(holdemail, tmpemail);
+ safestrncpy(holdemail, tmpemail, sizeof holdemail);
strprompt("Email address", tmpemail, 31);
r = CtdlIPCDirectoryLookup(ipc, tmpemail, buf);
if (r / 100 == 2) {
- extract_token(diruser, buf, 0, '@');
- extract_token(dirnode, buf, 1, '@');
+ extract_token(diruser, buf, 0, '@', sizeof diruser);
+ extract_token(dirnode, buf, 1, '@', sizeof dirnode);
striplt(diruser);
striplt(dirnode);
if ((strcasecmp(diruser, fullname))
"It is already in use by %s @ %s.\n",
diruser, dirnode);
ok = 0;
- strcpy(tmpemail, holdemail);
+ safestrncpy(tmpemail, holdemail, sizeof tmpemail);
}
}
} while (ok == 0);
/* now send the registration info back to the server */
- reg = (char *)realloc(reg, 4096); /* Overkill? */
+ reg = (char *)realloc(reg, SIZ);
if (reg) {
sprintf(reg, "%s\n%s\n%s\n%s\n%s\n%s\n%s\n%s\n",
tmpname, tmpaddr, tmpcity, tmpstate,
if (haschar(tbuf, '/'))
extract_token(tbuf, flnm,
num_tokens(tbuf, '/') - 1,
- '/'
+ '/', sizeof tbuf
);
/* filename.1, filename.2, etc */
if (a > 0) {
if (r / 100 == 1) {
a = 0;
do {
- extract_token(buf, resp, 0, '\n');
+ extract_token(buf, resp, 0, '\n', sizeof buf);
remove_token(resp, 0, '\n');
++a;
if (a == 1)
if (r / 100 == 2)
scr_printf("%s\n", cmd);
if (r / 100 == 3) {
- extract(buf, cmd, 0);
+ extract_token(buf, cmd, 0, '|', sizeof buf);
if (val_user(ipc, buf, 1) != 0) finished = 1;
}
} while (finished == 0);
return;
}
while (strlen(resp)) {
- extract_token(buf, resp, 0, '\n');
+ extract_token(buf, resp, 0, '\n', sizeof buf);
remove_token(resp, 0, '\n');
if ((pos + strlen(buf) + 5) > screenwidth) {
pprintf("\n");
return;
}
while (strlen(resp)) {
- extract_token(buf, resp, 0, '\n');
+ extract_token(buf, resp, 0, '\n', sizeof buf);
remove_token(resp, 0, '\n');
pprintf("%s\n", buf);
}
void do_system_configuration(CtdlIPC *ipc)
{
-#define NUM_CONFIGS 37
+#define NUM_CONFIGS 42
char buf[SIZ];
char sc[NUM_CONFIGS][SIZ];
if (r / 100 == 1) {
a = 0;
while (strlen(resp)) {
- extract_token(buf, resp, 0, '\n');
+ extract_token(buf, resp, 0, '\n', sizeof buf);
remove_token(resp, 0, '\n');
if (a < NUM_CONFIGS) {
strcpy(&sc[a][0], buf);
snprintf(sc[26], sizeof sc[26], "%d", (boolprompt(
"Allow Aides to Zap (forget) rooms",
atoi(&sc[26][0]))));
- snprintf(sc[30], sizeof sc[30], "%d", (boolprompt(
- "Allow system Aides access to user mailboxes",
- atoi(&sc[30][0]))));
if (strlen(&sc[18][0]) > 0) logpages = 1;
else logpages = 0;
strprompt("Minimum number of worker threads", &sc[21][0], 3);
strprompt("Maximum number of worker threads", &sc[22][0], 3);
+ strprompt("Server IP address (0.0.0.0 for 'any')", &sc[37][0], 15);
strprompt("POP3 server port (-1 to disable)", &sc[23][0], 5);
+ strprompt("POP3S server port (-1 to disable)", &sc[40][0], 5);
strprompt("IMAP server port (-1 to disable)", &sc[27][0], 5);
- strprompt("SMTP server port (-1 to disable)", &sc[24][0], 5);
+ strprompt("IMAPS server port (-1 to disable)", &sc[39][0], 5);
+ strprompt("SMTP MTA server port (-1 to disable)", &sc[24][0], 5);
+ strprompt("SMTP MSA server port (-1 to disable)", &sc[38][0], 5);
+ strprompt("SMTPS server port (-1 to disable)", &sc[41][0], 5);
/* This logic flips the question around, because it's one of those
* situations where 0=yes and 1=no
int badkey;
int i, j;
int quitting = 0;
+ int modified = 0;
int r;
r = CtdlIPCGetSystemConfigByType(ipc, INTERNETCFG, &resp, buf);
if (r / 100 == 1) {
while (strlen(resp)) {
- extract_token(buf, resp, 0, '\n');
+ extract_token(buf, resp, 0, '\n', sizeof buf);
remove_token(resp, 0, '\n');
++num_recs;
if (num_recs == 1) recs = malloc(sizeof(char *));
for (i=0; i<num_recs; ++i) {
color(DIM_WHITE);
scr_printf("%3d ", i+1);
- extract(buf, recs[i], 0);
+ extract_token(buf, recs[i], 0, '|', sizeof buf);
color(BRIGHT_CYAN);
scr_printf("%-50s ", buf);
- extract(buf, recs[i], 1);
+ extract_token(buf, recs[i], 1, '|', sizeof buf);
color(BRIGHT_MAGENTA);
scr_printf("%-20s\n", buf);
color(DIM_WHITE);
&buf[strlen(buf)]);
recs[num_recs-1] = strdup(buf);
}
+ modified = 1;
break;
case 'd':
i = intprompt("Delete which one",
--num_recs;
for (j=i; j<num_recs; ++j)
recs[j] = recs[j+1];
+ modified = 1;
break;
case 's':
r = 1;
r = CtdlIPCSetSystemConfigByType(ipc, INTERNETCFG, resp, buf);
if (r / 100 != 4) {
err_printf("%s\n", buf);
+ } else {
+ scr_printf("Wrote %d records.\n", num_recs);
+ modified = 0;
}
- quitting = 1;
break;
case 'q':
- quitting = boolprompt(
+ quitting = !modified || boolprompt(
"Quit without saving", 0);
break;
default:
badkey = 1;
}
- } while (quitting == 0);
+ } while (!quitting);
if (recs != NULL) {
for (i=0; i<num_recs; ++i) free(recs[i]);
int e_ex_code;
pid_t editor_pid;
int cksum;
- int b, i;
+ int b, i, tokens;
char buf[SIZ];
char instr[SIZ];
char addr[SIZ];
r = CtdlIPCGetRoomNetworkConfig(ipc, &listing, buf);
if (r / 100 == 1) {
while(listing && strlen(listing)) {
- extract_token(buf, listing, 0, '\n');
+ extract_token(buf, listing, 0, '\n', sizeof buf);
remove_token(listing, 0, '\n');
- extract(instr, buf, 0);
+ extract_token(instr, buf, 0, '|', sizeof instr);
if (!strcasecmp(instr, entrytype)) {
- extract(addr, buf, 1);
- fprintf(tempfp, "%s\n", addr);
+ tokens = num_tokens(buf, '|');
+ for (i=1; i<tokens; ++i) {
+ extract_token(addr, buf, i, '|', sizeof addr);
+ fprintf(tempfp, "%s", addr);
+ if (i < (tokens-1)) {
+ fprintf(tempfp, "|");
+ }
+ }
+ fprintf(tempfp, "\n");
}
}
}
if (e_ex_code == 0) { /* Save changes */
changefp = fopen(changefile, "w");
- CtdlIPC_putline(ipc, "GNET");
- CtdlIPC_getline(ipc, buf);
- if (buf[0] == '1') {
- while(CtdlIPC_getline(ipc, buf), strcmp(buf, "000")) {
- extract(instr, buf, 0);
+ r = CtdlIPCGetRoomNetworkConfig(ipc, &listing, buf);
+ if (r / 100 == 1) {
+ while(listing && strlen(listing)) {
+ extract_token(buf, listing, 0, '\n', sizeof buf);
+ remove_token(listing, 0, '\n');
+ extract_token(instr, buf, 0, '|', sizeof instr);
if (strcasecmp(instr, entrytype)) {
fprintf(changefp, "%s\n", buf);
}
}
}
+ if (listing) {
+ free(listing);
+ listing = NULL;
+ }
tempfp = fopen(filename, "r");
while (fgets(buf, sizeof buf, tempfp) != NULL) {
for (i=0; i<strlen(buf); ++i) {
fclose(changefp);
/* now write it to the server... */
- CtdlIPC_putline(ipc, "SNET");
- CtdlIPC_getline(ipc, buf);
- if (buf[0] == '4') {
- changefp = fopen(changefile, "r");
- if (changefp != NULL) {
- while (fgets(buf, sizeof buf,
- changefp) != NULL) {
- buf[strlen(buf) - 1] = 0;
- CtdlIPC_putline(ipc, buf);
- }
- fclose(changefp);
+ changefp = fopen(changefile, "r");
+ if (changefp != NULL) {
+ listing = load_message_from_file(changefp);
+ if (listing) {
+ r = CtdlIPCSetRoomNetworkConfig(ipc, listing, buf);
+ free(listing);
+ listing = NULL;
}
- CtdlIPC_putline(ipc, "000");
+ fclose(changefp);
}
}
int badkey;
int i, j;
int quitting = 0;
+ int modified = 0;
char *listing = NULL;
int r;
r = CtdlIPCGetSystemConfigByType(ipc, IGNETCFG, &listing, buf);
if (r / 100 == 1) while (*listing && strlen(listing)) {
- extract_token(buf, listing, 0, '\n');
+ extract_token(buf, listing, 0, '\n', sizeof buf);
remove_token(listing, 0, '\n');
++num_recs;
for (i=0; i<num_recs; ++i) {
color(DIM_WHITE);
scr_printf("%3d ", i+1);
- extract(buf, recs[i], 0);
+ extract_token(buf, recs[i], 0, '|', sizeof buf);
color(BRIGHT_CYAN);
scr_printf("%-16s ", buf);
- extract(buf, recs[i], 1);
+ extract_token(buf, recs[i], 1, '|', sizeof buf);
color(BRIGHT_MAGENTA);
scr_printf("%-18s ", buf);
- extract(buf, recs[i], 2);
+ extract_token(buf, recs[i], 2, '|', sizeof buf);
color(BRIGHT_CYAN);
scr_printf("%-32s ", buf);
- extract(buf, recs[i], 3);
+ extract_token(buf, recs[i], 3, '|', sizeof buf);
color(BRIGHT_MAGENTA);
scr_printf("%-3s\n", buf);
color(DIM_WHITE);
}
+ scr_printf("\n");
ch = keymenu("", "<A>dd|<D>elete|<S>ave|<Q>uit");
switch(ch) {
strprompt("Enter port number : ",
&buf[strlen(buf)-3], 5);
recs[num_recs-1] = strdup(buf);
+ modified = 1;
break;
case 'd':
i = intprompt("Delete which one",
--num_recs;
for (j=i; j<num_recs; ++j)
recs[j] = recs[j+1];
+ modified = 1;
break;
case 's':
r = 1;
r = CtdlIPCSetSystemConfigByType(ipc, IGNETCFG, listing, buf);
if (r / 100 != 4) {
scr_printf("%s\n", buf);
+ } else {
+ scr_printf("Wrote %d records.\n", num_recs);
+ modified = 0;
}
- quitting = 1;
break;
case 'q':
- quitting = boolprompt(
+ quitting = !modified || boolprompt(
"Quit without saving", 0);
break;
default:
badkey = 1;
}
- } while (quitting == 0);
+ } while (!quitting);
if (recs != NULL) {
for (i=0; i<num_recs; ++i) free(recs[i]);
int badkey;
int i, j;
int quitting = 0;
+ int modified = 0;
char *listing = NULL;
int r;
r = CtdlIPCGetSystemConfigByType(ipc, FILTERLIST, &listing, buf);
if (r / 100 == 1) while (*listing && strlen(listing)) {
- extract_token(buf, listing, 0, '\n');
+ extract_token(buf, listing, 0, '\n', sizeof buf);
remove_token(listing, 0, '\n');
++num_recs;
for (i=0; i<num_recs; ++i) {
color(DIM_WHITE);
scr_printf("%3d ", i+1);
- extract(buf, recs[i], 0);
+ extract_token(buf, recs[i], 0, '|', sizeof buf);
color(BRIGHT_CYAN);
scr_printf("%-28s ", buf);
- extract(buf, recs[i], 1);
+ extract_token(buf, recs[i], 1, '|', sizeof buf);
color(BRIGHT_MAGENTA);
scr_printf("%-28s ", buf);
- extract(buf, recs[i], 2);
+ extract_token(buf, recs[i], 2, '|', sizeof buf);
color(BRIGHT_CYAN);
scr_printf("%-16s\n", buf);
- extract(buf, recs[i], 3);
+ extract_token(buf, recs[i], 3, '|', sizeof buf);
color(DIM_WHITE);
}
&buf[strlen(buf)], 16);
strcat(buf, "|");
recs[num_recs-1] = strdup(buf);
+ modified = 1;
break;
case 'd':
i = intprompt("Delete which one",
--num_recs;
for (j=i; j<num_recs; ++j)
recs[j] = recs[j+1];
+ modified = 1;
break;
case 's':
r = 1;
r = CtdlIPCSetSystemConfigByType(ipc, FILTERLIST, listing, buf);
if (r / 100 != 4) {
scr_printf("%s\n", buf);
+ } else {
+ scr_printf("Wrote %d records.\n", num_recs);
+ modified = 0;
}
- quitting = 1;
break;
case 'q':
- quitting = boolprompt(
+ quitting = !modified || boolprompt(
"Quit without saving", 0);
break;
default:
badkey = 1;
}
- } while (quitting == 0);
+ } while (!quitting);
if (recs != NULL) {
for (i=0; i<num_recs; ++i) free(recs[i]);