-/* More Citadel/UX routines...
- * unlike routines.c, some of these DO use global variables.
- * $Id$
+/* $Id$
+ *
+ * More client-side support functions.
+ * Unlike routines.c, some of these DO use global variables.
+ *
*/
#include "sysdep.h"
void serv_write(char *buf, int nbytes);
int haschar(char *st, int ch);
void progress(long int curr, long int cmax);
-void citedit(FILE * fp, long int base_pos);
int yesno(void);
extern char temp[];
serv_puts("LBIO");
serv_gets(buf);
if (buf[0] != '1') {
- printf("%s\n", &buf[4]);
+ pprintf("%s\n", &buf[4]);
return;
}
while (serv_gets(buf), strcmp(buf, "000")) {
if ((pos + strlen(buf) + 5) > screenwidth) {
- printf("\n");
+ pprintf("\n");
pos = 1;
}
- printf("%s, ", buf);
+ pprintf("%s, ", buf);
pos = pos + strlen(buf) + 2;
}
- printf("%c%c \n\n", 8, 8);
+ pprintf("%c%c \n\n", 8, 8);
}
do {
newprompt("Read bio for who ('?' for list) : ", who, 25);
- printf("\n");
+ pprintf("\n");
if (!strcmp(who, "?"))
list_bio();
} while (!strcmp(who, "?"));
serv_puts(buf);
serv_gets(buf);
if (buf[0] != '1') {
- printf("%s\n", &buf[4]);
+ pprintf("%s\n", &buf[4]);
return;
}
while (serv_gets(buf), strcmp(buf, "000")) {
- printf("%s\n", buf);
+ pprintf("%s\n", buf);
}
}
void do_system_configuration(void)
{
char buf[256];
- char sc[23][256];
+ char sc[26][256];
int expire_mode = 0;
int expire_value = 0;
int a;
if (buf[0] == '1') {
a = 0;
while (serv_gets(buf), strcmp(buf, "000")) {
- if (a < 23)
+ if (a < 26)
strcpy(&sc[a][0], buf);
++a;
}
strprompt("Geographic location of this system", &sc[12][0], 31);
strprompt("Name of system administrator", &sc[13][0], 25);
strprompt("Paginator prompt", &sc[10][0], 79);
-
+ strprompt("Default moderation filter for new users", &sc[25][0], 4);
/* Security parameters */
strprompt("Minimum number of worker threads", &sc[21][0], 3);
strprompt("Maximum number of worker threads", &sc[22][0], 3);
strprompt("Server-to-server networking password", &sc[15][0], 19);
+ strprompt("POP3 server port (-1 to disable)", &sc[23][0], 5);
+ strprompt("SMTP server port (-1 to disable)", &sc[24][0], 5);
/* Expiry settings */
-
strprompt("Default user purge time (days)", &sc[16][0], 5);
strprompt("Default room purge time (days)", &sc[17][0], 5);
serv_puts("CONF set");
serv_gets(buf);
if (buf[0] == '4') {
- for (a = 0; a < 23; ++a)
+ for (a = 0; a < 26; ++a)
serv_puts(&sc[a][0]);
serv_puts("000");
}
}
+/*
+ * support function for do_internet_configuration()
+ */
+void get_inet_rec_type(char *buf) {
+ int sel;
+
+ keyopt(" <1> localhost (Alias for this computer)\n");
+ keyopt(" <2> gateway domain (Domain for all Citadel systems)\n");
+ keyopt(" <3> smart-host (Forward all outbound mail to this host)\n");
+ sel = intprompt("Which one", 1, 1, 3);
+ switch(sel) {
+ case 1: strcpy(buf, "localhost");
+ return;
+ case 2: strcpy(buf, "gatewaydomain");
+ return;
+ case 3: strcpy(buf, "smarthost");
+ return;
+ }
+}
+
+
/*
* Internet mail configuration
*/
void do_internet_configuration(void) {
char buf[256];
int num_recs = 0;
+ char **recs = NULL;
char ch;
int badkey;
- int i;
+ int i, j;
+ int quitting = 0;
sprintf(buf, "CONF getsys|%s", INTERNETCFG);
serv_puts(buf);
serv_gets(buf);
if (buf[0] == '1') while (serv_gets(buf), strcmp(buf, "000")) {
+ ++num_recs;
+ if (num_recs == 1) recs = malloc(sizeof(char *));
+ else recs = realloc(recs, (sizeof(char *)) * num_recs);
+ recs[num_recs-1] = malloc(256);
+ strcpy(recs[num_recs-1], buf);
}
- while (1) {
- /* do display */
+ do {
+ printf("\n");
+ color(BRIGHT_WHITE);
+ printf("### ");
+ printf(" Host or domain ");
+ printf(" Record type \n");
+ color(DIM_WHITE);
+ printf("--- ");
+ printf("-------------------------------------------------- ");
+ printf("--------------------\n");
+ for (i=0; i<num_recs; ++i) {
+ color(DIM_WHITE);
+ printf("%3d ", i+1);
+ extract(buf, recs[i], 0);
+ color(BRIGHT_CYAN);
+ printf("%-50s ", buf);
+ extract(buf, recs[i], 1);
+ color(BRIGHT_MAGENTA);
+ printf("%-20s\n", buf);
+ color(DIM_WHITE);
+ }
- keyopt("\n<A>dd <D>elete <S>ave <Q>uit -> ");
- badkey = 0;
- do {
- ch = inkey();
- ch = tolower(ch);
- switch(ch) {
- case 'a':
- printf("Add\n");
- break;
- case 'd':
- printf("Delete\n");
- break;
- case 's':
- printf("Save\n");
- return;
- case 'q':
- printf("Quit\n");
- i = boolprompt("Quit without saving", 0);
- if (i == 1) return;
- break;
- default:
- badkey = 1;
- }
- } while (badkey == 1);
+ ch = keymenu("", "<A>dd|<D>elete|<S>ave|<Q>uit");
+ switch(ch) {
+ case 'a':
+ ++num_recs;
+ if (num_recs == 1)
+ recs = malloc(sizeof(char *));
+ else recs = realloc(recs,
+ (sizeof(char *)) * num_recs);
+ newprompt("Enter host name: ",
+ buf, 50);
+ strcat(buf, "|");
+ get_inet_rec_type(&buf[strlen(buf)]);
+ recs[num_recs-1] = strdup(buf);
+ break;
+ case 'd':
+ i = intprompt("Delete which one",
+ 1, 1, num_recs) - 1;
+ free(recs[i]);
+ --num_recs;
+ for (j=i; j<num_recs; ++j)
+ recs[j] = recs[j+1];
+ break;
+ case 's':
+ sprintf(buf, "CONF putsys|%s",
+ INTERNETCFG);
+ serv_puts(buf);
+ serv_gets(buf);
+ if (buf[0] == '4') {
+ for (i=0; i<num_recs; ++i) {
+ serv_puts(recs[i]);
+ }
+ serv_puts("000");
+ }
+ else {
+ printf("%s\n", &buf[4]);
+ }
+ quitting = 1;
+ break;
+ case 'q':
+ quitting = boolprompt(
+ "Quit without saving", 0);
+ break;
+ default:
+ badkey = 1;
+ }
+ } while (quitting == 0);
+
+ if (recs != NULL) {
+ for (i=0; i<num_recs; ++i) free(recs[i]);
+ free(recs);
}
}