commit
aa0e0221b6
Binary file not shown.
240
bbs.c
240
bbs.c
@ -44,12 +44,12 @@ void dolog(char *fmt, ...) {
|
||||
dolog("Error opening log file!");
|
||||
return;
|
||||
}
|
||||
va_list ap;
|
||||
va_start(ap, fmt);
|
||||
vsnprintf(buffer, 512, fmt, ap);
|
||||
va_end(ap);
|
||||
va_list ap;
|
||||
va_start(ap, fmt);
|
||||
vsnprintf(buffer, 512, fmt, ap);
|
||||
va_end(ap);
|
||||
|
||||
fprintf(logfptr, "%02d:%02d:%02d [%s] %s\n", time_now.tm_hour, time_now.tm_min, time_now.tm_sec, ipaddress, buffer);
|
||||
fprintf(logfptr, "%02d:%02d:%02d [%s] %s\n", time_now.tm_hour, time_now.tm_min, time_now.tm_sec, ipaddress, buffer);
|
||||
|
||||
fclose(logfptr);
|
||||
}
|
||||
@ -117,8 +117,8 @@ void timer_handler(int signum) {
|
||||
gUser->timeleft--;
|
||||
|
||||
if (gUser->timeleft <= 0) {
|
||||
s_putstring(gSocket, "\r\n\r\nSorry, you're out of time today..\r\n");
|
||||
disconnect(gSocket, "Out of Time");
|
||||
s_printf("\r\n\r\nSorry, you're out of time today..\r\n");
|
||||
disconnect("Out of Time");
|
||||
}
|
||||
|
||||
|
||||
@ -127,21 +127,32 @@ void timer_handler(int signum) {
|
||||
usertimeout--;
|
||||
}
|
||||
if (usertimeout <= 0) {
|
||||
s_putstring(gSocket, "\r\n\r\nTimeout waiting for input..\r\n");
|
||||
disconnect(gSocket, "Timeout");
|
||||
s_printf("\r\n\r\nTimeout waiting for input..\r\n");
|
||||
disconnect("Timeout");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void s_putchar(int socket, char c) {
|
||||
write(socket, &c, 1);
|
||||
void s_printf(char *fmt, ...) {
|
||||
char buffer[512];
|
||||
|
||||
va_list ap;
|
||||
va_start(ap, fmt);
|
||||
vsnprintf(buffer, 512, fmt, ap);
|
||||
va_end(ap);
|
||||
|
||||
s_putstring(buffer);
|
||||
}
|
||||
|
||||
void s_putchar(char c) {
|
||||
write(gSocket, &c, 1);
|
||||
}
|
||||
|
||||
void s_putstring(int socket, char *c) {
|
||||
write(socket, c, strlen(c));
|
||||
void s_putstring(char *c) {
|
||||
write(gSocket, c, strlen(c));
|
||||
}
|
||||
|
||||
void s_displayansi_p(int socket, char *file) {
|
||||
void s_displayansi_p(char *file) {
|
||||
FILE *fptr;
|
||||
char c;
|
||||
|
||||
@ -151,14 +162,14 @@ void s_displayansi_p(int socket, char *file) {
|
||||
}
|
||||
c = fgetc(fptr);
|
||||
while (!feof(fptr) && c != 0x1a) {
|
||||
s_putchar(socket, c);
|
||||
s_putchar(c);
|
||||
c = fgetc(fptr);
|
||||
}
|
||||
fclose(fptr);
|
||||
}
|
||||
|
||||
|
||||
void s_displayansi(int socket, char *file) {
|
||||
void s_displayansi(char *file) {
|
||||
FILE *fptr;
|
||||
char c;
|
||||
|
||||
@ -172,39 +183,39 @@ void s_displayansi(int socket, char *file) {
|
||||
}
|
||||
c = fgetc(fptr);
|
||||
while (!feof(fptr) && c != 0x1a) {
|
||||
s_putchar(socket, c);
|
||||
s_putchar(c);
|
||||
c = fgetc(fptr);
|
||||
}
|
||||
fclose(fptr);
|
||||
}
|
||||
|
||||
char s_getchar(int socket) {
|
||||
char s_getchar() {
|
||||
unsigned char c;
|
||||
int len;
|
||||
|
||||
do {
|
||||
|
||||
len = read(socket, &c, 1);
|
||||
len = read(gSocket, &c, 1);
|
||||
|
||||
if (len == 0) {
|
||||
disconnect(socket, "Socket Closed");
|
||||
disconnect("Socket Closed");
|
||||
}
|
||||
|
||||
while (c == 255) {
|
||||
len = read(socket, &c, 1);
|
||||
len = read(gSocket, &c, 1);
|
||||
if (len == 0) {
|
||||
disconnect(socket, "Socket Closed");
|
||||
disconnect("Socket Closed");
|
||||
} else if (c == 255) {
|
||||
usertimeout = 10;
|
||||
return c;
|
||||
}
|
||||
len = read(socket, &c, 1);
|
||||
len = read(gSocket, &c, 1);
|
||||
if (len == 0) {
|
||||
disconnect(socket, "Socket Closed");
|
||||
disconnect("Socket Closed");
|
||||
}
|
||||
len = read(socket, &c, 1);
|
||||
len = read(gSocket, &c, 1);
|
||||
if (len == 0) {
|
||||
disconnect(socket, "Socket Closed");
|
||||
disconnect("Socket Closed");
|
||||
}
|
||||
}
|
||||
|
||||
@ -212,7 +223,7 @@ char s_getchar(int socket) {
|
||||
|
||||
if (c == '\r') {
|
||||
if (len == 0) {
|
||||
disconnect(socket, "Socket Closed");
|
||||
disconnect("Socket Closed");
|
||||
}
|
||||
}
|
||||
} while (c == '\n');
|
||||
@ -220,25 +231,25 @@ char s_getchar(int socket) {
|
||||
return (char)c;
|
||||
}
|
||||
|
||||
char s_getc(int socket) {
|
||||
char c = s_getchar(socket);
|
||||
char s_getc() {
|
||||
char c = s_getchar();
|
||||
|
||||
s_putchar(socket, c);
|
||||
s_putchar(c);
|
||||
return (char)c;
|
||||
}
|
||||
|
||||
void s_readstring(int socket, char *buffer, int max) {
|
||||
void s_readstring(char *buffer, int max) {
|
||||
int i;
|
||||
char c;
|
||||
|
||||
memset(buffer, 0, max);
|
||||
|
||||
for (i=0;i<max;i++) {
|
||||
c = s_getchar(socket);
|
||||
c = s_getchar();
|
||||
if ((c == '\b' || c == 127) && i > 0) {
|
||||
buffer[i-1] = '\0';
|
||||
i -= 2;
|
||||
s_putstring(socket, "\e[D \e[D");
|
||||
s_printf("\e[D \e[D");
|
||||
continue;
|
||||
} else if (c == '\b' || c == 127) {
|
||||
i -= 1;
|
||||
@ -248,23 +259,23 @@ void s_readstring(int socket, char *buffer, int max) {
|
||||
if (c == '\n' || c == '\r') {
|
||||
return;
|
||||
}
|
||||
s_putchar(socket, c);
|
||||
s_putchar(c);
|
||||
buffer[i] = c;
|
||||
buffer[i+1] = '\0';
|
||||
}
|
||||
}
|
||||
|
||||
void s_readpass(int socket, char *buffer, int max) {
|
||||
void s_readpass(char *buffer, int max) {
|
||||
int i;
|
||||
char c;
|
||||
|
||||
for (i=0;i<max;i++) {
|
||||
c = s_getchar(socket);
|
||||
c = s_getchar();
|
||||
|
||||
if ((c == '\b' || c == 127) && i > 0) {
|
||||
buffer[i-1] = '\0';
|
||||
i-=2;
|
||||
s_putstring(socket, "\e[D \e[D");
|
||||
s_printf("\e[D \e[D");
|
||||
continue;
|
||||
} else if (c == '\b' || c == 127) {
|
||||
i -= 1;
|
||||
@ -274,13 +285,13 @@ void s_readpass(int socket, char *buffer, int max) {
|
||||
if (c == '\n' || c == '\r') {
|
||||
return;
|
||||
}
|
||||
s_putchar(socket, '*');
|
||||
s_putchar('*');
|
||||
buffer[i] = c;
|
||||
buffer[i+1] = '\0';
|
||||
}
|
||||
}
|
||||
|
||||
void disconnect(int socket, char *calledby) {
|
||||
void disconnect(char *calledby) {
|
||||
char buffer[256];
|
||||
if (gUser != NULL) {
|
||||
save_user(gUser);
|
||||
@ -288,7 +299,7 @@ void disconnect(int socket, char *calledby) {
|
||||
dolog("Node %d disconnected (%s)", mynode, calledby);
|
||||
sprintf(buffer, "%s/nodeinuse.%d", conf.bbs_path, mynode);
|
||||
remove(buffer);
|
||||
close(socket);
|
||||
close(gSocket);
|
||||
exit(0);
|
||||
}
|
||||
|
||||
@ -297,9 +308,7 @@ void record_last10_callers(struct user_record *user) {
|
||||
struct last10_callers callers[10];
|
||||
|
||||
int i,j;
|
||||
char buffer[256];
|
||||
struct tm l10_time;
|
||||
FILE *fptr = fopen("last10.dat", "rb");
|
||||
FILE *fptr = fopen("last10.dat", "rb");
|
||||
|
||||
if (fptr != NULL) {
|
||||
for (i=0;i<10;i++) {
|
||||
@ -332,16 +341,15 @@ void record_last10_callers(struct user_record *user) {
|
||||
}
|
||||
}
|
||||
|
||||
void display_last10_callers(int socket, struct user_record *user) {
|
||||
void display_last10_callers(struct user_record *user) {
|
||||
struct last10_callers callers[10];
|
||||
|
||||
int i,z,j;
|
||||
char buffer[256];
|
||||
struct tm l10_time;
|
||||
int i,z;
|
||||
struct tm l10_time;
|
||||
FILE *fptr = fopen("last10.dat", "rb");
|
||||
|
||||
s_putstring(socket, "\r\n\e[1;37mLast 10 callers:\r\n");
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\r\n");
|
||||
s_printf("\r\n\e[1;37mLast 10 callers:\r\n");
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\r\n");
|
||||
|
||||
if (fptr != NULL) {
|
||||
|
||||
@ -358,53 +366,41 @@ void display_last10_callers(int socket, struct user_record *user) {
|
||||
|
||||
for (z=0;z<i;z++) {
|
||||
localtime_r(&callers[z].time, &l10_time);
|
||||
sprintf(buffer, "\e[1;37m%-16s \e[1;36m%-32s \e[1;32m%02d:%02d %02d-%02d-%02d\e[0m\r\n", callers[z].name, callers[z].location, l10_time.tm_hour, l10_time.tm_min, l10_time.tm_mday, l10_time.tm_mon + 1, l10_time.tm_year - 100);
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\e[1;37m%-16s \e[1;36m%-32s \e[1;32m%02d:%02d %02d-%02d-%02d\e[0m\r\n", callers[z].name, callers[z].location, l10_time.tm_hour, l10_time.tm_min, l10_time.tm_mday, l10_time.tm_mon + 1, l10_time.tm_year - 100);
|
||||
}
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
sprintf(buffer, "Press any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
s_getc();
|
||||
}
|
||||
|
||||
void display_info(int socket) {
|
||||
char buffer[256];
|
||||
struct utsname name;
|
||||
void display_info() {
|
||||
struct utsname name;
|
||||
|
||||
uname(&name);
|
||||
|
||||
sprintf(buffer, "\r\n\r\n\e[1;37mSystem Information\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;30m----------------------------------------------\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mBBS Name : \e[1;37m%s\r\n", conf.bbs_name);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mSysOp Name : \e[1;37m%s\r\n", conf.sysop_name);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mNode : \e[1;37m%d\r\n", mynode);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mBBS Version : \e[1;37mMagicka %d.%d (%s)\r\n", VERSION_MAJOR, VERSION_MINOR, VERSION_STR);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mSystem : \e[1;37m%s (%s)\r\n", name.sysname, name.machine);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;30m----------------------------------------------\e[0m\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\n\r\n\e[1;37mSystem Information\r\n");
|
||||
s_printf("\e[1;30m----------------------------------------------\r\n");
|
||||
s_printf("\e[1;32mBBS Name : \e[1;37m%s\r\n", conf.bbs_name);
|
||||
s_printf("\e[1;32mSysOp Name : \e[1;37m%s\r\n", conf.sysop_name);
|
||||
s_printf("\e[1;32mNode : \e[1;37m%d\r\n", mynode);
|
||||
s_printf("\e[1;32mBBS Version : \e[1;37mMagicka %d.%d (%s)\r\n", VERSION_MAJOR, VERSION_MINOR, VERSION_STR);
|
||||
s_printf("\e[1;32mSystem : \e[1;37m%s (%s)\r\n", name.sysname, name.machine);
|
||||
s_printf("\e[1;30m----------------------------------------------\e[0m\r\n");
|
||||
|
||||
sprintf(buffer, "Press any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
s_getc();
|
||||
}
|
||||
|
||||
void automessage_write(int socket, struct user_record *user) {
|
||||
void automessage_write(struct user_record *user) {
|
||||
FILE *fptr;
|
||||
char automsg[450];
|
||||
char buffer[90];
|
||||
char buffer[76];
|
||||
int i;
|
||||
struct tm timenow;
|
||||
time_t timen;
|
||||
|
||||
memset(automsg, 0, 450);
|
||||
memset(buffer, 0, 90);
|
||||
memset(buffer, 0, 76);
|
||||
|
||||
if (user->sec_level >= conf.automsgwritelvl) {
|
||||
timen = time(NULL);
|
||||
@ -414,11 +410,10 @@ void automessage_write(int socket, struct user_record *user) {
|
||||
|
||||
automsg[strlen(automsg) - 1] = '\r';
|
||||
automsg[strlen(automsg)] = '\n';
|
||||
s_putstring(socket, "\r\nEnter your message (4 lines):\r\n");
|
||||
s_printf("\r\nEnter your message (4 lines):\r\n");
|
||||
for (i=0;i<4;i++) {
|
||||
sprintf(buffer, "\r\n%d: ", i);
|
||||
s_putstring(socket, buffer);
|
||||
s_readstring(socket, buffer, 75);
|
||||
s_printf("\r\n%d: ", i);
|
||||
s_readstring(buffer, 75);
|
||||
strcat(automsg, buffer);
|
||||
strcat(automsg, "\r\n");
|
||||
}
|
||||
@ -433,12 +428,12 @@ void automessage_write(int socket, struct user_record *user) {
|
||||
}
|
||||
}
|
||||
|
||||
void automessage_display(int socket) {
|
||||
void automessage_display() {
|
||||
struct stat s;
|
||||
FILE *fptr;
|
||||
char buffer[90];
|
||||
int i;
|
||||
s_putstring(socket, "\r\n\r\n");
|
||||
s_printf("\r\n\r\n");
|
||||
if (stat("automessage.txt", &s) == 0) {
|
||||
fptr = fopen("automessage.txt", "r");
|
||||
if (fptr) {
|
||||
@ -448,17 +443,17 @@ void automessage_display(int socket) {
|
||||
buffer[strlen(buffer) - 1] = '\r';
|
||||
buffer[strlen(buffer)] = '\n';
|
||||
|
||||
s_putstring(socket, buffer);
|
||||
s_printf(buffer);
|
||||
}
|
||||
fclose(fptr);
|
||||
} else {
|
||||
dolog("Error opening automessage.txt");
|
||||
}
|
||||
} else {
|
||||
s_putstring(socket, "No automessage!\r\n");
|
||||
s_printf("No automessage!\r\n");
|
||||
}
|
||||
s_putstring(socket, "\e[0mPress any key to continue...\r\n");
|
||||
s_getc(socket);
|
||||
s_printf("\e[0mPress any key to continue...\r\n");
|
||||
s_getc();
|
||||
}
|
||||
|
||||
void runbbs(int socket, char *ip) {
|
||||
@ -484,11 +479,11 @@ void runbbs(int socket, char *ip) {
|
||||
write(socket, iac_echo, 3);
|
||||
write(socket, iac_sga, 3);
|
||||
|
||||
gUser = NULL;
|
||||
gSocket = socket;
|
||||
|
||||
|
||||
sprintf(buffer, "Magicka BBS v%d.%d (%s), Loading...\r\n", VERSION_MAJOR, VERSION_MINOR, VERSION_STR);
|
||||
s_putstring(socket, buffer);
|
||||
|
||||
s_printf("Magicka BBS v%d.%d (%s), Loading...\r\n", VERSION_MAJOR, VERSION_MINOR, VERSION_STR);
|
||||
|
||||
// find out which node we are
|
||||
mynode = 0;
|
||||
for (i=1;i<=conf.nodes;i++) {
|
||||
@ -510,12 +505,11 @@ void runbbs(int socket, char *ip) {
|
||||
}
|
||||
|
||||
if (mynode == 0) {
|
||||
s_putstring(socket, "Sorry, all nodes are in use. Please try later\r\n");
|
||||
s_printf("Sorry, all nodes are in use. Please try later\r\n");
|
||||
close(socket);
|
||||
exit(1);
|
||||
}
|
||||
gUser = NULL;
|
||||
gSocket = socket;
|
||||
|
||||
usertimeout = 10;
|
||||
timeoutpaused = 0;
|
||||
|
||||
@ -531,22 +525,22 @@ void runbbs(int socket, char *ip) {
|
||||
|
||||
setitimer (ITIMER_REAL, &itime, 0);
|
||||
|
||||
s_displayansi(socket, "issue");
|
||||
s_displayansi("issue");
|
||||
|
||||
s_putstring(socket, "\e[0mEnter your Login Name or NEW to create an account\r\n");
|
||||
s_putstring(socket, "Login:> ");
|
||||
s_printf("\e[0mEnter your Login Name or NEW to create an account\r\n");
|
||||
s_printf("Login:> ");
|
||||
|
||||
s_readstring(socket, buffer, 25);
|
||||
s_readstring(buffer, 25);
|
||||
|
||||
if (strcasecmp(buffer, "new") == 0) {
|
||||
user = new_user(socket);
|
||||
user = new_user();
|
||||
} else {
|
||||
s_putstring(socket, "\r\nPassword:> ");
|
||||
s_readpass(socket, password, 16);
|
||||
user = check_user_pass(socket, buffer, password);
|
||||
s_printf("\r\nPassword:> ");
|
||||
s_readpass(password, 16);
|
||||
user = check_user_pass(buffer, password);
|
||||
if (user == NULL) {
|
||||
s_putstring(socket, "\r\nIncorrect Login.\r\n");
|
||||
disconnect(socket, "Incorrect Login");
|
||||
s_printf("\r\nIncorrect Login.\r\n");
|
||||
disconnect("Incorrect Login");
|
||||
}
|
||||
|
||||
for (i=1;i<=conf.nodes;i++) {
|
||||
@ -555,14 +549,14 @@ void runbbs(int socket, char *ip) {
|
||||
nodefile = fopen(buffer, "r");
|
||||
if (!nodefile) {
|
||||
dolog("Error opening nodefile!");
|
||||
disconnect(socket, "Error opening nodefile!");
|
||||
disconnect("Error opening nodefile!");
|
||||
}
|
||||
fgets(buffer, 256, nodefile);
|
||||
|
||||
if (strcasecmp(user->loginname, buffer) == 0) {
|
||||
fclose(nodefile);
|
||||
s_putstring(socket, "\r\nYou are already logged in.\r\n");
|
||||
disconnect(socket, "Already Logged in");
|
||||
s_printf("\r\nYou are already logged in.\r\n");
|
||||
disconnect("Already Logged in");
|
||||
}
|
||||
fclose(nodefile);
|
||||
}
|
||||
@ -621,10 +615,9 @@ void runbbs(int socket, char *ip) {
|
||||
|
||||
while (stat(buffer, &s) == 0) {
|
||||
sprintf(buffer, "bulletin%d", i);
|
||||
s_displayansi(socket, buffer);
|
||||
sprintf(buffer, "\e[0mPress any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_displayansi(buffer);
|
||||
s_printf("\e[0mPress any key to continue...\r\n");
|
||||
s_getc();
|
||||
i++;
|
||||
sprintf(buffer, "%s/bulletin%d.ans", conf.ansi_path, i);
|
||||
}
|
||||
@ -632,28 +625,27 @@ void runbbs(int socket, char *ip) {
|
||||
// external login cmd
|
||||
|
||||
// display info
|
||||
display_info(socket);
|
||||
display_info();
|
||||
|
||||
display_last10_callers(socket, user);
|
||||
display_last10_callers(user);
|
||||
|
||||
// check email
|
||||
i = mail_getemailcount(user);
|
||||
if (i > 0) {
|
||||
sprintf(buffer, "\r\nYou have %d e-mail(s) in your inbox.\r\n", i);
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\nYou have %d e-mail(s) in your inbox.\r\n", i);
|
||||
} else {
|
||||
s_putstring(socket, "\r\nYou have no e-mail.\r\n");
|
||||
s_printf("\r\nYou have no e-mail.\r\n");
|
||||
}
|
||||
|
||||
mail_scan(socket, user);
|
||||
mail_scan(user);
|
||||
|
||||
automessage_display(socket);
|
||||
automessage_display();
|
||||
}
|
||||
record_last10_callers(user);
|
||||
// main menu
|
||||
main_menu(socket, user);
|
||||
main_menu(user);
|
||||
|
||||
s_displayansi(socket, "goodbye");
|
||||
s_displayansi("goodbye");
|
||||
dolog("%s is logging out, on node %d", user->loginname, mynode);
|
||||
disconnect(socket, "Log out");
|
||||
disconnect("Log out");
|
||||
}
|
||||
|
59
bbs.h
59
bbs.h
@ -136,52 +136,53 @@ struct user_record {
|
||||
int timeson;
|
||||
};
|
||||
|
||||
extern void automessage_write(int socket, struct user_record *user);
|
||||
extern void automessage_display(int socket);
|
||||
extern void automessage_write(struct user_record *user);
|
||||
extern void automessage_display();
|
||||
extern void dolog(char *fmt, ...);
|
||||
extern void runbbs(int sock, char *ipaddress);
|
||||
extern struct fido_addr *parse_fido_addr(const char *str);
|
||||
extern void s_putchar(int socket, char c);
|
||||
extern void s_putstring(int socket, char *c);
|
||||
extern void s_displayansi_p(int socket, char *file);
|
||||
extern void s_displayansi(int socket, char *file);
|
||||
extern char s_getchar(int socket);
|
||||
extern void s_readpass(int socket, char *buffer, int max);
|
||||
extern void s_readstring(int socket, char *buffer, int max);
|
||||
extern char s_getc(int socket);
|
||||
extern void disconnect(int socket, char *calledby);
|
||||
extern void display_info(int socket);
|
||||
extern void display_last10_callers(int socket, struct user_record *user);
|
||||
extern void s_putchar(char c);
|
||||
extern void s_printf(char *fmt, ...);
|
||||
extern void s_putstring(char *c);
|
||||
extern void s_displayansi_p(char *file);
|
||||
extern void s_displayansi(char *file);
|
||||
extern char s_getchar();
|
||||
extern void s_readpass(char *buffer, int max);
|
||||
extern void s_readstring(char *buffer, int max);
|
||||
extern char s_getc();
|
||||
extern void disconnect(char *calledby);
|
||||
extern void display_info();
|
||||
extern void display_last10_callers(struct user_record *user);
|
||||
|
||||
extern void gen_salt(char **s);
|
||||
extern char *hash_sha256(char *pass, char *salt);
|
||||
extern int save_user(struct user_record *user);
|
||||
extern int check_user(char *loginname);
|
||||
extern struct user_record *new_user(int socket);
|
||||
extern struct user_record *check_user_pass(int socket, char *loginname, char *password);
|
||||
extern void list_users(int socket, struct user_record *user);
|
||||
extern struct user_record *new_user();
|
||||
extern struct user_record *check_user_pass(char *loginname, char *password);
|
||||
extern void list_users(struct user_record *user);
|
||||
|
||||
extern void main_menu(int socket, struct user_record *user);
|
||||
extern void main_menu(struct user_record *user);
|
||||
|
||||
extern void mail_scan(int socket, struct user_record *user);
|
||||
extern int mail_menu(int socket, struct user_record *user);
|
||||
extern char *editor(int socket, struct user_record *user, char *quote, char *from, int email);
|
||||
extern char *external_editor(int socket, struct user_record *user, char *to, char *from, char *quote, char *qfrom, char *subject, int email);
|
||||
extern void mail_scan(struct user_record *user);
|
||||
extern int mail_menu(struct user_record *user);
|
||||
extern char *editor(struct user_record *user, char *quote, char *from, int email);
|
||||
extern char *external_editor(struct user_record *user, char *to, char *from, char *quote, char *qfrom, char *subject, int email);
|
||||
|
||||
extern int door_menu(int socket, struct user_record *user);
|
||||
extern void rundoor(int socket, struct user_record *user, char *cmd, int stdio);
|
||||
extern int door_menu(struct user_record *user);
|
||||
extern void rundoor(struct user_record *user, char *cmd, int stdio);
|
||||
|
||||
extern void bbs_list(int socket, struct user_record *user);
|
||||
extern void bbs_list(struct user_record *user);
|
||||
|
||||
extern void chat_system(int sock, struct user_record *user);
|
||||
extern void chat_system(struct user_record *user);
|
||||
|
||||
extern int mail_getemailcount(struct user_record *user);
|
||||
extern void send_email(int socket, struct user_record *user);
|
||||
extern void list_emails(int socket, struct user_record *user);
|
||||
extern void send_email(struct user_record *user);
|
||||
extern void list_emails(struct user_record *user);
|
||||
|
||||
extern int file_menu(int socket, struct user_record *user);
|
||||
extern int file_menu(struct user_record *user);
|
||||
|
||||
extern void settings_menu(int sock, struct user_record *user);
|
||||
extern void settings_menu(struct user_record *user);
|
||||
|
||||
extern void lua_push_cfunctions(lua_State *L);
|
||||
#endif
|
||||
|
127
bbs_list.c
127
bbs_list.c
@ -8,7 +8,7 @@
|
||||
extern struct bbs_config conf;
|
||||
extern int mynode;
|
||||
|
||||
void add_bbs(int socket, struct user_record *user) {
|
||||
void add_bbs(struct user_record *user) {
|
||||
char *create_sql = "CREATE TABLE IF NOT EXISTS bbslist ("
|
||||
"id INTEGER PRIMARY KEY,"
|
||||
"bbsname TEXT,"
|
||||
@ -28,27 +28,24 @@ void add_bbs(int socket, struct user_record *user) {
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
|
||||
s_putstring(socket, "\r\n\e[1;37mEnter the BBS Name: \e[0m");
|
||||
s_readstring(socket, bbsname, 18);
|
||||
s_printf("\r\n\e[1;37mEnter the BBS Name: \e[0m");
|
||||
s_readstring(bbsname, 18);
|
||||
|
||||
s_putstring(socket, "\r\n\e[1;37mEnter the Sysop's Name: \e[0m");
|
||||
s_readstring(socket, sysop, 16);
|
||||
s_printf("\r\n\e[1;37mEnter the Sysop's Name: \e[0m");
|
||||
s_readstring(sysop, 16);
|
||||
|
||||
s_putstring(socket, "\r\n\e[1;37mEnter the Telnet URL: \e[0m");
|
||||
s_readstring(socket, telnet, 38);
|
||||
s_printf("\r\n\e[1;37mEnter the Telnet URL: \e[0m");
|
||||
s_readstring(telnet, 38);
|
||||
|
||||
s_putstring(socket, "\r\nYou entered:\r\n");
|
||||
s_putstring(socket, "\e[1;30m----------------------------------------------\e[0m\r\n");
|
||||
sprintf(buffer, "\e[1;37mBBS Name: \e[1;32m%s\r\n", bbsname);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;37mSysop: \e[1;32m%s\r\n", sysop);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;37mTelnet URL: \e[1;32m%s\r\n", telnet);
|
||||
s_putstring(socket, buffer);
|
||||
s_putstring(socket, "\e[1;30m----------------------------------------------\e[0m\r\n");
|
||||
s_putstring(socket, "Is this correct? (Y/N) :");
|
||||
s_printf("\r\nYou entered:\r\n");
|
||||
s_printf("\e[1;30m----------------------------------------------\e[0m\r\n");
|
||||
s_printf("\e[1;37mBBS Name: \e[1;32m%s\r\n", bbsname);
|
||||
s_printf("\e[1;37mSysop: \e[1;32m%s\r\n", sysop);
|
||||
s_printf("\e[1;37mTelnet URL: \e[1;32m%s\r\n", telnet);
|
||||
s_printf("\e[1;30m----------------------------------------------\e[0m\r\n");
|
||||
s_printf("Is this correct? (Y/N) :");
|
||||
|
||||
c = s_getc(socket);
|
||||
c = s_getc();
|
||||
if (tolower(c) == 'y') {
|
||||
sprintf(buffer, "%s/bbslist.sq3", conf.bbs_path);
|
||||
|
||||
@ -96,79 +93,78 @@ void add_bbs(int socket, struct user_record *user) {
|
||||
}
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\n\e[1;32mAdded!\e[0m\r\n");
|
||||
s_printf("\r\n\e[1;32mAdded!\e[0m\r\n");
|
||||
} else {
|
||||
s_putstring(socket, "\r\n\e[1;31mAborted!\e[0m\r\n");
|
||||
s_printf("\r\n\e[1;31mAborted!\e[0m\r\n");
|
||||
}
|
||||
}
|
||||
|
||||
void delete_bbs(int socket, struct user_record *user) {
|
||||
void delete_bbs(struct user_record *user) {
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
char *sql = "SELECT bbsname FROM bbslist WHERE id=? and owner=?";
|
||||
char *dsql = "DELETE FROM bbslist WHERE id=?";
|
||||
int i;
|
||||
char c;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
char *sql = "SELECT bbsname FROM bbslist WHERE id=? and owner=?";
|
||||
char *dsql = "DELETE FROM bbslist WHERE id=?";
|
||||
int i;
|
||||
char c;
|
||||
|
||||
s_putstring(socket, "\r\nPlease enter the id of the BBS you want to delete: ");
|
||||
s_readstring(socket, buffer, 5);
|
||||
i = atoi(buffer);
|
||||
s_printf("\r\nPlease enter the id of the BBS you want to delete: ");
|
||||
s_readstring(buffer, 5);
|
||||
i = atoi(buffer);
|
||||
|
||||
sprintf(buffer, "%s/bbslist.sq3", conf.bbs_path);
|
||||
sprintf(buffer, "%s/bbslist.sq3", conf.bbs_path);
|
||||
|
||||
rc = sqlite3_open(buffer, &db);
|
||||
rc = sqlite3_open(buffer, &db);
|
||||
if (rc != SQLITE_OK) {
|
||||
return;
|
||||
}
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
if (rc == SQLITE_OK) {
|
||||
sqlite3_bind_int(res, 1, i);
|
||||
sqlite3_bind_int(res, 2, user->id);
|
||||
} else {
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nThere are no BBSes in the list yet!\r\n");
|
||||
s_printf("\r\nThere are no BBSes in the list yet!\r\n");
|
||||
return;
|
||||
}
|
||||
if (sqlite3_step(res) == SQLITE_ROW) {
|
||||
sprintf(buffer, "\r\nAre you sure you want to delete %s?\r\n", sqlite3_column_text(res, 0));
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\nAre you sure you want to delete %s?\r\n", sqlite3_column_text(res, 0));
|
||||
sqlite3_finalize(res);
|
||||
c = s_getc(socket);
|
||||
c = s_getc();
|
||||
if (tolower(c) == 'y') {
|
||||
rc = sqlite3_prepare_v2(db, dsql, -1, &res, 0);
|
||||
if (rc == SQLITE_OK) {
|
||||
sqlite3_bind_int(res, 1, i);
|
||||
} else {
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nThere are no BBSes in the list yet!\r\n");
|
||||
s_printf("\r\nThere are no BBSes in the list yet!\r\n");
|
||||
return;
|
||||
}
|
||||
sqlite3_step(res);
|
||||
s_putstring(socket, "\r\n\e[1;32mDeleted!\e[0m\r\n");
|
||||
s_printf("\r\n\e[1;32mDeleted!\e[0m\r\n");
|
||||
sqlite3_finalize(res);
|
||||
} else {
|
||||
s_putstring(socket, "\r\n\e[1;32mAborted!\e[0m\r\n");
|
||||
s_printf("\r\n\e[1;32mAborted!\e[0m\r\n");
|
||||
}
|
||||
} else {
|
||||
sqlite3_finalize(res);
|
||||
s_putstring(socket, "\r\nThat BBS entry either doesn't exist or wasn't created by you.\r\n");
|
||||
s_printf("\r\nThat BBS entry either doesn't exist or wasn't created by you.\r\n");
|
||||
}
|
||||
sqlite3_close(db);
|
||||
}
|
||||
|
||||
void list_bbses(int socket) {
|
||||
void list_bbses() {
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
char *sql = "SELECT id,bbsname,sysop,telnet FROM bbslist";
|
||||
int i;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
char *sql = "SELECT id,bbsname,sysop,telnet FROM bbslist";
|
||||
int i;
|
||||
|
||||
sprintf(buffer, "%s/bbslist.sq3", conf.bbs_path);
|
||||
sprintf(buffer, "%s/bbslist.sq3", conf.bbs_path);
|
||||
|
||||
rc = sqlite3_open(buffer, &db);
|
||||
rc = sqlite3_open(buffer, &db);
|
||||
if (rc != SQLITE_OK) {
|
||||
dolog("Cannot open database: %s", sqlite3_errmsg(db));
|
||||
sqlite3_close(db);
|
||||
@ -177,51 +173,48 @@ void list_bbses(int socket) {
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
if (rc != SQLITE_OK) {
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nThere are no BBSes in the list yet!\r\n");
|
||||
s_printf("\r\nThere are no BBSes in the list yet!\r\n");
|
||||
return;
|
||||
}
|
||||
i = 0;
|
||||
s_putstring(socket, "\r\n\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf("\r\n\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
|
||||
while (sqlite3_step(res) == SQLITE_ROW) {
|
||||
sprintf(buffer, "\e[1;30m[\e[1;34m%3d\e[1;30m] \e[1;37m%-18s \e[1;33m%-16s \e[1;32m%-37s\e[0m\r\n", sqlite3_column_int(res, 0), sqlite3_column_text(res, 1), sqlite3_column_text(res, 2), sqlite3_column_text(res, 3));
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\e[1;30m[\e[1;34m%3d\e[1;30m] \e[1;37m%-18s \e[1;33m%-16s \e[1;32m%-37s\e[0m\r\n", sqlite3_column_int(res, 0), sqlite3_column_text(res, 1), sqlite3_column_text(res, 2), sqlite3_column_text(res, 3));
|
||||
i++;
|
||||
if (i == 20) {
|
||||
sprintf(buffer, "Press any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
s_getc();
|
||||
i = 0;
|
||||
}
|
||||
}
|
||||
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
|
||||
sprintf(buffer, "Press any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
s_getc();
|
||||
}
|
||||
|
||||
void bbs_list(int socket, struct user_record *user) {
|
||||
void bbs_list(struct user_record *user) {
|
||||
int doquit = 0;
|
||||
char c;
|
||||
|
||||
while(!doquit) {
|
||||
s_putstring(socket, "\r\n\e[1;32mBBS Listings: \e[1;37m(\e[1;33mL\e[1;37m) \e[1;32mList, \e[1;37m(\e[1;33mA\e[1;37m) \e[1;32mAdd \e[1;37m(\e[1;33mD\e[1;37m) \e[1;32mDelete \e[1;37m(\e[1;33mQ\e[1;37m) \e[1;32mQuit\e[0m\r\n");
|
||||
s_printf("\r\n\e[1;32mBBS Listings: \e[1;37m(\e[1;33mL\e[1;37m) \e[1;32mList, \e[1;37m(\e[1;33mA\e[1;37m) \e[1;32mAdd \e[1;37m(\e[1;33mD\e[1;37m) \e[1;32mDelete \e[1;37m(\e[1;33mQ\e[1;37m) \e[1;32mQuit\e[0m\r\n");
|
||||
|
||||
c = s_getc(socket);
|
||||
c = s_getc();
|
||||
|
||||
switch(tolower(c)) {
|
||||
case 'l':
|
||||
list_bbses(socket);
|
||||
list_bbses();
|
||||
break;
|
||||
case 'a':
|
||||
add_bbs(socket, user);
|
||||
add_bbs(user);
|
||||
break;
|
||||
case 'd':
|
||||
delete_bbs(socket, user);
|
||||
delete_bbs(user);
|
||||
break;
|
||||
case 'q':
|
||||
doquit = 1;
|
||||
|
121
chat_system.c
121
chat_system.c
@ -11,6 +11,7 @@
|
||||
|
||||
extern struct bbs_config conf;
|
||||
extern int mynode;
|
||||
extern int gSocket;
|
||||
|
||||
static char **screenbuffer;
|
||||
static int chat_socket;
|
||||
@ -43,25 +44,25 @@ int hostname_to_ip(char * hostname , char* ip) {
|
||||
struct hostent *he;
|
||||
struct in_addr **addr_list;
|
||||
int i;
|
||||
|
||||
if ( (he = gethostbyname( hostname ) ) == NULL)
|
||||
|
||||
if ( (he = gethostbyname( hostname ) ) == NULL)
|
||||
{
|
||||
// get the host info
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
addr_list = (struct in_addr **) he->h_addr_list;
|
||||
|
||||
|
||||
for(i = 0; addr_list[i] != NULL; i++) {
|
||||
strcpy(ip , inet_ntoa(*addr_list[i]) );
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
return 1;
|
||||
}
|
||||
void append_screenbuffer(char *buffer) {
|
||||
int z;
|
||||
|
||||
|
||||
for (z=0;z<strlen(buffer);z++) {
|
||||
if (row_at == 80) {
|
||||
if (line_at == 22) {
|
||||
@ -72,7 +73,7 @@ void append_screenbuffer(char *buffer) {
|
||||
line_at++;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
screenbuffer[line_at][row_at] = buffer[z];
|
||||
row_at++;
|
||||
screenbuffer[line_at][row_at] = '\0';
|
||||
@ -82,53 +83,47 @@ void append_screenbuffer(char *buffer) {
|
||||
}
|
||||
if (line_at < 22) {
|
||||
line_at++;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
row_at = 0;
|
||||
}
|
||||
|
||||
void chat_system(int sock, struct user_record *user) {
|
||||
void chat_system(struct user_record *user) {
|
||||
struct sockaddr_in servaddr;
|
||||
fd_set fds;
|
||||
int t;
|
||||
int ret;
|
||||
char inputbuffer[80];
|
||||
int inputbuffer_at = 0;
|
||||
int len;
|
||||
char c;
|
||||
char buffer2[256];
|
||||
char buffer[513];
|
||||
char buffer3[513];
|
||||
char outputbuffer[513];
|
||||
int buffer_at = 0;
|
||||
fd_set fds;
|
||||
int t;
|
||||
int ret;
|
||||
char inputbuffer[80];
|
||||
int inputbuffer_at = 0;
|
||||
int len;
|
||||
char c;
|
||||
char buffer2[256];
|
||||
char buffer[513];
|
||||
char outputbuffer[513];
|
||||
int buffer_at = 0;
|
||||
int do_update = 1;
|
||||
int i;
|
||||
int o;
|
||||
int l;
|
||||
int j;
|
||||
int z;
|
||||
int z2;
|
||||
char *usr;
|
||||
char *cmd;
|
||||
char *where;
|
||||
char *message;
|
||||
char *pos;
|
||||
char *sep;
|
||||
char *target;
|
||||
memset(inputbuffer, 0, 80);
|
||||
if (conf.irc_server == NULL) {
|
||||
s_putstring(sock, "\r\nSorry, Chat is not supported on this system.\r\n");
|
||||
s_putstring("\r\nSorry, Chat is not supported on this system.\r\n");
|
||||
return;
|
||||
}
|
||||
row_at = 0;
|
||||
line_at = 0;
|
||||
s_putstring(sock, "\e[2J");
|
||||
|
||||
s_putstring("\e[2J");
|
||||
|
||||
memset(&servaddr, 0, sizeof(struct sockaddr_in));
|
||||
servaddr.sin_family = AF_INET;
|
||||
servaddr.sin_port = htons(conf.irc_port);
|
||||
|
||||
|
||||
|
||||
|
||||
if ( (chat_socket = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
|
||||
return;
|
||||
}
|
||||
@ -145,36 +140,36 @@ void chat_system(int sock, struct user_record *user) {
|
||||
raw("USER %s 0 0 :%s\r\n", user->loginname, user->loginname);
|
||||
raw("NICK %s\r\n", user->loginname);
|
||||
raw("JOIN %s\r\n", conf.irc_channel);
|
||||
|
||||
|
||||
memset(buffer, 0, 513);
|
||||
|
||||
screenbuffer = (char **)malloc(sizeof(char *) * 23);
|
||||
|
||||
screenbuffer = (char **)malloc(sizeof(char *) * 23);
|
||||
for (i=0;i<23;i++) {
|
||||
screenbuffer[i] = (char *)malloc(81);
|
||||
memset(screenbuffer[i], 0, 81);
|
||||
}
|
||||
|
||||
|
||||
while (1) {
|
||||
FD_ZERO(&fds);
|
||||
FD_SET(sock, &fds);
|
||||
FD_SET(gSocket, &fds);
|
||||
FD_SET(chat_socket, &fds);
|
||||
|
||||
if (chat_socket > sock) {
|
||||
|
||||
if (chat_socket > gSocket) {
|
||||
t = chat_socket + 1;
|
||||
} else {
|
||||
t = sock + 1;
|
||||
t = gSocket + 1;
|
||||
}
|
||||
|
||||
|
||||
ret = select(t, &fds, NULL, NULL, NULL);
|
||||
|
||||
|
||||
if (ret > 0) {
|
||||
if (FD_ISSET(sock, &fds)) {
|
||||
len = read(sock, &c, 1);
|
||||
if (FD_ISSET(gSocket, &fds)) {
|
||||
len = read(gSocket, &c, 1);
|
||||
if (len == 0) {
|
||||
raw("QUIT\r\n");
|
||||
disconnect(sock, "Socket closed");
|
||||
disconnect("Socket closed");
|
||||
}
|
||||
|
||||
|
||||
if (c == '\r') {
|
||||
if (inputbuffer[0] == '/') {
|
||||
if (strcasecmp(&inputbuffer[1], "quit") == 0) {
|
||||
@ -205,19 +200,19 @@ void chat_system(int sock, struct user_record *user) {
|
||||
do_update = 2;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (FD_ISSET(chat_socket, &fds)) {
|
||||
len = read(chat_socket, &c, 1);
|
||||
if (len == 0) {
|
||||
s_putstring(sock, "\r\n\r\n\r\nLost connection to chat server!\r\n");
|
||||
s_putstring("\r\n\r\n\r\nLost connection to chat server!\r\n");
|
||||
for (i=0;i<22;i++) {
|
||||
free(screenbuffer[i]);
|
||||
}
|
||||
free(screenbuffer);
|
||||
free(screenbuffer);
|
||||
return;
|
||||
}
|
||||
|
||||
if (c == '\r' || buffer_at == 512) {
|
||||
|
||||
if (c == '\r' || buffer_at == 512) {
|
||||
if (!strncmp(buffer, "PING", 4)) {
|
||||
buffer[1] = 'O';
|
||||
raw(buffer);
|
||||
@ -241,7 +236,7 @@ void chat_system(int sock, struct user_record *user) {
|
||||
}
|
||||
|
||||
|
||||
if (!strncmp(cmd, "PRIVMSG", 7) || !strncmp(cmd, "NOTICE", 6)) {
|
||||
if (!strncmp(cmd, "PRIVMSG", 7) || !strncmp(cmd, "NOTICE", 6)) {
|
||||
for (j=0;j<strlen(message);j++) {
|
||||
if (message[j] == ' ') {
|
||||
where = message;
|
||||
@ -255,13 +250,13 @@ void chat_system(int sock, struct user_record *user) {
|
||||
if (!strncmp(cmd, "PRIVMSG", 7)) {
|
||||
if (strcmp(target, conf.irc_channel) == 0) {
|
||||
sprintf(outputbuffer, "%s: %s", usr, message);
|
||||
}
|
||||
}
|
||||
append_screenbuffer(outputbuffer);
|
||||
do_update = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
memset(buffer, 0, 513);
|
||||
buffer_at = 0;
|
||||
} else if (c != '\n') {
|
||||
@ -271,22 +266,20 @@ void chat_system(int sock, struct user_record *user) {
|
||||
}
|
||||
}
|
||||
if (do_update == 1) {
|
||||
s_putstring(sock, "\e[2J");
|
||||
s_putstring("\e[2J");
|
||||
for (i=0;i<=line_at;i++) {
|
||||
sprintf(buffer2, "%s\r\n", screenbuffer[i]);
|
||||
s_putstring(sock, buffer2);
|
||||
s_printf("%s\r\n", screenbuffer[i]);
|
||||
}
|
||||
for (i=line_at+1;i<22;i++) {
|
||||
s_putstring(sock, "\r\n");
|
||||
s_putstring("\r\n");
|
||||
}
|
||||
s_putstring(sock, "\e[1;45;37m Type /Quit to Exit\e[K\e[0m\r\n");
|
||||
s_putstring("\e[1;45;37m Type /Quit to Exit\e[K\e[0m\r\n");
|
||||
if (inputbuffer_at > 0) {
|
||||
s_putstring(sock, inputbuffer);
|
||||
}
|
||||
s_putstring(inputbuffer);
|
||||
}
|
||||
do_update = 0;
|
||||
} else if (do_update == 2) {
|
||||
sprintf(buffer2, "\e[24;1f%s\e[K", inputbuffer);
|
||||
s_putstring(sock, buffer2);
|
||||
s_printf("\e[24;1f%s\e[K", inputbuffer);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
44
doors.c
44
doors.c
@ -22,6 +22,7 @@
|
||||
|
||||
extern struct bbs_config conf;
|
||||
extern int mynode;
|
||||
extern int gSocket;
|
||||
|
||||
int running_door_pid = 0;
|
||||
int running_door = 0;
|
||||
@ -36,7 +37,7 @@ void doorchld_handler(int s)
|
||||
running_door = 0;
|
||||
}
|
||||
|
||||
int write_door32sys(int socket, struct user_record *user) {
|
||||
int write_door32sys(struct user_record *user) {
|
||||
struct stat s;
|
||||
char buffer[256];
|
||||
FILE *fptr;
|
||||
@ -59,7 +60,7 @@ int write_door32sys(int socket, struct user_record *user) {
|
||||
}
|
||||
|
||||
fprintf(fptr, "2\n"); // telnet type
|
||||
fprintf(fptr, "%d\n", socket); // socket
|
||||
fprintf(fptr, "%d\n", gSocket); // socket
|
||||
fprintf(fptr, "38400\n"); // baudrate
|
||||
fprintf(fptr, "Magicka %d.%d\n", VERSION_MAJOR, VERSION_MINOR);
|
||||
fprintf(fptr, "%d\n", user->id);
|
||||
@ -126,14 +127,13 @@ int write_door32sys(int socket, struct user_record *user) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
void rundoor(int socket, struct user_record *user, char *cmd, int stdio) {
|
||||
void rundoor(struct user_record *user, char *cmd, int stdio) {
|
||||
char buffer[256];
|
||||
int pid;
|
||||
char *arguments[4];
|
||||
int ret;
|
||||
char c;
|
||||
int len;
|
||||
int status;
|
||||
int master;
|
||||
int slave;
|
||||
fd_set fdset;
|
||||
@ -143,7 +143,7 @@ void rundoor(int socket, struct user_record *user, char *cmd, int stdio) {
|
||||
|
||||
timeoutpaused = 1;
|
||||
|
||||
if (write_door32sys(socket, user) != 0) {
|
||||
if (write_door32sys(user) != 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
@ -152,7 +152,7 @@ void rundoor(int socket, struct user_record *user, char *cmd, int stdio) {
|
||||
arguments[0] = strdup(cmd);
|
||||
sprintf(buffer, "%d", mynode);
|
||||
arguments[1] = strdup(buffer);
|
||||
sprintf(buffer, "%d", socket);
|
||||
sprintf(buffer, "%d", gSocket);
|
||||
arguments[2] = strdup(buffer);
|
||||
arguments[3] = NULL;
|
||||
|
||||
@ -192,19 +192,19 @@ void rundoor(int socket, struct user_record *user, char *cmd, int stdio) {
|
||||
while(running_door != 0) {
|
||||
FD_ZERO(&fdset);
|
||||
FD_SET(master, &fdset);
|
||||
FD_SET(socket, &fdset);
|
||||
if (master > socket) {
|
||||
FD_SET(gSocket, &fdset);
|
||||
if (master > gSocket) {
|
||||
t = master + 1;
|
||||
} else {
|
||||
t = socket + 1;
|
||||
t = gSocket + 1;
|
||||
}
|
||||
ret = select(t, &fdset, NULL, NULL, NULL);
|
||||
if (ret > 0) {
|
||||
if (FD_ISSET(socket, &fdset)) {
|
||||
len = read(socket, &c, 1);
|
||||
if (FD_ISSET(gSocket, &fdset)) {
|
||||
len = read(gSocket, &c, 1);
|
||||
if (len == 0) {
|
||||
close(master);
|
||||
disconnect(socket, "Socket Closed");
|
||||
disconnect("Socket Closed");
|
||||
return;
|
||||
}
|
||||
if (c == '\n' || c == '\0') {
|
||||
@ -217,7 +217,7 @@ void rundoor(int socket, struct user_record *user, char *cmd, int stdio) {
|
||||
close(master);
|
||||
break;
|
||||
}
|
||||
write(socket, &c, 1);
|
||||
write(gSocket, &c, 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -227,16 +227,15 @@ void rundoor(int socket, struct user_record *user, char *cmd, int stdio) {
|
||||
free(arguments[1]);
|
||||
free(arguments[2]);
|
||||
} else {
|
||||
sprintf(buffer, "%s %d %d", cmd, mynode, socket);
|
||||
sprintf(buffer, "%s %d %d", cmd, mynode, gSocket);
|
||||
system(buffer);
|
||||
}
|
||||
timeoutpaused = 0;
|
||||
}
|
||||
|
||||
int door_menu(int socket, struct user_record *user) {
|
||||
int door_menu(struct user_record *user) {
|
||||
int doquit = 0;
|
||||
int dodoors = 0;
|
||||
char prompt[128];
|
||||
char buffer[256];
|
||||
int i;
|
||||
char c;
|
||||
@ -268,12 +267,11 @@ int door_menu(int socket, struct user_record *user) {
|
||||
|
||||
while (!dodoors) {
|
||||
if (do_internal_menu == 1) {
|
||||
s_displayansi(socket, "doors");
|
||||
s_displayansi("doors");
|
||||
|
||||
sprintf(prompt, "\e[0m\r\nTL: %dm :> ", user->timeleft);
|
||||
s_putstring(socket, prompt);
|
||||
s_printf("\e[0m\r\nTL: %dm :> ", user->timeleft);
|
||||
|
||||
c = s_getc(socket);
|
||||
c = s_getc();
|
||||
} else {
|
||||
lua_getglobal(L, "menu");
|
||||
result = lua_pcall(L, 0, 1, 0);
|
||||
@ -293,8 +291,8 @@ int door_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case 'g':
|
||||
{
|
||||
s_putstring(socket, "\r\nAre you sure you want to log off? (Y/N)");
|
||||
c = s_getc(socket);
|
||||
s_printf("\r\nAre you sure you want to log off? (Y/N)");
|
||||
c = s_getc();
|
||||
if (tolower(c) == 'y') {
|
||||
doquit = 1;
|
||||
dodoors = 1;
|
||||
@ -306,7 +304,7 @@ int door_menu(int socket, struct user_record *user) {
|
||||
for (i=0;i<conf.door_count;i++) {
|
||||
if (tolower(c) == tolower(conf.doors[i]->key)) {
|
||||
dolog("%s is launched door %s, on node %d", user->loginname, conf.doors[i]->name, mynode);
|
||||
rundoor(socket, user, conf.doors[i]->command, conf.doors[i]->stdio);
|
||||
rundoor(user, conf.doors[i]->command, conf.doors[i]->stdio);
|
||||
dolog("%s is returned from door %s, on node %d", user->loginname, conf.doors[i]->name, mynode);
|
||||
break;
|
||||
}
|
||||
|
133
email.c
133
email.c
@ -8,7 +8,7 @@
|
||||
|
||||
extern struct bbs_config conf;
|
||||
|
||||
void send_email(int socket, struct user_record *user) {
|
||||
void send_email(struct user_record *user) {
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
@ -27,30 +27,30 @@ void send_email(int socket, struct user_record *user) {
|
||||
char *isql = "INSERT INTO email (sender, recipient, subject, body, date, seen) VALUES(?, ?, ?, ?, ?, 0)";
|
||||
char *err_msg = 0;
|
||||
|
||||
s_putstring(socket, "\r\nTO: ");
|
||||
s_readstring(socket, buffer, 16);
|
||||
s_printf("\r\nTO: ");
|
||||
s_readstring(buffer, 16);
|
||||
|
||||
if (strlen(buffer) == 0) {
|
||||
s_putstring(socket, "\r\nAborted\r\n");
|
||||
s_printf("\r\nAborted\r\n");
|
||||
return;
|
||||
}
|
||||
if (check_user(buffer)) {
|
||||
s_putstring(socket, "\r\n\r\nInvalid Username\r\n");
|
||||
s_printf("\r\n\r\nInvalid Username\r\n");
|
||||
return;
|
||||
}
|
||||
|
||||
recipient = strdup(buffer);
|
||||
s_putstring(socket, "\r\nSUBJECT: ");
|
||||
s_readstring(socket, buffer, 25);
|
||||
s_printf("\r\nSUBJECT: ");
|
||||
s_readstring(buffer, 25);
|
||||
if (strlen(buffer) == 0) {
|
||||
free(recipient);
|
||||
s_putstring(socket, "\r\nAborted\r\n");
|
||||
s_printf("\r\nAborted\r\n");
|
||||
return;
|
||||
}
|
||||
subject = strdup(buffer);
|
||||
|
||||
// post a message
|
||||
msg = external_editor(socket, user, user->loginname, recipient, NULL, NULL, subject, 1);
|
||||
msg = external_editor(user, user->loginname, recipient, NULL, NULL, subject, 1);
|
||||
|
||||
if (msg != NULL) {
|
||||
sprintf(buffer, "%s/email.sq3", conf.bbs_path);
|
||||
@ -87,7 +87,7 @@ void send_email(int socket, struct user_record *user) {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nNo such email\r\n");
|
||||
s_printf("\r\nNo such email\r\n");
|
||||
return;
|
||||
}
|
||||
sqlite3_step(res);
|
||||
@ -100,7 +100,7 @@ void send_email(int socket, struct user_record *user) {
|
||||
free(recipient);
|
||||
}
|
||||
|
||||
void show_email(int socket, struct user_record *user, int msgno) {
|
||||
void show_email(struct user_record *user, int msgno) {
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
@ -125,23 +125,23 @@ void show_email(int socket, struct user_record *user, int msgno) {
|
||||
|
||||
rc = sqlite3_open(buffer, &db);
|
||||
if (rc != SQLITE_OK) {
|
||||
dolog("Cannot open database: %s", sqlite3_errmsg(db));
|
||||
sqlite3_close(db);
|
||||
dolog("Cannot open database: %s", sqlite3_errmsg(db));
|
||||
sqlite3_close(db);
|
||||
|
||||
exit(1);
|
||||
}
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
exit(1);
|
||||
}
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
|
||||
if (rc == SQLITE_OK) {
|
||||
sqlite3_bind_text(res, 1, user->loginname, -1, 0);
|
||||
sqlite3_bind_int(res, 2, msgno);
|
||||
} else {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
if (rc == SQLITE_OK) {
|
||||
sqlite3_bind_text(res, 1, user->loginname, -1, 0);
|
||||
sqlite3_bind_int(res, 2, msgno);
|
||||
} else {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nNo such email\r\n");
|
||||
s_printf("\r\nNo such email\r\n");
|
||||
return;
|
||||
}
|
||||
}
|
||||
if (sqlite3_step(res) == SQLITE_ROW) {
|
||||
id = sqlite3_column_int(res, 0);
|
||||
sender = strdup((char *)sqlite3_column_text(res, 1));
|
||||
@ -150,16 +150,14 @@ void show_email(int socket, struct user_record *user, int msgno) {
|
||||
date = (time_t)sqlite3_column_int(res, 4);
|
||||
|
||||
|
||||
sprintf(buffer, "\e[2J\e[1;32mFrom : \e[1;37m%s\r\n", sender);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mSubject : \e[1;37m%s\r\n", subject);
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\e[2J\e[1;32mFrom : \e[1;37m%s\r\n", sender);
|
||||
s_printf("\e[1;32mSubject : \e[1;37m%s\r\n", subject);
|
||||
localtime_r(&date, &msg_date);
|
||||
sprintf(buffer, "\e[1;32mDate : \e[1;37m%s", asctime(&msg_date));
|
||||
buffer[strlen(buffer) - 1] = '\0';
|
||||
strcat(buffer, "\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf(buffer);
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
|
||||
lines = 0;
|
||||
chars = 0;
|
||||
@ -167,16 +165,16 @@ void show_email(int socket, struct user_record *user, int msgno) {
|
||||
for (z=0;z<strlen(body);z++) {
|
||||
if (body[z] == '\r' || chars == 79) {
|
||||
chars = 0;
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
lines++;
|
||||
if (lines == 19) {
|
||||
s_putstring(socket, "\e[1;37mPress a key to continue...\e[0m");
|
||||
s_getc(socket);
|
||||
s_printf("\e[1;37mPress a key to continue...\e[0m");
|
||||
s_getc();
|
||||
lines = 0;
|
||||
s_putstring(socket, "\e[5;1H\e[0J");
|
||||
s_printf("\e[5;1H\e[0J");
|
||||
}
|
||||
} else {
|
||||
s_putchar(socket, body[z]);
|
||||
s_putchar(body[z]);
|
||||
chars++;
|
||||
}
|
||||
}
|
||||
@ -195,8 +193,8 @@ void show_email(int socket, struct user_record *user, int msgno) {
|
||||
}
|
||||
sqlite3_step(res);
|
||||
|
||||
s_putstring(socket, "\e[1;37mPress \e[1;36mR\e[1;37m to reply, \e[1;36mD\e[1;37m to delete \e[1;36mEnter\e[1;37m to quit...\e[0m\r\n");
|
||||
c = s_getc(socket);
|
||||
s_printf("\e[1;37mPress \e[1;36mR\e[1;37m to reply, \e[1;36mD\e[1;37m to delete \e[1;36mEnter\e[1;37m to quit...\e[0m\r\n");
|
||||
c = s_getc();
|
||||
if (tolower(c) == 'r') {
|
||||
if (subject != NULL) {
|
||||
if (strncasecmp(buffer, "RE:", 3) != 0) {
|
||||
@ -209,8 +207,7 @@ void show_email(int socket, struct user_record *user, int msgno) {
|
||||
subject = (char *)malloc(strlen(buffer) + 1);
|
||||
strcpy(subject, buffer);
|
||||
|
||||
//replybody = editor(socket, user, body, sender);
|
||||
replybody = external_editor(socket, user, user->loginname, sender, body, sender, subject, 1);
|
||||
replybody = external_editor(user, user->loginname, sender, body, sender, subject, 1);
|
||||
if (replybody != NULL) {
|
||||
rc = sqlite3_prepare_v2(db, isql, -1, &res, 0);
|
||||
|
||||
@ -224,7 +221,7 @@ void show_email(int socket, struct user_record *user, int msgno) {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nNo such email\r\n");
|
||||
s_printf("\r\nNo such email\r\n");
|
||||
return;
|
||||
}
|
||||
sqlite3_step(res);
|
||||
@ -249,7 +246,7 @@ void show_email(int socket, struct user_record *user, int msgno) {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nNo such email\r\n");
|
||||
s_printf("\r\nNo such email\r\n");
|
||||
return;
|
||||
}
|
||||
sqlite3_step(res);
|
||||
@ -265,7 +262,7 @@ void show_email(int socket, struct user_record *user, int msgno) {
|
||||
}
|
||||
}
|
||||
|
||||
void list_emails(int socket, struct user_record *user) {
|
||||
void list_emails(struct user_record *user) {
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
@ -273,8 +270,6 @@ void list_emails(int socket, struct user_record *user) {
|
||||
char *sql = "SELECT sender,subject,seen,date FROM email WHERE recipient LIKE ?";
|
||||
char *subject;
|
||||
char *from;
|
||||
char *to;
|
||||
char *body;
|
||||
time_t date;
|
||||
int seen;
|
||||
int msgid;
|
||||
@ -298,12 +293,12 @@ void list_emails(int socket, struct user_record *user) {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nYou have no email\r\n");
|
||||
s_printf("\r\nYou have no email\r\n");
|
||||
return;
|
||||
}
|
||||
|
||||
msgid = 0;
|
||||
s_putstring(socket, "\e[2J\e[1;37;44m[MSG#] Subject From Date \r\n\e[0m");
|
||||
s_printf("\e[2J\e[1;37;44m[MSG#] Subject From Date \r\n\e[0m");
|
||||
while (sqlite3_step(res) == SQLITE_ROW) {
|
||||
from = strdup((char *)sqlite3_column_text(res, 0));
|
||||
subject = strdup((char *)sqlite3_column_text(res, 1));
|
||||
@ -311,18 +306,16 @@ void list_emails(int socket, struct user_record *user) {
|
||||
date = (time_t)sqlite3_column_int(res, 3);
|
||||
localtime_r(&date, &msg_date);
|
||||
if (seen == 0) {
|
||||
sprintf(buffer, "\e[1;30m[\e[1;34m%4d\e[1;30m]\e[1;32m*\e[1;37m%-39.39s \e[1;32m%-16.16s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", msgid + 1, subject, from, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100);
|
||||
s_printf("\e[1;30m[\e[1;34m%4d\e[1;30m]\e[1;32m*\e[1;37m%-39.39s \e[1;32m%-16.16s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", msgid + 1, subject, from, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100);
|
||||
} else {
|
||||
sprintf(buffer, "\e[1;30m[\e[1;34m%4d\e[1;30m] \e[1;37m%-39.39s \e[1;32m%-16.16s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", msgid + 1, subject, from, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100);
|
||||
s_printf("\e[1;30m[\e[1;34m%4d\e[1;30m] \e[1;37m%-39.39s \e[1;32m%-16.16s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", msgid + 1, subject, from, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100);
|
||||
}
|
||||
s_putstring(socket, buffer);
|
||||
|
||||
free(from);
|
||||
free(subject);
|
||||
|
||||
if (msgid % 22 == 0 && msgid != 0) {
|
||||
s_putstring(socket, "\e[1;37mEnter \e[1;36m# \e[1;37mto read, \e[1;36mQ \e[1;37mto quit or \e[1;36mEnter\e[1;37m to continue\e[0m\r\n");
|
||||
s_readstring(socket, buffer, 5);
|
||||
s_printf("\e[1;37mEnter \e[1;36m# \e[1;37mto read, \e[1;36mQ \e[1;37mto quit or \e[1;36mEnter\e[1;37m to continue\e[0m\r\n");
|
||||
s_readstring(buffer, 5);
|
||||
if (strlen(buffer) > 0) {
|
||||
if (tolower(buffer[0]) == 'q') {
|
||||
sqlite3_finalize(res);
|
||||
@ -332,24 +325,24 @@ void list_emails(int socket, struct user_record *user) {
|
||||
msgtoread = atoi(buffer) - 1;
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
show_email(socket, user, msgtoread);
|
||||
show_email(user, msgtoread);
|
||||
return;
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "\e[2J\e[1;37;44m[MSG#] Subject From Date \r\n\e[0m");
|
||||
s_printf("\e[2J\e[1;37;44m[MSG#] Subject From Date \r\n\e[0m");
|
||||
}
|
||||
msgid++;
|
||||
}
|
||||
if (msgid == 0) {
|
||||
s_putstring(socket, "\r\nYou have no email\r\n");
|
||||
s_printf( "\r\nYou have no email\r\n");
|
||||
} else {
|
||||
s_putstring(socket, "\e[1;37mEnter \e[1;36m# \e[1;37mto read, or \e[1;36mEnter\e[1;37m to quit\e[0m\r\n");
|
||||
s_readstring(socket, buffer, 5);
|
||||
s_printf("\e[1;37mEnter \e[1;36m# \e[1;37mto read, or \e[1;36mEnter\e[1;37m to quit\e[0m\r\n");
|
||||
s_readstring(buffer, 5);
|
||||
if (strlen(buffer) > 0) {
|
||||
msgtoread = atoi(buffer) - 1;
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
show_email(socket, user, msgtoread);
|
||||
show_email(user, msgtoread);
|
||||
return;
|
||||
}
|
||||
}
|
||||
@ -363,32 +356,32 @@ int mail_getemailcount(struct user_record *user) {
|
||||
int count;
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
|
||||
sprintf(buffer, "%s/email.sq3", conf.bbs_path);
|
||||
|
||||
rc = sqlite3_open(buffer, &db);
|
||||
if (rc != SQLITE_OK) {
|
||||
dolog("Cannot open database: %s", sqlite3_errmsg(db));
|
||||
sqlite3_close(db);
|
||||
dolog("Cannot open database: %s", sqlite3_errmsg(db));
|
||||
sqlite3_close(db);
|
||||
|
||||
exit(1);
|
||||
}
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
exit(1);
|
||||
}
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
|
||||
if (rc == SQLITE_OK) {
|
||||
sqlite3_bind_text(res, 1, user->loginname, -1, 0);
|
||||
} else {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
if (rc == SQLITE_OK) {
|
||||
sqlite3_bind_text(res, 1, user->loginname, -1, 0);
|
||||
} else {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
count = 0;
|
||||
|
||||
if (sqlite3_step(res) == SQLITE_ROW) {
|
||||
if (sqlite3_step(res) == SQLITE_ROW) {
|
||||
count = sqlite3_column_int(res, 0);
|
||||
}
|
||||
|
||||
|
158
files.c
158
files.c
@ -13,8 +13,7 @@
|
||||
#include "lua/lualib.h"
|
||||
#include "lua/lauxlib.h"
|
||||
extern struct bbs_config conf;
|
||||
|
||||
static int doCancel = 0;
|
||||
extern int gSocket;
|
||||
|
||||
struct file_entry {
|
||||
char *filename;
|
||||
@ -127,7 +126,7 @@ int doIO(ZModem *zm) {
|
||||
} else if (i > 0) {
|
||||
len = read(zm->ifd, buffer, 2048);
|
||||
if (len == 0) {
|
||||
disconnect(zm->ifd, "Socket closed");
|
||||
disconnect("Socket closed");
|
||||
}
|
||||
|
||||
pos = 0;
|
||||
@ -159,9 +158,8 @@ int doIO(ZModem *zm) {
|
||||
return done;
|
||||
}
|
||||
|
||||
void upload_zmodem(int socket, struct user_record *user) {
|
||||
void upload_zmodem(struct user_record *user) {
|
||||
ZModem zm;
|
||||
int done;
|
||||
|
||||
|
||||
upload_path = conf.file_directories[user->cur_file_dir]->file_subs[user->cur_file_sub]->upload_path;
|
||||
@ -170,20 +168,20 @@ void upload_zmodem(int socket, struct user_record *user) {
|
||||
zm.windowsize = 0;
|
||||
zm.bufsize = 0;
|
||||
|
||||
zm.ifd = socket;
|
||||
zm.ofd = socket;
|
||||
zm.ifd = gSocket;
|
||||
zm.ofd = gSocket;
|
||||
|
||||
zm.zrinitflags = 0;
|
||||
zm.zsinitflags = 0;
|
||||
|
||||
zm.packetsize = 1024;
|
||||
|
||||
done = ZmodemRInit(&zm);
|
||||
ZmodemRInit(&zm);
|
||||
|
||||
doIO(&zm);
|
||||
}
|
||||
|
||||
void upload(int socket, struct user_record *user) {
|
||||
void upload(struct user_record *user) {
|
||||
char buffer[331];
|
||||
char buffer2[66];
|
||||
char buffer3[256];
|
||||
@ -197,19 +195,18 @@ void upload(int socket, struct user_record *user) {
|
||||
"approved INTEGER);";
|
||||
char *sql = "INSERT INTO files (filename, description, size, dlcount, approved) VALUES(?, ?, ?, 0, 0)";
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
struct stat s;
|
||||
char *err_msg = NULL;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
struct stat s;
|
||||
char *err_msg = NULL;
|
||||
|
||||
upload_zmodem(socket, user);
|
||||
upload_zmodem(user);
|
||||
|
||||
s_putstring(socket, "\r\nPlease enter a description:\r\n");
|
||||
s_printf("\r\nPlease enter a description:\r\n");
|
||||
buffer[0] = '\0';
|
||||
for (i=0;i<5;i++) {
|
||||
sprintf(buffer2, "\r\n%d: ", i);
|
||||
s_putstring(socket, buffer2);
|
||||
s_readstring(socket, buffer2, 65);
|
||||
s_printf("\r\n%d: ", i);
|
||||
s_readstring(buffer2, 65);
|
||||
if (strlen(buffer2) == 0) {
|
||||
break;
|
||||
}
|
||||
@ -261,18 +258,9 @@ void upload(int socket, struct user_record *user) {
|
||||
sqlite3_close(db);
|
||||
}
|
||||
|
||||
void download_zmodem(int socket, struct user_record *user, char *filename) {
|
||||
void download_zmodem(struct user_record *user, char *filename) {
|
||||
ZModem zm;
|
||||
int done ;
|
||||
fd_set readfds;
|
||||
struct timeval timeout;
|
||||
int i;
|
||||
int j;
|
||||
int len;
|
||||
int pos;
|
||||
|
||||
u_char buffer[2048];
|
||||
u_char buffer2[1024];
|
||||
|
||||
dolog("Attempting to upload %s", filename);
|
||||
|
||||
@ -280,8 +268,8 @@ void download_zmodem(int socket, struct user_record *user, char *filename) {
|
||||
zm.windowsize = 0;
|
||||
zm.bufsize = 0;
|
||||
|
||||
zm.ifd = socket;
|
||||
zm.ofd = socket;
|
||||
zm.ifd = gSocket;
|
||||
zm.ofd = gSocket;
|
||||
|
||||
zm.zrinitflags = 0;
|
||||
zm.zsinitflags = 0;
|
||||
@ -331,19 +319,18 @@ void download_zmodem(int socket, struct user_record *user, char *filename) {
|
||||
}
|
||||
}
|
||||
|
||||
void download(int socket, struct user_record *user) {
|
||||
void download(struct user_record *user) {
|
||||
int i;
|
||||
char *ssql = "select dlcount from files where filename like ?";
|
||||
char *usql = "update files set dlcount=? where filename like ?";
|
||||
char buffer[256];
|
||||
int dloads;
|
||||
char *err_msg = NULL;
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
|
||||
for (i=0;i<tagged_count;i++) {
|
||||
download_zmodem(socket, user, tagged_files[i]);
|
||||
download_zmodem(user, tagged_files[i]);
|
||||
|
||||
sprintf(buffer, "%s/%s.sq3", conf.bbs_path, conf.file_directories[user->cur_file_dir]->file_subs[user->cur_file_sub]->database);
|
||||
|
||||
@ -397,7 +384,7 @@ void download(int socket, struct user_record *user) {
|
||||
tagged_count = 0;
|
||||
}
|
||||
|
||||
void list_files(int socket, struct user_record *user) {
|
||||
void list_files(struct user_record *user) {
|
||||
char *sql = "select filename, description, size, dlcount from files where approved=1";
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
@ -407,7 +394,6 @@ void list_files(int socket, struct user_record *user) {
|
||||
int file_size;
|
||||
char file_unit;
|
||||
int lines = 0;
|
||||
char desc;
|
||||
int i;
|
||||
int j;
|
||||
int z;
|
||||
@ -430,7 +416,7 @@ void list_files(int socket, struct user_record *user) {
|
||||
if (rc != SQLITE_OK) {
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_putstring(socket, "\r\nNo files in this area!\r\n");
|
||||
s_printf("\r\nNo files in this area!\r\n");
|
||||
return;
|
||||
}
|
||||
|
||||
@ -455,10 +441,10 @@ void list_files(int socket, struct user_record *user) {
|
||||
sqlite3_close(db);
|
||||
|
||||
if (files_c == 0) {
|
||||
s_putstring(socket, "\r\nNo files in this area!\r\n");
|
||||
s_printf("\r\nNo files in this area!\r\n");
|
||||
return;
|
||||
}
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
for (i=0;i<files_c;i++) {
|
||||
file_size = files_e[i]->size;
|
||||
if (file_size > 1024 * 1024 * 1024) {
|
||||
@ -473,20 +459,19 @@ void list_files(int socket, struct user_record *user) {
|
||||
} else {
|
||||
file_unit = 'b';
|
||||
}
|
||||
sprintf(buffer, "\r\n\r\n\e[1;30m[\e[1;34m%3d\e[1;30m] \e[1;33m%3ddloads \e[1;36m%4d%c \e[1;37m%-56s\r\n \e[0;32m", i, files_e[i]->dlcount, file_size, file_unit, basename(files_e[i]->filename));
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\n\r\n\e[1;30m[\e[1;34m%3d\e[1;30m] \e[1;33m%3ddloads \e[1;36m%4d%c \e[1;37m%-56s\r\n \e[0;32m", i, files_e[i]->dlcount, file_size, file_unit, basename(files_e[i]->filename));
|
||||
lines+=3;
|
||||
for (j=0;j<strlen(files_e[i]->description);j++) {
|
||||
if (files_e[i]->description[j] == '\n') {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
lines++;
|
||||
if (lines >= 18) {
|
||||
lines = 0;
|
||||
while (1) {
|
||||
s_putstring(socket, "\r\n\e[0mEnter # to tag, Q to quit, Enter to continue: ");
|
||||
s_readstring(socket, buffer, 5);
|
||||
s_printf("\r\n\e[0mEnter # to tag, Q to quit, Enter to continue: ");
|
||||
s_readstring(buffer, 5);
|
||||
if (strlen(buffer) == 0) {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
break;
|
||||
} else if (tolower(buffer[0]) == 'q') {
|
||||
for (z=0;z<files_c;z++) {
|
||||
@ -495,7 +480,7 @@ void list_files(int socket, struct user_record *user) {
|
||||
free(files_e[z]);
|
||||
}
|
||||
free(files_e);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
return;
|
||||
} else {
|
||||
z = atoi(buffer);
|
||||
@ -516,28 +501,27 @@ void list_files(int socket, struct user_record *user) {
|
||||
}
|
||||
tagged_files[tagged_count] = strdup(files_e[z]->filename);
|
||||
tagged_count++;
|
||||
sprintf(buffer, "\r\nTagged %s\r\n", basename(files_e[z]->filename));
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\nTagged %s\r\n", basename(files_e[z]->filename));
|
||||
} else {
|
||||
s_putstring(socket, "\r\nAlready Tagged\r\n");
|
||||
s_printf("\r\nAlready Tagged\r\n");
|
||||
}
|
||||
} else {
|
||||
s_putstring(socket, "\r\nSorry, you don't have permission to download from this area\r\n");
|
||||
s_printf("\r\nSorry, you don't have permission to download from this area\r\n");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
s_putstring(socket, " \e[0;32m");
|
||||
s_printf(" \e[0;32m");
|
||||
}
|
||||
} else {
|
||||
s_putchar(socket, files_e[i]->description[j]);
|
||||
s_putchar(files_e[i]->description[j]);
|
||||
}
|
||||
}
|
||||
}
|
||||
while (1) {
|
||||
s_putstring(socket, "\r\n\e[0mEnter # to tag, Enter to quit: ");
|
||||
s_readstring(socket, buffer, 5);
|
||||
s_printf("\r\n\e[0mEnter # to tag, Enter to quit: ");
|
||||
s_readstring(buffer, 5);
|
||||
if (strlen(buffer) == 0) {
|
||||
for (z=0;z<files_c;z++) {
|
||||
free(files_e[z]->filename);
|
||||
@ -545,7 +529,7 @@ void list_files(int socket, struct user_record *user) {
|
||||
free(files_e[z]);
|
||||
}
|
||||
free(files_e);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
return;
|
||||
} else {
|
||||
z = atoi(buffer);
|
||||
@ -566,20 +550,19 @@ void list_files(int socket, struct user_record *user) {
|
||||
}
|
||||
tagged_files[tagged_count] = strdup(files_e[z]->filename);
|
||||
tagged_count++;
|
||||
sprintf(buffer, "\r\nTagged %s\r\n", basename(files_e[z]->filename));
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\nTagged %s\r\n", basename(files_e[z]->filename));
|
||||
} else {
|
||||
s_putstring(socket, "\r\nAlready Tagged\r\n");
|
||||
s_printf("\r\nAlready Tagged\r\n");
|
||||
}
|
||||
} else {
|
||||
s_putstring(socket, "\r\nSorry, you don't have permission to download from this area\r\n");
|
||||
s_printf("\r\nSorry, you don't have permission to download from this area\r\n");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int file_menu(int socket, struct user_record *user) {
|
||||
int file_menu(struct user_record *user) {
|
||||
int doquit = 0;
|
||||
int dofiles = 0;
|
||||
char c;
|
||||
@ -614,12 +597,11 @@ int file_menu(int socket, struct user_record *user) {
|
||||
|
||||
while (!dofiles) {
|
||||
if (do_internal_menu == 1) {
|
||||
s_displayansi(socket, "filemenu");
|
||||
s_displayansi("filemenu");
|
||||
|
||||
sprintf(prompt, "\e[0m\r\nDir: (%d) %s\r\nSub: (%d) %s\r\nTL: %dm :> ", user->cur_file_dir, conf.file_directories[user->cur_file_dir]->name, user->cur_file_sub, conf.file_directories[user->cur_file_dir]->file_subs[user->cur_file_sub]->name, user->timeleft);
|
||||
s_putstring(socket, prompt);
|
||||
s_printf("\e[0m\r\nDir: (%d) %s\r\nSub: (%d) %s\r\nTL: %dm :> ", user->cur_file_dir, conf.file_directories[user->cur_file_dir]->name, user->cur_file_sub, conf.file_directories[user->cur_file_dir]->file_subs[user->cur_file_sub]->name, user->timeleft);
|
||||
|
||||
c = s_getc(socket);
|
||||
c = s_getc();
|
||||
} else {
|
||||
lua_getglobal(L, "menu");
|
||||
result = lua_pcall(L, 0, 1, 0);
|
||||
@ -636,25 +618,24 @@ int file_menu(int socket, struct user_record *user) {
|
||||
switch(tolower(c)) {
|
||||
case 'i':
|
||||
{
|
||||
s_putstring(socket, "\r\n\r\nFile Directories:\r\n\r\n");
|
||||
s_printf("\r\n\r\nFile Directories:\r\n\r\n");
|
||||
for (i=0;i<conf.file_directory_count;i++) {
|
||||
if (conf.file_directories[i]->sec_level <= user->sec_level) {
|
||||
sprintf(prompt, " %d. %s\r\n", i, conf.file_directories[i]->name);
|
||||
s_putstring(socket, prompt);
|
||||
s_printf(" %d. %s\r\n", i, conf.file_directories[i]->name);
|
||||
}
|
||||
if (i != 0 && i % 20 == 0) {
|
||||
s_putstring(socket, "Press any key to continue...\r\n");
|
||||
c = s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
c = s_getc();
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "Enter the directory number: ");
|
||||
s_readstring(socket, prompt, 5);
|
||||
s_printf("Enter the directory number: ");
|
||||
s_readstring(prompt, 5);
|
||||
if (tolower(prompt[0]) != 'q') {
|
||||
j = atoi(prompt);
|
||||
if (j < 0 || j >= conf.file_directory_count || conf.file_directories[j]->sec_level > user->sec_level) {
|
||||
s_putstring(socket, "\r\nInvalid directory number!\r\n");
|
||||
s_printf("\r\nInvalid directory number!\r\n");
|
||||
} else {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
user->cur_file_dir = j;
|
||||
user->cur_file_sub = 0;
|
||||
}
|
||||
@ -663,43 +644,42 @@ int file_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case 's':
|
||||
{
|
||||
s_putstring(socket, "\r\n\r\nFile Subdirectories:\r\n\r\n");
|
||||
s_printf("\r\n\r\nFile Subdirectories:\r\n\r\n");
|
||||
for (i=0;i<conf.file_directories[user->cur_file_dir]->file_sub_count;i++) {
|
||||
sprintf(prompt, " %d. %s\r\n", i, conf.file_directories[user->cur_file_dir]->file_subs[i]->name);
|
||||
s_putstring(socket, prompt);
|
||||
s_printf(" %d. %s\r\n", i, conf.file_directories[user->cur_file_dir]->file_subs[i]->name);
|
||||
|
||||
if (i != 0 && i % 20 == 0) {
|
||||
s_putstring(socket, "Press any key to continue...\r\n");
|
||||
c = s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
c = s_getc();
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "Enter the sub directory number: ");
|
||||
s_readstring(socket, prompt, 5);
|
||||
s_printf("Enter the sub directory number: ");
|
||||
s_readstring(prompt, 5);
|
||||
if (tolower(prompt[0]) != 'q') {
|
||||
j = atoi(prompt);
|
||||
if (j < 0 || j >= conf.file_directories[user->cur_file_dir]->file_sub_count) {
|
||||
s_putstring(socket, "\r\nInvalid sub directiry number!\r\n");
|
||||
s_printf("\r\nInvalid sub directiry number!\r\n");
|
||||
} else {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
user->cur_file_sub = j;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
case 'l':
|
||||
list_files(socket, user);
|
||||
list_files(user);
|
||||
break;
|
||||
case 'u':
|
||||
{
|
||||
if (user->sec_level >= conf.file_directories[user->cur_file_dir]->file_subs[user->cur_file_sub]->upload_sec_level) {
|
||||
upload(socket, user);
|
||||
upload(user);
|
||||
} else {
|
||||
s_putstring(socket, "Sorry, you don't have permission to upload in this Sub\r\n");
|
||||
s_printf("Sorry, you don't have permission to upload in this Sub\r\n");
|
||||
}
|
||||
}
|
||||
break;
|
||||
case 'd':
|
||||
download(socket, user);
|
||||
download(user);
|
||||
break;
|
||||
case 'c':
|
||||
{
|
||||
@ -764,8 +744,8 @@ int file_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case 'g':
|
||||
{
|
||||
s_putstring(socket, "\r\nAre you sure you want to log off? (Y/N)");
|
||||
c = s_getc(socket);
|
||||
s_printf("\r\nAre you sure you want to log off? (Y/N)");
|
||||
c = s_getc();
|
||||
if (tolower(c) == 'y') {
|
||||
dofiles = 1;
|
||||
doquit = 1;
|
||||
|
14
lua_glue.c
14
lua_glue.c
@ -12,7 +12,7 @@ extern int gSocket;
|
||||
int l_bbsWString(lua_State *L) {
|
||||
char *str = (char *)lua_tostring(L, -1);
|
||||
|
||||
s_putstring(gSocket, str);
|
||||
s_printf("%s", str);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -25,7 +25,7 @@ int l_bbsRString(lua_State *L) {
|
||||
len = 256;
|
||||
}
|
||||
|
||||
s_readstring(gSocket, buffer, len);
|
||||
s_readstring(buffer, len);
|
||||
|
||||
lua_pushstring(L, buffer);
|
||||
|
||||
@ -35,7 +35,7 @@ int l_bbsRString(lua_State *L) {
|
||||
int l_bbsRChar(lua_State *L) {
|
||||
char c;
|
||||
|
||||
c = s_getc(gSocket);
|
||||
c = s_getc();
|
||||
|
||||
lua_pushlstring(L, &c, 1);
|
||||
|
||||
@ -45,7 +45,7 @@ int l_bbsRChar(lua_State *L) {
|
||||
int l_bbsDisplayAnsi(lua_State *L) {
|
||||
char *str = (char *)lua_tostring(L, -1);
|
||||
|
||||
s_displayansi(gSocket, str);
|
||||
s_displayansi(str);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -94,7 +94,7 @@ int l_bbsGetEmailCount(lua_State *L) {
|
||||
}
|
||||
|
||||
int l_bbsMailScan(lua_State *L) {
|
||||
mail_scan(gSocket, gUser);
|
||||
mail_scan(gUser);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -102,7 +102,7 @@ int l_bbsRunDoor(lua_State *L) {
|
||||
char *cmd = (char *)lua_tostring(L, 1);
|
||||
int stdio = lua_toboolean(L, 2);
|
||||
|
||||
rundoor(gSocket, gUser, cmd, stdio);
|
||||
rundoor(gUser, cmd, stdio);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -114,7 +114,7 @@ int l_bbsTimeLeft(lua_State *L) {
|
||||
}
|
||||
|
||||
int l_bbsDisplayAutoMsg(lua_State *L) {
|
||||
automessage_display(gSocket);
|
||||
automessage_display();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
399
mail_menu.c
399
mail_menu.c
@ -261,13 +261,12 @@ struct msg_headers *read_message_headers(int msgconf, int msgarea, struct user_r
|
||||
return msghs;
|
||||
}
|
||||
|
||||
char *external_editor(int socket, struct user_record *user, char *to, char *from, char *quote, char *qfrom, char *subject, int email) {
|
||||
char *external_editor(struct user_record *user, char *to, char *from, char *quote, char *qfrom, char *subject, int email) {
|
||||
char c;
|
||||
FILE *fptr;
|
||||
char *body = NULL;
|
||||
char buffer[256];
|
||||
char buffer2[256];
|
||||
int len;
|
||||
int len;
|
||||
int totlen;
|
||||
char *body2 = NULL;
|
||||
char *tagline;
|
||||
@ -279,8 +278,8 @@ char *external_editor(int socket, struct user_record *user, char *to, char *from
|
||||
|
||||
|
||||
if (conf.external_editor_cmd != NULL) {
|
||||
s_putstring(socket, "\r\nUse external editor? (Y/N) ");
|
||||
c = s_getc(socket);
|
||||
s_printf("\r\nUse external editor? (Y/N) ");
|
||||
c = s_getc();
|
||||
if (tolower(c) == 'y') {
|
||||
|
||||
sprintf(buffer, "%s/node%d", conf.bbs_path, mynode);
|
||||
@ -335,7 +334,7 @@ char *external_editor(int socket, struct user_record *user, char *to, char *from
|
||||
}
|
||||
fclose(fptr);
|
||||
|
||||
rundoor(socket, user, conf.external_editor_cmd, conf.external_editor_stdio);
|
||||
rundoor(user, conf.external_editor_cmd, conf.external_editor_stdio);
|
||||
|
||||
// readin msgtmp
|
||||
sprintf(buffer, "%s/node%d/MSGTMP", conf.bbs_path, mynode);
|
||||
@ -413,15 +412,14 @@ char *external_editor(int socket, struct user_record *user, char *to, char *from
|
||||
return body2;
|
||||
}
|
||||
}
|
||||
return editor(socket, user, quote, qfrom, email);
|
||||
return editor(user, quote, qfrom, email);
|
||||
}
|
||||
|
||||
char *editor(int socket, struct user_record *user, char *quote, char *from, int email) {
|
||||
char *editor(struct user_record *user, char *quote, char *from, int email) {
|
||||
int lines = 0;
|
||||
char buffer[256];
|
||||
char linebuffer[80];
|
||||
char prompt[12];
|
||||
int doquit = 0;
|
||||
int doquit = 0;
|
||||
char **content = NULL;
|
||||
int i;
|
||||
char *msg;
|
||||
@ -460,14 +458,13 @@ char *editor(int socket, struct user_record *user, char *quote, char *from, int
|
||||
}
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "\r\n\e[1;32mMagicka Internal Editor, Type \e[1;37m/S \e[1;32mto save, \e[1;37m/A \e[1;32mto abort and \e[1;37m/? \e[1;32mfor help\r\n");
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m");
|
||||
s_printf("\r\n\e[1;32mMagicka Internal Editor, Type \e[1;37m/S \e[1;32mto save, \e[1;37m/A \e[1;32mto abort and \e[1;37m/? \e[1;32mfor help\r\n");
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m");
|
||||
|
||||
while(!doquit) {
|
||||
sprintf(prompt, "\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", lines, next_line_buffer);
|
||||
s_putstring(socket, prompt);
|
||||
s_printf("\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", lines, next_line_buffer);
|
||||
strcpy(linebuffer, next_line_buffer);
|
||||
s_readstring(socket, &linebuffer[strlen(next_line_buffer)], 70 - strlen(next_line_buffer));
|
||||
s_readstring(&linebuffer[strlen(next_line_buffer)], 70 - strlen(next_line_buffer));
|
||||
memset(next_line_buffer, 0, 70);
|
||||
|
||||
if (strlen(linebuffer) == 70 && linebuffer[69] != ' ') {
|
||||
@ -475,8 +472,7 @@ char *editor(int socket, struct user_record *user, char *quote, char *from, int
|
||||
if (linebuffer[i] == ' ') {
|
||||
linebuffer[i] = '\0';
|
||||
strcpy(next_line_buffer, &linebuffer[i+1]);
|
||||
sprintf(prompt, "\e[%dD\e[0K", 70 - i);
|
||||
s_putstring(socket, prompt);
|
||||
s_printf("\e[%dD\e[0K", 70 - i);
|
||||
break;
|
||||
}
|
||||
}
|
||||
@ -548,21 +544,20 @@ char *editor(int socket, struct user_record *user, char *quote, char *from, int
|
||||
return NULL;
|
||||
} else if (toupper(linebuffer[1]) == 'Q') {
|
||||
if (quote == NULL) {
|
||||
s_putstring(socket, "\r\nNo message to quote!\r\n");
|
||||
s_printf("\r\nNo message to quote!\r\n");
|
||||
} else {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
for (i=0;i<quotelines;i++) {
|
||||
sprintf(buffer, "\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", i, quotecontent[i]);
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", i, quotecontent[i]);
|
||||
}
|
||||
|
||||
s_putstring(socket, "\r\nQuote from Line: ");
|
||||
s_readstring(socket, buffer, 5);
|
||||
s_printf("\r\nQuote from Line: ");
|
||||
s_readstring(buffer, 5);
|
||||
qfrom = atoi(buffer);
|
||||
s_putstring(socket, "\r\nQuote to Line: ");
|
||||
s_readstring(socket, buffer, 5);
|
||||
s_printf("\r\nQuote to Line: ");
|
||||
s_readstring(buffer, 5);
|
||||
qto = atoi(buffer);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
|
||||
if (qto > quotelines) {
|
||||
qto = quotelines;
|
||||
@ -571,7 +566,7 @@ char *editor(int socket, struct user_record *user, char *quote, char *from, int
|
||||
qfrom = 0;
|
||||
}
|
||||
if (qfrom > qto) {
|
||||
s_putstring(socket, "Quoting Cancelled\r\n");
|
||||
s_printf("Quoting Cancelled\r\n");
|
||||
}
|
||||
|
||||
for (i=qfrom;i<=qto;i++) {
|
||||
@ -585,40 +580,38 @@ char *editor(int socket, struct user_record *user, char *quote, char *from, int
|
||||
lines++;
|
||||
}
|
||||
|
||||
s_putstring(socket, "\r\n\e[1;32mMagicka Internal Editor, Type \e[1;37m/S \e[1;32mto save, \e[1;37m/A \e[1;32mto abort and \e[1;37m/? \e[1;32mfor help\r\n");
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m");
|
||||
s_printf("\r\n\e[1;32mMagicka Internal Editor, Type \e[1;37m/S \e[1;32mto save, \e[1;37m/A \e[1;32mto abort and \e[1;37m/? \e[1;32mfor help\r\n");
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m");
|
||||
|
||||
for (i=0;i<lines;i++) {
|
||||
sprintf(buffer, "\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", i, content[i]);
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", i, content[i]);
|
||||
}
|
||||
}
|
||||
} else if (toupper(linebuffer[1]) == 'L') {
|
||||
s_putstring(socket, "\r\n\e[1;32mMagicka Internal Editor, Type \e[1;37m/S \e[1;32mto save, \e[1;37m/A \e[1;32mto abort and \e[1;37m/? \e[1;32mfor help\r\n");
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m");
|
||||
s_printf("\r\n\e[1;32mMagicka Internal Editor, Type \e[1;37m/S \e[1;32mto save, \e[1;37m/A \e[1;32mto abort and \e[1;37m/? \e[1;32mfor help\r\n");
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m");
|
||||
|
||||
for (i=0;i<lines;i++) {
|
||||
sprintf(buffer, "\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", i, content[i]);
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", i, content[i]);
|
||||
}
|
||||
} else if (linebuffer[1] == '?') {
|
||||
s_putstring(socket, "\e[1;33m\r\nHELP\r\n");
|
||||
s_putstring(socket, "/S - Save Message\r\n");
|
||||
s_putstring(socket, "/A - Abort Message\r\n");
|
||||
s_putstring(socket, "/Q - Quote Message\r\n");
|
||||
s_putstring(socket, "/E - Edit (Rewrite) Line\r\n");
|
||||
s_putstring(socket, "/D - Delete Line\r\n");
|
||||
s_putstring(socket, "/I - Insert Line\r\n");
|
||||
s_putstring(socket, "/L - Relist Message\r\n\e[0m");
|
||||
s_printf("\e[1;33m\r\nHELP\r\n");
|
||||
s_printf("/S - Save Message\r\n");
|
||||
s_printf("/A - Abort Message\r\n");
|
||||
s_printf("/Q - Quote Message\r\n");
|
||||
s_printf("/E - Edit (Rewrite) Line\r\n");
|
||||
s_printf("/D - Delete Line\r\n");
|
||||
s_printf("/I - Insert Line\r\n");
|
||||
s_printf("/L - Relist Message\r\n\e[0m");
|
||||
} else if (toupper(linebuffer[1]) == 'D') {
|
||||
s_putstring(socket, "\r\nWhich line do you want to delete? ");
|
||||
s_readstring(socket, buffer, 6);
|
||||
s_printf("\r\nWhich line do you want to delete? ");
|
||||
s_readstring(buffer, 6);
|
||||
if (strlen(buffer) == 0) {
|
||||
s_putstring(socket, "\r\nAborted...\r\n");
|
||||
s_printf("\r\nAborted...\r\n");
|
||||
} else {
|
||||
z = atoi(buffer);
|
||||
if (z < 0 || z >= lines) {
|
||||
s_putstring(socket, "\r\nAborted...\r\n");
|
||||
s_printf("\r\nAborted...\r\n");
|
||||
} else {
|
||||
for (i=z;i<lines-1;i++) {
|
||||
free(content[i]);
|
||||
@ -630,37 +623,34 @@ char *editor(int socket, struct user_record *user, char *quote, char *from, int
|
||||
}
|
||||
}
|
||||
} else if (toupper(linebuffer[1]) == 'E') {
|
||||
s_putstring(socket, "\r\nWhich line do you want to edit? ");
|
||||
s_readstring(socket, buffer, 6);
|
||||
s_printf("\r\nWhich line do you want to edit? ");
|
||||
s_readstring(buffer, 6);
|
||||
if (strlen(buffer) == 0) {
|
||||
s_putstring(socket, "\r\nAborted...\r\n");
|
||||
s_printf("\r\nAborted...\r\n");
|
||||
} else {
|
||||
z = atoi(buffer);
|
||||
if (z < 0 || z >= lines) {
|
||||
s_putstring(socket, "\r\nAborted...\r\n");
|
||||
s_printf("\r\nAborted...\r\n");
|
||||
} else {
|
||||
sprintf(buffer, "\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", z, content[z]);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m", z);
|
||||
s_putstring(socket, buffer);
|
||||
s_readstring(socket, linebuffer, 70);
|
||||
s_printf("\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m%s", z, content[z]);
|
||||
s_printf("\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m", z);
|
||||
s_readstring(linebuffer, 70);
|
||||
free(content[z]);
|
||||
content[z] = strdup(linebuffer);
|
||||
}
|
||||
}
|
||||
} else if (toupper(linebuffer[1]) == 'I') {
|
||||
s_putstring(socket, "\r\nInsert before which line? ");
|
||||
s_readstring(socket, buffer, 6);
|
||||
s_printf("\r\nInsert before which line? ");
|
||||
s_readstring(buffer, 6);
|
||||
if (strlen(buffer) == 0) {
|
||||
s_putstring(socket, "\r\nAborted...\r\n");
|
||||
s_printf("\r\nAborted...\r\n");
|
||||
} else {
|
||||
z = atoi(buffer);
|
||||
if (z < 0 || z >= lines) {
|
||||
s_putstring(socket, "\r\nAborted...\r\n");
|
||||
s_printf("\r\nAborted...\r\n");
|
||||
} else {
|
||||
sprintf(buffer, "\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m", z);
|
||||
s_putstring(socket, buffer);
|
||||
s_readstring(socket, linebuffer, 70);
|
||||
s_printf("\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m", z);
|
||||
s_readstring(linebuffer, 70);
|
||||
lines++;
|
||||
content = (char **)realloc(content, sizeof(char *) * lines);
|
||||
|
||||
@ -693,10 +683,9 @@ char *editor(int socket, struct user_record *user, char *quote, char *from, int
|
||||
return NULL;
|
||||
}
|
||||
|
||||
void read_message(int socket, struct user_record *user, struct msg_headers *msghs, int mailno) {
|
||||
void read_message(struct user_record *user, struct msg_headers *msghs, int mailno) {
|
||||
s_JamBase *jb;
|
||||
s_JamBaseHeader jbh;
|
||||
s_JamMsgHeader jmh;
|
||||
s_JamMsgHeader jmh;
|
||||
s_JamSubPacket* jsp;
|
||||
s_JamSubfield jsf;
|
||||
s_JamLastRead jlr;
|
||||
@ -715,14 +704,8 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
char c;
|
||||
char *replybody;
|
||||
struct fido_addr *from_addr = NULL;
|
||||
struct fido_addr *dest;
|
||||
int wwiv_to = 0;
|
||||
int i, j;
|
||||
char *wwiv_addressee;
|
||||
char *dest_addr;
|
||||
int to_us;
|
||||
char *msgid = NULL;
|
||||
char timestr[17];
|
||||
int i, j;
|
||||
char timestr[17];
|
||||
int doquit = 0;
|
||||
int skip_line = 0;
|
||||
int chars = 0;
|
||||
@ -750,24 +733,20 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
|
||||
if (msghs->msgs[mailno]->oaddress != NULL && conf.mail_conferences[user->cur_mail_conf]->nettype == NETWORK_FIDO) {
|
||||
from_addr = parse_fido_addr(msghs->msgs[mailno]->oaddress);
|
||||
sprintf(buffer, "\e[2J\e[1;32mFrom : \e[1;37m%s (%d:%d/%d.%d)\r\n", msghs->msgs[mailno]->from, from_addr->zone, from_addr->net, from_addr->node, from_addr->point);
|
||||
s_printf("\e[2J\e[1;32mFrom : \e[1;37m%s (%d:%d/%d.%d)\r\n", msghs->msgs[mailno]->from, from_addr->zone, from_addr->net, from_addr->node, from_addr->point);
|
||||
free(from_addr);
|
||||
} else {
|
||||
sprintf(buffer, "\e[2J\e[1;32mFrom : \e[1;37m%s\r\n", msghs->msgs[mailno]->from);
|
||||
s_printf("\e[2J\e[1;32mFrom : \e[1;37m%s\r\n", msghs->msgs[mailno]->from);
|
||||
}
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mTo : \e[1;37m%-27.27s \e[1;32mArea : \e[1;37m%-27.27s\r\n", msghs->msgs[mailno]->to, conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->name);
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mSubject : \e[1;37m%-27.27s \e[1;32mMsgNo : \e[1;37m%4d of %4d\r\n", msghs->msgs[mailno]->subject, mailno + 1, msghs->msg_count);
|
||||
s_putstring(socket, buffer);
|
||||
localtime_r((time_t *)&msghs->msgs[mailno]->msg_h->DateWritten, &msg_date);
|
||||
s_printf("\e[1;32mTo : \e[1;37m%-27.27s \e[1;32mArea : \e[1;37m%-27.27s\r\n", msghs->msgs[mailno]->to, conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->name);
|
||||
s_printf("\e[1;32mSubject : \e[1;37m%-27.27s \e[1;32mMsgNo : \e[1;37m%4d of %4d\r\n", msghs->msgs[mailno]->subject, mailno + 1, msghs->msg_count);
|
||||
localtime_r((time_t *)&msghs->msgs[mailno]->msg_h->DateWritten, &msg_date);
|
||||
sprintf(buffer, "\e[1;32mDate : \e[1;37m%s", asctime(&msg_date));
|
||||
buffer[strlen(buffer) - 1] = '\0';
|
||||
strcat(buffer, "\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
sprintf(buffer, "\e[1;32mAttribs : \e[1;37m%s\r\n", (msghs->msgs[mailno]->msg_h->Attribute & MSG_SENT ? "SENT" : ""));
|
||||
s_putstring(socket, buffer);
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf(buffer);
|
||||
s_printf("\e[1;32mAttribs : \e[1;37m%s\r\n", (msghs->msgs[mailno]->msg_h->Attribute & MSG_SENT ? "SENT" : ""));
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
|
||||
body = (char *)malloc(msghs->msgs[mailno]->msg_h->TxtLen);
|
||||
|
||||
@ -817,16 +796,16 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
if (body[z] == '\r' || chars == 79) {
|
||||
chars = 0;
|
||||
if (body[z] == '\r') {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
} else {
|
||||
s_putchar(socket, body[z]);
|
||||
s_putchar(body[z]);
|
||||
}
|
||||
lines++;
|
||||
if (lines >= 17) {
|
||||
s_putstring(socket, "\e[1;37mPress a key to continue...\e[0m");
|
||||
s_getc(socket);
|
||||
s_printf("\e[1;37mPress a key to continue...\e[0m");
|
||||
s_getc();
|
||||
lines = 0;
|
||||
s_putstring(socket, "\e[7;1H\e[0J");
|
||||
s_printf("\e[7;1H\e[0J");
|
||||
}
|
||||
} else if (body[z] == '\e' && body[z + 1] == '[') {
|
||||
ansi = z;
|
||||
@ -835,7 +814,7 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
if (body[z] == 'm') {
|
||||
strncpy(buffer, &body[ansi], (z - ansi) + 1);
|
||||
buffer[z - ansi + 1] = '\0';
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("%s", buffer);
|
||||
} else if (body[z] == 'A') {
|
||||
j = atoi(&body[ansi + 2]);
|
||||
if (j == 0 && ansi + 2 == z) {
|
||||
@ -843,7 +822,7 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
}
|
||||
for (i=0;i<j;i++) {
|
||||
if (lines - 1 >= 0) {
|
||||
s_putstring(socket, "\e[A");
|
||||
s_printf("\e[A");
|
||||
lines--;
|
||||
} else {
|
||||
break;
|
||||
@ -856,7 +835,7 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
}
|
||||
for (i=0;i<j;i++) {
|
||||
if (chars + 1 <= 79) {
|
||||
s_putstring(socket, "\e[C");
|
||||
s_printf("\e[C");
|
||||
chars++;
|
||||
} else {
|
||||
break;
|
||||
@ -869,7 +848,7 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
}
|
||||
for (i=0;i<j;i++) {
|
||||
if (lines + 1 < 17) {
|
||||
s_putstring(socket, "\e[B");
|
||||
s_printf("\e[B");
|
||||
lines++;
|
||||
} else {
|
||||
break;
|
||||
@ -882,7 +861,7 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
}
|
||||
for (i=0;i<j;i++) {
|
||||
if (chars - 1 >= 0) {
|
||||
s_putstring(socket, "\e[D");
|
||||
s_printf("\e[D");
|
||||
chars--;
|
||||
} else {
|
||||
break;
|
||||
@ -891,18 +870,18 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
}
|
||||
} else {
|
||||
chars++;
|
||||
s_putchar(socket, body[z]);
|
||||
s_putchar(body[z]);
|
||||
}
|
||||
}
|
||||
|
||||
s_putstring(socket, "\r\n\e[1;37mPress \e[1;36mR \e[1;37mto reply, \e[1;36mQ \e[1;37mto quit, \e[1;36mB \e[1;37mto go Back, \e[1;36mSPACE \e[1;37mfor Next Mesage...");
|
||||
s_printf("\r\n\e[1;37mPress \e[1;36mR \e[1;37mto reply, \e[1;36mQ \e[1;37mto quit, \e[1;36mB \e[1;37mto go Back, \e[1;36mSPACE \e[1;37mfor Next Mesage...");
|
||||
|
||||
c = s_getc(socket);
|
||||
c = s_getc();
|
||||
|
||||
if (tolower(c) == 'r') {
|
||||
JAM_CloseMB(jb);
|
||||
if (user->sec_level < conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->write_sec_level) {
|
||||
s_putstring(socket, "\r\nSorry, you are not allowed to post in this area\r\n");
|
||||
s_printf("\r\nSorry, you are not allowed to post in this area\r\n");
|
||||
} else {
|
||||
if (msghs->msgs[mailno]->subject != NULL) {
|
||||
if (strncasecmp(msghs->msgs[mailno]->subject, "RE:", 3) != 0) {
|
||||
@ -914,25 +893,24 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
subject = (char *)malloc(strlen(buffer) + 1);
|
||||
strcpy(subject, buffer);
|
||||
|
||||
sprintf(buffer, "\r\n\r\nReplying to: %s\r\n", subject);
|
||||
s_putstring(socket, buffer);
|
||||
s_putstring(socket, "Change Subject? (Y/N) ");
|
||||
s_printf("\r\n\r\nReplying to: %s\r\n", subject);
|
||||
s_printf("Change Subject? (Y/N) ");
|
||||
|
||||
c = s_getc(socket);
|
||||
c = s_getc();
|
||||
|
||||
if (tolower(c) == 'y') {
|
||||
s_putstring(socket, "\r\nNew subject: ");
|
||||
s_readstring(socket, buffer, 25);
|
||||
s_printf("\r\nNew subject: ");
|
||||
s_readstring(buffer, 25);
|
||||
|
||||
if (strlen(buffer) == 0) {
|
||||
s_putstring(socket, "\r\nOk, not changing the subject line...");
|
||||
s_printf("\r\nOk, not changing the subject line...");
|
||||
} else {
|
||||
free(subject);
|
||||
subject = (char *)malloc(strlen(buffer) + 1);
|
||||
strcpy(subject, buffer);
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
|
||||
if (msghs->msgs[mailno]->from != NULL) {
|
||||
strcpy(buffer, msghs->msgs[mailno]->from);
|
||||
@ -961,7 +939,7 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
to = (char *)malloc(strlen(buffer) + 1);
|
||||
strcpy(to, buffer);
|
||||
}
|
||||
replybody = external_editor(socket, user, to, from, body, msghs->msgs[mailno]->from, subject, 0);
|
||||
replybody = external_editor(user, to, from, body, msghs->msgs[mailno]->from, subject, 0);
|
||||
if (replybody != NULL) {
|
||||
|
||||
jb = open_jam_base(conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->path);
|
||||
@ -1189,7 +1167,7 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
} else if (c == ' ') {
|
||||
mailno++;
|
||||
if (mailno >= msghs->msg_count) {
|
||||
s_putstring(socket, "\r\n\r\nNo more messages\r\n");
|
||||
s_printf("\r\n\r\nNo more messages\r\n");
|
||||
doquit = 1;
|
||||
}
|
||||
} else if (tolower(c) == 'b') {
|
||||
@ -1200,12 +1178,11 @@ void read_message(int socket, struct user_record *user, struct msg_headers *msgh
|
||||
}
|
||||
}
|
||||
|
||||
int mail_menu(int socket, struct user_record *user) {
|
||||
int mail_menu(struct user_record *user) {
|
||||
int doquit = 0;
|
||||
int domail = 0;
|
||||
char c;
|
||||
char prompt[128];
|
||||
char buffer[256];
|
||||
char buffer[256];
|
||||
char buffer2[256];
|
||||
int i;
|
||||
int j;
|
||||
@ -1214,8 +1191,7 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
struct msg_headers *msghs;
|
||||
|
||||
s_JamBase *jb;
|
||||
s_JamBaseHeader jbh;
|
||||
s_JamMsgHeader jmh;
|
||||
s_JamMsgHeader jmh;
|
||||
s_JamSubPacket* jsp;
|
||||
s_JamSubfield jsf;
|
||||
s_JamLastRead jlr;
|
||||
@ -1225,20 +1201,11 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
char *subject;
|
||||
char *from;
|
||||
char *to;
|
||||
char *body;
|
||||
char *replybody;
|
||||
char *wwiv_addressee;
|
||||
char timestr[17];
|
||||
char timestr[17];
|
||||
char *msg;
|
||||
int closed;
|
||||
uint32_t jam_crc;
|
||||
unsigned int lastmsg,currmsg;
|
||||
int lines;
|
||||
struct fido_addr *from_addr = NULL;
|
||||
struct fido_addr *dest = NULL;
|
||||
char *dest_addr;
|
||||
int to_us;
|
||||
int wwiv_to;
|
||||
struct fido_addr *from_addr = NULL;
|
||||
int wwiv_to;
|
||||
struct stat s;
|
||||
int do_internal_menu = 0;
|
||||
char *lRet;
|
||||
@ -1269,13 +1236,12 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
|
||||
while (!domail) {
|
||||
if (do_internal_menu == 1) {
|
||||
s_displayansi(socket, "mailmenu");
|
||||
s_displayansi("mailmenu");
|
||||
|
||||
|
||||
sprintf(prompt, "\e[0m\r\nConf: (%d) %s\r\nArea: (%d) %s\r\nTL: %dm :> ", user->cur_mail_conf, conf.mail_conferences[user->cur_mail_conf]->name, user->cur_mail_area, conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->name, user->timeleft);
|
||||
s_putstring(socket, prompt);
|
||||
|
||||
c = s_getc(socket);
|
||||
s_printf("\e[0m\r\nConf: (%d) %s\r\nArea: (%d) %s\r\nTL: %dm :> ", user->cur_mail_conf, conf.mail_conferences[user->cur_mail_conf]->name, user->cur_mail_area, conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->name, user->timeleft);
|
||||
|
||||
c = s_getc();
|
||||
} else {
|
||||
lua_getglobal(L, "menu");
|
||||
result = lua_pcall(L, 0, 1, 0);
|
||||
@ -1292,7 +1258,7 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
switch(tolower(c)) {
|
||||
case 'd':
|
||||
{
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
// list mail in message base
|
||||
msghs = read_message_headers(user->cur_mail_conf, user->cur_mail_area, user);
|
||||
if (msghs != NULL && msghs->msg_count > 0) {
|
||||
@ -1308,9 +1274,9 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
all_unread = 1;
|
||||
}
|
||||
JAM_CloseMB(jb);
|
||||
sprintf(buffer, "Read message [1-%d] or N for New: ", msghs->msg_count);
|
||||
s_putstring(socket, buffer);
|
||||
s_readstring(socket, buffer, 6);
|
||||
s_printf("Read message [1-%d] or N for New: ", msghs->msg_count);
|
||||
|
||||
s_readstring(buffer, 6);
|
||||
|
||||
if (tolower(buffer[0]) == 'n') {
|
||||
if (all_unread == 0) {
|
||||
@ -1329,7 +1295,7 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
}
|
||||
|
||||
if (i > 0 && i <= msghs->msg_count) {
|
||||
read_message(socket, user, msghs, i - 1);
|
||||
read_message(user, msghs, i - 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1341,14 +1307,14 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
case 'p':
|
||||
{
|
||||
if (user->sec_level < conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->write_sec_level) {
|
||||
s_putstring(socket, "\r\nSorry, you are not allowed to post in this area\r\n");
|
||||
s_printf("\r\nSorry, you are not allowed to post in this area\r\n");
|
||||
break;
|
||||
}
|
||||
if (conf.mail_conferences[user->cur_mail_conf]->nettype == NETWORK_WWIV && conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->type == TYPE_ECHOMAIL_AREA) {
|
||||
sprintf(buffer, "ALL");
|
||||
} else {
|
||||
s_putstring(socket, "\r\nTO: ");
|
||||
s_readstring(socket, buffer, 16);
|
||||
s_printf("\r\nTO: ");
|
||||
s_readstring(buffer, 16);
|
||||
}
|
||||
if (strlen(buffer) == 0) {
|
||||
strcpy(buffer, "ALL");
|
||||
@ -1356,43 +1322,41 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
|
||||
if (conf.mail_conferences[user->cur_mail_conf]->networked == 0 && strcasecmp(buffer, "ALL") != 0) {
|
||||
if (check_user(buffer)) {
|
||||
s_putstring(socket, "\r\n\r\nInvalid Username\r\n");
|
||||
s_printf("\r\n\r\nInvalid Username\r\n");
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->type == TYPE_NETMAIL_AREA) {
|
||||
s_putstring(socket, "\r\nADDR: ");
|
||||
s_readstring(socket, buffer2, 32);
|
||||
s_printf("\r\nADDR: ");
|
||||
s_readstring(buffer2, 32);
|
||||
if (conf.mail_conferences[user->cur_mail_conf]->nettype == NETWORK_FIDO) {
|
||||
from_addr = parse_fido_addr(buffer2);
|
||||
if (!from_addr) {
|
||||
s_putstring(socket, "\r\n\r\nInvalid Address\r\n");
|
||||
s_printf("\r\n\r\nInvalid Address\r\n");
|
||||
break;
|
||||
} else {
|
||||
if (from_addr->zone == 0 && from_addr->net == 0 && from_addr->node == 0 && from_addr->point == 0) {
|
||||
free(from_addr);
|
||||
s_putstring(socket, "\r\n\r\nInvalid Address\r\n");
|
||||
s_printf("\r\n\r\nInvalid Address\r\n");
|
||||
break;
|
||||
}
|
||||
sprintf(buffer2, "\r\nMailing to %d:%d/%d.%d\r\n", from_addr->zone, from_addr->net, from_addr->node, from_addr->point);
|
||||
s_putstring(socket, buffer2);
|
||||
}
|
||||
s_printf(buffer2, "\r\nMailing to %d:%d/%d.%d\r\n", from_addr->zone, from_addr->net, from_addr->node, from_addr->point);
|
||||
}
|
||||
} else if (conf.mail_conferences[user->cur_mail_conf]->nettype == NETWORK_WWIV) {
|
||||
wwiv_to = atoi(buffer2);
|
||||
if (wwiv_to == 0) {
|
||||
s_putstring(socket, "\r\n\r\nInvalid Address\r\n");
|
||||
s_printf("\r\n\r\nInvalid Address\r\n");
|
||||
break;
|
||||
} else {
|
||||
sprintf(buffer2, "\r\nMailing to @%d\r\n", wwiv_to);
|
||||
s_putstring(socket, buffer2);
|
||||
s_printf("\r\nMailing to @%d\r\n", wwiv_to);
|
||||
}
|
||||
}
|
||||
}
|
||||
to = strdup(buffer);
|
||||
s_putstring(socket, "\r\nSUBJECT: ");
|
||||
s_readstring(socket, buffer, 25);
|
||||
s_printf("\r\nSUBJECT: ");
|
||||
s_readstring(buffer, 25);
|
||||
if (strlen(buffer) == 0) {
|
||||
s_putstring(socket, "\r\nAborted!\r\n");
|
||||
s_printf("\r\nAborted!\r\n");
|
||||
free(to);
|
||||
if (from_addr != NULL) {
|
||||
free(from_addr);
|
||||
@ -1401,9 +1365,17 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
}
|
||||
subject = strdup(buffer);
|
||||
|
||||
// post a message
|
||||
msg = external_editor(socket, user, to, from, NULL, NULL, subject, 0);
|
||||
|
||||
// post a message
|
||||
if (conf.mail_conferences[user->cur_mail_conf]->realnames == 0) {
|
||||
from = strdup(user->loginname);
|
||||
} else {
|
||||
from = (char *)malloc(strlen(user->firstname) + strlen(user->lastname) + 2);
|
||||
sprintf(from, "%s %s", user->firstname, user->lastname);
|
||||
}
|
||||
msg = external_editor(user, to, from, NULL, NULL, subject, 0);
|
||||
|
||||
free(from);
|
||||
|
||||
if (msg != NULL) {
|
||||
jb = open_jam_base(conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->path);
|
||||
if (!jb) {
|
||||
@ -1427,7 +1399,7 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
if (conf.mail_conferences[user->cur_mail_conf]->nettype == NETWORK_WWIV) {
|
||||
sprintf(buffer, "%s #%d @%d (%s)", user->loginname, user->id, conf.mail_conferences[user->cur_mail_conf]->wwivnode, user->firstname);
|
||||
} else {
|
||||
sprintf(from, "%s %s", user->firstname, user->lastname);
|
||||
sprintf(buffer, "%s %s", user->firstname, user->lastname);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1599,7 +1571,7 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case 'l':
|
||||
{
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
// list mail in message base
|
||||
msghs = read_message_headers(user->cur_mail_conf, user->cur_mail_area, user);
|
||||
if (msghs != NULL && msghs->msg_count > 0) {
|
||||
@ -1615,10 +1587,9 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
all_unread = 1;
|
||||
}
|
||||
JAM_CloseMB(jb);
|
||||
sprintf(buffer, "Start at message [1-%d] or N for New? ", msghs->msg_count);
|
||||
s_putstring(socket, buffer);
|
||||
|
||||
s_readstring(socket, buffer, 6);
|
||||
s_printf("Start at message [1-%d] or N for New? ", msghs->msg_count);
|
||||
|
||||
s_readstring(buffer, 6);
|
||||
if (tolower(buffer[0]) == 'n') {
|
||||
if (all_unread == 0) {
|
||||
k = jlr.HighReadMsg;
|
||||
@ -1638,21 +1609,19 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
}
|
||||
}
|
||||
closed = 0;
|
||||
s_putstring(socket, "\e[2J\e[1;37;44m[MSG#] Subject From To Date \r\n\e[0m");
|
||||
s_printf("\e[2J\e[1;37;44m[MSG#] Subject From To Date \r\n\e[0m");
|
||||
|
||||
for (j=i-1;j<msghs->msg_count;j++) {
|
||||
localtime_r((time_t *)&msghs->msgs[j]->msg_h->DateWritten, &msg_date);
|
||||
if (msghs->msgs[j]->msg_no > jlr.HighReadMsg || all_unread) {
|
||||
sprintf(buffer, "\e[1;30m[\e[1;34m%4d\e[1;30m]\e[1;32m*\e[1;37m%-25.25s \e[1;32m%-15.15s \e[1;33m%-15.15s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", j + 1, msghs->msgs[j]->subject, msghs->msgs[j]->from, msghs->msgs[j]->to, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100);
|
||||
s_printf("\e[1;30m[\e[1;34m%4d\e[1;30m]\e[1;32m*\e[1;37m%-25.25s \e[1;32m%-15.15s \e[1;33m%-15.15s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", j + 1, msghs->msgs[j]->subject, msghs->msgs[j]->from, msghs->msgs[j]->to, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100);
|
||||
} else {
|
||||
sprintf(buffer, "\e[1;30m[\e[1;34m%4d\e[1;30m] \e[1;37m%-25.25s \e[1;32m%-15.15s \e[1;33m%-15.15s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", j + 1, msghs->msgs[j]->subject, msghs->msgs[j]->from, msghs->msgs[j]->to, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100);
|
||||
s_printf("\e[1;30m[\e[1;34m%4d\e[1;30m] \e[1;37m%-25.25s \e[1;32m%-15.15s \e[1;33m%-15.15s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", j + 1, msghs->msgs[j]->subject, msghs->msgs[j]->from, msghs->msgs[j]->to, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100);
|
||||
}
|
||||
s_putstring(socket, buffer);
|
||||
|
||||
|
||||
if ((j - (i - 1)) != 0 && (j - (i - 1)) % 20 == 0) {
|
||||
sprintf(buffer, "(#) Read Message # (Q) Quit (ENTER) Continue\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_readstring(socket, buffer, 6);
|
||||
s_printf("(#) Read Message # (Q) Quit (ENTER) Continue\r\n");
|
||||
s_readstring(buffer, 6);
|
||||
|
||||
if (tolower(buffer[0]) == 'q') {
|
||||
closed = 1;
|
||||
@ -1661,22 +1630,21 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
z = atoi(buffer);
|
||||
if (z > 0 && z <= msghs->msg_count) {
|
||||
closed = 1;
|
||||
read_message(socket, user, msghs, z - 1);
|
||||
read_message(user, msghs, z - 1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "\e[2J\e[1;37;44m[MSG#] Subject From To Date \r\n\e[0m");
|
||||
s_printf("\e[2J\e[1;37;44m[MSG#] Subject From To Date \r\n\e[0m");
|
||||
}
|
||||
|
||||
}
|
||||
if (closed == 0) {
|
||||
sprintf(buffer, "(#) Read Message # (ENTER) Quit\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_readstring(socket, buffer, 6);
|
||||
s_printf("(#) Read Message # (ENTER) Quit\r\n");
|
||||
s_readstring(buffer, 6);
|
||||
if (strlen(buffer) > 0) {
|
||||
z = atoi(buffer);
|
||||
if (z > 0 && z <= msghs->msg_count) {
|
||||
read_message(socket, user, msghs, z - 1);
|
||||
read_message(user, msghs, z - 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1686,31 +1654,30 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
free_message_headers(msghs);
|
||||
}
|
||||
} else {
|
||||
s_putstring(socket, "\r\nThere is no mail in this area\r\n");
|
||||
s_printf("\r\nThere is no mail in this area\r\n");
|
||||
}
|
||||
}
|
||||
break;
|
||||
case 'c':
|
||||
{
|
||||
s_putstring(socket, "\r\n\r\nMail Conferences:\r\n\r\n");
|
||||
s_printf("\r\n\r\nMail Conferences:\r\n\r\n");
|
||||
for (i=0;i<conf.mail_conference_count;i++) {
|
||||
if (conf.mail_conferences[i]->sec_level <= user->sec_level) {
|
||||
sprintf(buffer, " %d. %s\r\n", i, conf.mail_conferences[i]->name);
|
||||
s_putstring(socket, buffer);
|
||||
}
|
||||
s_printf(" %d. %s\r\n", i, conf.mail_conferences[i]->name);
|
||||
}
|
||||
if (i != 0 && i % 20 == 0) {
|
||||
s_putstring(socket, "Press any key to continue...\r\n");
|
||||
c = s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
c = s_getc();
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "Enter the conference number: ");
|
||||
s_readstring(socket, buffer, 5);
|
||||
s_printf("Enter the conference number: ");
|
||||
s_readstring(buffer, 5);
|
||||
if (tolower(buffer[0]) != 'q') {
|
||||
j = atoi(buffer);
|
||||
if (j < 0 || j >= conf.mail_conference_count || conf.mail_conferences[j]->sec_level > user->sec_level) {
|
||||
s_putstring(socket, "\r\nInvalid conference number!\r\n");
|
||||
s_printf("\r\nInvalid conference number!\r\n");
|
||||
} else {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
user->cur_mail_conf = j;
|
||||
user->cur_mail_area = 0;
|
||||
}
|
||||
@ -1719,25 +1686,24 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case 'a':
|
||||
{
|
||||
s_putstring(socket, "\r\n\r\nMail Areas:\r\n\r\n");
|
||||
s_printf("\r\n\r\nMail Areas:\r\n\r\n");
|
||||
for (i=0;i<conf.mail_conferences[user->cur_mail_conf]->mail_area_count;i++) {
|
||||
if (conf.mail_conferences[user->cur_mail_conf]->mail_areas[i]->read_sec_level <= user->sec_level) {
|
||||
sprintf(buffer, " %d. %s\r\n", i, conf.mail_conferences[user->cur_mail_conf]->mail_areas[i]->name);
|
||||
s_putstring(socket, buffer);
|
||||
}
|
||||
s_printf(" %d. %s\r\n", i, conf.mail_conferences[user->cur_mail_conf]->mail_areas[i]->name);
|
||||
}
|
||||
if (i != 0 && i % 20 == 0) {
|
||||
s_putstring(socket, "Press any key to continue...\r\n");
|
||||
c = s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
c = s_getc();
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "Enter the area number: ");
|
||||
s_readstring(socket, buffer, 5);
|
||||
s_printf("Enter the area number: ");
|
||||
s_readstring(buffer, 5);
|
||||
if (tolower(buffer[0]) != 'q') {
|
||||
j = atoi(buffer);
|
||||
if (j < 0 || j >= conf.mail_conferences[user->cur_mail_conf]->mail_area_count || conf.mail_conferences[user->cur_mail_conf]->mail_areas[j]->read_sec_level > user->sec_level) {
|
||||
s_putstring(socket, "\r\nInvalid area number!\r\n");
|
||||
s_printf("\r\nInvalid area number!\r\n");
|
||||
} else {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
user->cur_mail_area = j;
|
||||
}
|
||||
}
|
||||
@ -1750,8 +1716,8 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case 'g':
|
||||
{
|
||||
s_putstring(socket, "\r\nAre you sure you want to log off? (Y/N)");
|
||||
c = s_getc(socket);
|
||||
s_printf("\r\nAre you sure you want to log off? (Y/N)");
|
||||
c = s_getc();
|
||||
if (tolower(c) == 'y') {
|
||||
domail = 1;
|
||||
doquit = 1;
|
||||
@ -1760,14 +1726,14 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case 'e':
|
||||
{
|
||||
send_email(socket, user);
|
||||
send_email(user);
|
||||
}
|
||||
break;
|
||||
case 'r':
|
||||
{
|
||||
// Read your email...
|
||||
s_putstring(socket, "\r\n");
|
||||
list_emails(socket, user);
|
||||
s_printf("\r\n");
|
||||
list_emails(user);
|
||||
}
|
||||
break;
|
||||
case '}':
|
||||
@ -1832,7 +1798,7 @@ int mail_menu(int socket, struct user_record *user) {
|
||||
return doquit;
|
||||
}
|
||||
|
||||
void mail_scan(int socket, struct user_record *user) {
|
||||
void mail_scan(struct user_record *user) {
|
||||
s_JamBase *jb;
|
||||
s_JamBaseHeader jbh;
|
||||
s_JamLastRead jlr;
|
||||
@ -1840,20 +1806,17 @@ void mail_scan(int socket, struct user_record *user) {
|
||||
char c;
|
||||
int i;
|
||||
int j;
|
||||
char buffer[256];
|
||||
int count;
|
||||
|
||||
s_putstring(socket, "\r\nScan for new mail? (Y/N) : ");
|
||||
c = s_getc(socket);
|
||||
|
||||
s_printf("\r\nScan for new mail? (Y/N) : ");
|
||||
c = s_getc();
|
||||
|
||||
if (tolower(c) == 'y') {
|
||||
for (i=0;i<conf.mail_conference_count;i++) {
|
||||
if (conf.mail_conferences[i]->sec_level > user->sec_level) {
|
||||
continue;
|
||||
}
|
||||
sprintf(buffer, "\r\n%d. %s\r\n", i, conf.mail_conferences[i]->name);
|
||||
s_putstring(socket, buffer);
|
||||
for (j=0;j<conf.mail_conferences[i]->mail_area_count;j++) {
|
||||
s_printf("\r\n%d. %s\r\n", i, conf.mail_conferences[i]->name);
|
||||
for (j=0;j<conf.mail_conferences[i]->mail_area_count;j++) {
|
||||
if (conf.mail_conferences[i]->mail_areas[j]->read_sec_level > user->sec_level) {
|
||||
continue;
|
||||
}
|
||||
@ -1871,21 +1834,19 @@ void mail_scan(int socket, struct user_record *user) {
|
||||
JAM_CloseMB(jb);
|
||||
continue;
|
||||
}
|
||||
sprintf(buffer, " --> %d. %s (%d new)\r\n", j, conf.mail_conferences[i]->mail_areas[j]->name, jbh.ActiveMsgs);
|
||||
s_printf(" --> %d. %s (%d new)\r\n", j, conf.mail_conferences[i]->mail_areas[j]->name, jbh.ActiveMsgs);
|
||||
} else {
|
||||
if (jlr.HighReadMsg < (jbh.ActiveMsgs - 1)) {
|
||||
sprintf(buffer, " --> %d. %s (%d new)\r\n", j, conf.mail_conferences[i]->mail_areas[j]->name, (jbh.ActiveMsgs - 1) - jlr.HighReadMsg);
|
||||
s_printf(" --> %d. %s (%d new)\r\n", j, conf.mail_conferences[i]->mail_areas[j]->name, (jbh.ActiveMsgs - 1) - jlr.HighReadMsg);
|
||||
} else {
|
||||
JAM_CloseMB(jb);
|
||||
continue;
|
||||
}
|
||||
}
|
||||
s_putstring(socket, buffer);
|
||||
JAM_CloseMB(jb);
|
||||
JAM_CloseMB(jb);
|
||||
}
|
||||
}
|
||||
sprintf(buffer, "\r\nPress any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_printf("\r\nPress any key to continue...\r\n");
|
||||
s_getc();
|
||||
}
|
||||
}
|
||||
|
2
main.c
2
main.c
@ -321,7 +321,7 @@ static int handler(void* user, const char* section, const char* name,
|
||||
void server(int port) {
|
||||
struct sigaction sa;
|
||||
struct sigaction st;
|
||||
int socket_desc, client_sock, c, *new_sock;
|
||||
int socket_desc, client_sock, c;
|
||||
int pid;
|
||||
struct sockaddr_in server, client;
|
||||
|
||||
|
68
main_menu.c
68
main_menu.c
@ -10,10 +10,9 @@
|
||||
|
||||
extern struct bbs_config conf;
|
||||
|
||||
void main_menu(int socket, struct user_record *user) {
|
||||
void main_menu(struct user_record *user) {
|
||||
int doquit = 0;
|
||||
char c;
|
||||
char prompt[128];
|
||||
char buffer[256];
|
||||
int i;
|
||||
struct stat s;
|
||||
@ -45,13 +44,12 @@ void main_menu(int socket, struct user_record *user) {
|
||||
while (!doquit) {
|
||||
|
||||
if (do_internal_menu == 1) {
|
||||
s_displayansi(socket, "mainmenu");
|
||||
s_displayansi("mainmenu");
|
||||
|
||||
|
||||
sprintf(prompt, "\r\n\e[0mTL: %dm :> ", user->timeleft);
|
||||
s_putstring(socket, prompt);
|
||||
s_printf("\r\n\e[0mTL: %dm :> ", user->timeleft);
|
||||
|
||||
c = s_getc(socket);
|
||||
c = s_getc();
|
||||
} else {
|
||||
lua_getglobal(L, "menu");
|
||||
result = lua_pcall(L, 0, 1, 0);
|
||||
@ -69,7 +67,7 @@ void main_menu(int socket, struct user_record *user) {
|
||||
switch(tolower(c)) {
|
||||
case 'o':
|
||||
{
|
||||
automessage_write(socket, user);
|
||||
automessage_write(user);
|
||||
}
|
||||
break;
|
||||
case 'a':
|
||||
@ -77,49 +75,48 @@ void main_menu(int socket, struct user_record *user) {
|
||||
if (conf.text_file_count > 0) {
|
||||
|
||||
while(1) {
|
||||
s_putstring(socket, "\r\n\e[1;32mText Files Collection\r\n");
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf("\r\n\e[1;32mText Files Collection\r\n");
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
|
||||
for (i=0;i<conf.text_file_count;i++) {
|
||||
sprintf(buffer, "\e[1;30m[\e[1;34m%3d\e[1;30m] \e[1;37m%s\r\n", i, conf.text_files[i]->name);
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\e[1;30m[\e[1;34m%3d\e[1;30m] \e[1;37m%s\r\n", i, conf.text_files[i]->name);
|
||||
}
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_putstring(socket, "Enter the number of a text file to display or Q to quit: ");
|
||||
s_readstring(socket, buffer, 4);
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf("Enter the number of a text file to display or Q to quit: ");
|
||||
s_readstring(buffer, 4);
|
||||
if (tolower(buffer[0]) != 'q') {
|
||||
i = atoi(buffer);
|
||||
if (i >= 0 && i < conf.text_file_count) {
|
||||
s_putstring(socket, "\r\n");
|
||||
s_displayansi_p(socket, conf.text_files[i]->path);
|
||||
s_putstring(socket, "Press any key to continue...");
|
||||
s_getc(socket);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\n");
|
||||
s_displayansi_p(conf.text_files[i]->path);
|
||||
s_printf("Press any key to continue...");
|
||||
s_getc();
|
||||
s_printf("\r\n");
|
||||
}
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
s_putstring(socket, "\r\nSorry, there are no text files to display\r\n");
|
||||
s_putstring(socket, "Press any key to continue...\r\n");
|
||||
s_getc(socket);
|
||||
s_printf("\r\nSorry, there are no text files to display\r\n");
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
s_getc();
|
||||
}
|
||||
}
|
||||
break;
|
||||
case 'c':
|
||||
{
|
||||
chat_system(socket, user);
|
||||
chat_system(user);
|
||||
}
|
||||
break;
|
||||
case 'l':
|
||||
{
|
||||
bbs_list(socket, user);
|
||||
bbs_list(user);
|
||||
}
|
||||
break;
|
||||
case 'u':
|
||||
{
|
||||
list_users(socket, user);
|
||||
list_users(user);
|
||||
}
|
||||
break;
|
||||
case 'b':
|
||||
@ -129,10 +126,9 @@ void main_menu(int socket, struct user_record *user) {
|
||||
|
||||
while (stat(buffer, &s) == 0) {
|
||||
sprintf(buffer, "bulletin%d", i);
|
||||
s_displayansi(socket, buffer);
|
||||
sprintf(buffer, "\e[0mPress any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_displayansi(buffer);
|
||||
s_printf("\e[0mPress any key to continue...\r\n");
|
||||
s_getc();
|
||||
i++;
|
||||
sprintf(buffer, "%s/bulletin%d.ans", conf.ansi_path, i);
|
||||
}
|
||||
@ -140,23 +136,23 @@ void main_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case '1':
|
||||
{
|
||||
display_last10_callers(socket, user);
|
||||
display_last10_callers(user);
|
||||
}
|
||||
break;
|
||||
case 'd':
|
||||
{
|
||||
doquit = door_menu(socket, user);
|
||||
doquit = door_menu(user);
|
||||
}
|
||||
break;
|
||||
case 'm':
|
||||
{
|
||||
doquit = mail_menu(socket, user);
|
||||
doquit = mail_menu(user);
|
||||
}
|
||||
break;
|
||||
case 'g':
|
||||
{
|
||||
s_putstring(socket, "\r\nAre you sure you want to log off? (Y/N)");
|
||||
c = s_getc(socket);
|
||||
s_printf("\r\nAre you sure you want to log off? (Y/N)");
|
||||
c = s_getc();
|
||||
if (tolower(c) == 'y') {
|
||||
doquit = 1;
|
||||
}
|
||||
@ -164,12 +160,12 @@ void main_menu(int socket, struct user_record *user) {
|
||||
break;
|
||||
case 't':
|
||||
{
|
||||
doquit = file_menu(socket, user);
|
||||
doquit = file_menu(user);
|
||||
}
|
||||
break;
|
||||
case 's':
|
||||
{
|
||||
settings_menu(socket, user);
|
||||
settings_menu(user);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
35
settings.c
35
settings.c
@ -4,32 +4,31 @@
|
||||
#include <ctype.h>
|
||||
#include "bbs.h"
|
||||
|
||||
void settings_menu(int sock, struct user_record *user) {
|
||||
void settings_menu(struct user_record *user) {
|
||||
char buffer[256];
|
||||
int dosettings = 0;
|
||||
char c;
|
||||
char *hash;
|
||||
|
||||
while (!dosettings) {
|
||||
s_putstring(sock, "\e[2J\e[1;32mYour Settings\r\n");
|
||||
s_putstring(sock, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_putstring(sock, "\e[0;36mP. \e[1;37mPassword (\e[1;33mNot Shown\e[1;37m)\r\n");
|
||||
sprintf(buffer, "\e[0;36mL. \e[1;37mLocation (\e[1;33m%s\e[1;37m)\r\n", user->location);
|
||||
s_putstring(sock, buffer);
|
||||
s_putstring(sock, "\e[0;36mQ. \e[1;37mQuit to Main Menu\r\n");
|
||||
s_putstring(sock, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf("\e[2J\e[1;32mYour Settings\r\n");
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf("\e[0;36mP. \e[1;37mPassword (\e[1;33mNot Shown\e[1;37m)\r\n");
|
||||
s_printf("\e[0;36mL. \e[1;37mLocation (\e[1;33m%s\e[1;37m)\r\n", user->location);
|
||||
s_printf("\e[0;36mQ. \e[1;37mQuit to Main Menu\r\n");
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
|
||||
c = s_getc(sock);
|
||||
c = s_getc();
|
||||
|
||||
switch(tolower(c)) {
|
||||
case 'p':
|
||||
{
|
||||
s_putstring(sock, "\r\nEnter your current password: ");
|
||||
s_readpass(sock, buffer, 16);
|
||||
s_printf("\r\nEnter your current password: ");
|
||||
s_readpass(buffer, 16);
|
||||
hash = hash_sha256(buffer, user->salt);
|
||||
if (strcmp(hash, user->password) == 0) {
|
||||
s_putstring(sock, "\r\nEnter your new password (8 chars min): ");
|
||||
s_readstring(sock, buffer, 16);
|
||||
s_printf("\r\nEnter your new password (8 chars min): ");
|
||||
s_readstring(buffer, 16);
|
||||
if (strlen(buffer) >= 8) {
|
||||
free(user->password);
|
||||
free(user->salt);
|
||||
@ -38,19 +37,19 @@ void settings_menu(int sock, struct user_record *user) {
|
||||
user->password = hash_sha256(buffer, user->salt);
|
||||
|
||||
save_user(user);
|
||||
s_putstring(sock, "\r\nPassword Changed!\r\n");
|
||||
s_printf("\r\nPassword Changed!\r\n");
|
||||
} else {
|
||||
s_putstring(sock, "\r\nPassword too short!\r\n");
|
||||
s_printf("\r\nPassword too short!\r\n");
|
||||
}
|
||||
} else {
|
||||
s_putstring(sock, "\r\nPassword Incorrect!\r\n");
|
||||
s_printf("\r\nPassword Incorrect!\r\n");
|
||||
}
|
||||
}
|
||||
break;
|
||||
case 'l':
|
||||
{
|
||||
s_putstring(sock, "\r\nEnter your new location: ");
|
||||
s_readstring(sock, buffer, 32);
|
||||
s_printf("\r\nEnter your new location: ");
|
||||
s_readstring(buffer, 32);
|
||||
free(user->location);
|
||||
user->location = (char *)malloc(strlen(buffer) + 1);
|
||||
strcpy(user->location, buffer);
|
||||
|
156
users.c
156
users.c
@ -82,7 +82,6 @@ int save_user(struct user_record *user) {
|
||||
|
||||
char *update_sql = "UPDATE users SET password=?, salt=?, firstname=?,"
|
||||
"lastname=?, email=?, location=?, sec_level=?, last_on=?, time_left=?, cur_mail_conf=?, cur_mail_area=?, cur_file_dir=?, cur_file_sub=?, times_on=? where loginname LIKE ?";
|
||||
char *err_msg = 0;
|
||||
|
||||
sprintf(buffer, "%s/users.sq3", conf.bbs_path);
|
||||
|
||||
@ -219,7 +218,7 @@ int inst_user(struct user_record *user) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
struct user_record *check_user_pass(int socket, char *loginname, char *password) {
|
||||
struct user_record *check_user_pass(char *loginname, char *password) {
|
||||
struct user_record *user;
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
@ -322,7 +321,7 @@ struct user_record *check_user_pass(int socket, char *loginname, char *password)
|
||||
return user;
|
||||
}
|
||||
|
||||
void list_users(int socket, struct user_record *user) {
|
||||
void list_users(struct user_record *user) {
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
@ -346,70 +345,67 @@ void list_users(int socket, struct user_record *user) {
|
||||
sqlite3_close(db);
|
||||
exit(1);
|
||||
}
|
||||
s_putstring(socket, "\e[2J\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_putstring(socket, "User Name Location Times On\r\n");
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf("\e[2J\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
s_printf("User Name Location Times On\r\n");
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
i = 0;
|
||||
while (sqlite3_step(res) == SQLITE_ROW) {
|
||||
sprintf(buffer, "\e[1;37m%-16s \e[1;36m%-32s \e[1;32m%5d\r\n", sqlite3_column_text(res, 0), sqlite3_column_text(res, 1), sqlite3_column_int(res, 2));
|
||||
s_putstring(socket, buffer);
|
||||
s_printf("\e[1;37m%-16s \e[1;36m%-32s \e[1;32m%5d\r\n", sqlite3_column_text(res, 0), sqlite3_column_text(res, 1), sqlite3_column_int(res, 2));
|
||||
|
||||
i++;
|
||||
if (i == 20) {
|
||||
sprintf(buffer, "Press any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
s_getc();
|
||||
i = 0;
|
||||
}
|
||||
}
|
||||
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
|
||||
sprintf(buffer, "Press any key to continue...\r\n");
|
||||
s_putstring(socket, buffer);
|
||||
s_getc(socket);
|
||||
s_printf("Press any key to continue...\r\n");
|
||||
s_getc();
|
||||
}
|
||||
|
||||
int check_user(char *loginname) {
|
||||
char buffer[256];
|
||||
sqlite3 *db;
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
char *sql = "SELECT * FROM users WHERE loginname = ?";
|
||||
sqlite3_stmt *res;
|
||||
int rc;
|
||||
char *sql = "SELECT * FROM users WHERE loginname = ?";
|
||||
|
||||
sprintf(buffer, "%s/users.sq3", conf.bbs_path);
|
||||
|
||||
rc = sqlite3_open(buffer, &db);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
dolog("Cannot open database: %s", sqlite3_errmsg(db));
|
||||
sqlite3_close(db);
|
||||
dolog("Cannot open database: %s", sqlite3_errmsg(db));
|
||||
sqlite3_close(db);
|
||||
|
||||
exit(1);
|
||||
}
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
exit(1);
|
||||
}
|
||||
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
|
||||
|
||||
if (rc == SQLITE_OK) {
|
||||
sqlite3_bind_text(res, 1, loginname, -1, 0);
|
||||
} else {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
}
|
||||
if (rc == SQLITE_OK) {
|
||||
sqlite3_bind_text(res, 1, loginname, -1, 0);
|
||||
} else {
|
||||
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
|
||||
}
|
||||
|
||||
int step = sqlite3_step(res);
|
||||
int step = sqlite3_step(res);
|
||||
|
||||
if (step == SQLITE_ROW) {
|
||||
if (step == SQLITE_ROW) {
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
return 1;
|
||||
sqlite3_finalize(res);
|
||||
sqlite3_close(db);
|
||||
return 1;
|
||||
}
|
||||
|
||||
struct user_record *new_user(int socket) {
|
||||
struct user_record *new_user() {
|
||||
char buffer[256];
|
||||
struct user_record *user;
|
||||
int done = 0;
|
||||
@ -419,24 +415,24 @@ struct user_record *new_user(int socket) {
|
||||
int i;
|
||||
|
||||
user = (struct user_record *)malloc(sizeof(struct user_record));
|
||||
s_putstring(socket, "\r\n\r\n");
|
||||
s_displayansi(socket, "newuser");
|
||||
s_printf("\r\n\r\n");
|
||||
s_displayansi("newuser");
|
||||
|
||||
do {
|
||||
passok = 0;
|
||||
nameok = 0;
|
||||
do {
|
||||
s_putstring(socket, "\r\nWhat is your login name: ");
|
||||
s_readstring(socket, buffer, 16);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_printf("\r\nWhat is your login name: ");
|
||||
s_readstring(buffer, 16);
|
||||
s_printf("\r\n");
|
||||
if (strlen(buffer) < 3) {
|
||||
s_putstring(socket, "Sorry, that name is too short.\r\n");
|
||||
s_printf("Sorry, that name is too short.\r\n");
|
||||
continue;
|
||||
}
|
||||
|
||||
for (i=0;i<strlen(buffer);i++) {
|
||||
if (!(tolower(buffer[i]) >= 97 && tolower(buffer[i]) <= 122)) {
|
||||
s_putstring(socket, "Sorry, invalid character, can only use alpha characters.\r\n");
|
||||
s_printf("Sorry, invalid character, can only use alpha characters.\r\n");
|
||||
nameok = 1;
|
||||
break;
|
||||
}
|
||||
@ -446,80 +442,80 @@ struct user_record *new_user(int socket) {
|
||||
continue;
|
||||
}
|
||||
if (strcasecmp(buffer, "unknown") == 0) {
|
||||
s_putstring(socket, "Sorry, that name is reserved.\r\n");
|
||||
s_printf("Sorry, that name is reserved.\r\n");
|
||||
continue;
|
||||
}
|
||||
if (strcasecmp(buffer, "all") == 0) {
|
||||
s_putstring(socket, "Sorry, that name is reserved.\r\n");
|
||||
s_printf("Sorry, that name is reserved.\r\n");
|
||||
continue;
|
||||
}
|
||||
if (strcasecmp(buffer, "new") == 0) {
|
||||
s_putstring(socket, "Sorry, that name is reserved.\r\n");
|
||||
s_printf("Sorry, that name is reserved.\r\n");
|
||||
continue;
|
||||
}
|
||||
user->loginname = strdup(buffer);
|
||||
nameok = check_user(user->loginname);
|
||||
if (!nameok) {
|
||||
s_putstring(socket, "Sorry, that name is in use.\r\n");
|
||||
s_printf("Sorry, that name is in use.\r\n");
|
||||
free(user->loginname);
|
||||
memset(buffer, 0, 256);
|
||||
}
|
||||
} while (!nameok);
|
||||
s_putstring(socket, "What is your first name: ");
|
||||
s_printf("What is your first name: ");
|
||||
memset(buffer, 0, 256);
|
||||
s_readstring(socket, buffer, 32);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_readstring(buffer, 32);
|
||||
s_printf("\r\n");
|
||||
user->firstname = strdup(buffer);
|
||||
|
||||
s_putstring(socket, "What is your last name: ");
|
||||
s_printf("What is your last name: ");
|
||||
memset(buffer, 0, 256);
|
||||
s_readstring(socket, buffer, 32);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_readstring(buffer, 32);
|
||||
s_printf("\r\n");
|
||||
user->lastname = strdup(buffer);
|
||||
|
||||
s_putstring(socket, "What is your e-mail address: ");
|
||||
s_printf("What is your e-mail address: ");
|
||||
memset(buffer, 0, 256);
|
||||
s_readstring(socket, buffer, 64);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_readstring(buffer, 64);
|
||||
s_printf("\r\n");
|
||||
user->email = strdup(buffer);
|
||||
|
||||
s_putstring(socket, "Where are you located: ");
|
||||
s_printf("Where are you located: ");
|
||||
memset(buffer, 0, 256);
|
||||
s_readstring(socket, buffer, 32);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_readstring(buffer, 32);
|
||||
s_printf("\r\n");
|
||||
user->location = strdup(buffer);
|
||||
|
||||
do {
|
||||
s_putstring(socket, "What password would you like (at least 8 characters): ");
|
||||
s_printf("What password would you like (at least 8 characters): ");
|
||||
memset(buffer, 0, 256);
|
||||
s_readstring(socket, buffer, 16);
|
||||
s_putstring(socket, "\r\n");
|
||||
s_readstring(buffer, 16);
|
||||
s_printf("\r\n");
|
||||
if (strlen(buffer) >= 8) {
|
||||
passok = 1;
|
||||
} else {
|
||||
s_putstring(socket, "Password too short!\r\n");
|
||||
s_printf("Password too short!\r\n");
|
||||
}
|
||||
} while (!passok);
|
||||
gen_salt(&user->salt);
|
||||
user->password = hash_sha256(buffer, user->salt);
|
||||
|
||||
s_putstring(socket, "You Entered:\r\n");
|
||||
s_putstring(socket, "-------------------------------------\r\n");
|
||||
s_putstring(socket, "Login Name: ");
|
||||
s_putstring(socket, user->loginname);
|
||||
s_putstring(socket, "\r\nFirst Name: ");
|
||||
s_putstring(socket, user->firstname);
|
||||
s_putstring(socket, "\r\nLast Name: ");
|
||||
s_putstring(socket, user->lastname);
|
||||
s_putstring(socket, "\r\nE-mail: ");
|
||||
s_putstring(socket, user->email);
|
||||
s_putstring(socket, "\r\nLocation: ");
|
||||
s_putstring(socket, user->location);
|
||||
s_putstring(socket, "\r\n-------------------------------------\r\n");
|
||||
s_putstring(socket, "Is this Correct? (Y/N)");
|
||||
c = s_getchar(socket);
|
||||
s_printf("You Entered:\r\n");
|
||||
s_printf("-------------------------------------\r\n");
|
||||
s_printf("Login Name: ");
|
||||
s_printf(user->loginname);
|
||||
s_printf("\r\nFirst Name: ");
|
||||
s_printf(user->firstname);
|
||||
s_printf("\r\nLast Name: ");
|
||||
s_printf(user->lastname);
|
||||
s_printf("\r\nE-mail: ");
|
||||
s_printf(user->email);
|
||||
s_printf("\r\nLocation: ");
|
||||
s_printf(user->location);
|
||||
s_printf("\r\n-------------------------------------\r\n");
|
||||
s_printf("Is this Correct? (Y/N)");
|
||||
c = s_getchar();
|
||||
while (tolower(c) != 'y' && tolower(c) != 'n') {
|
||||
c = s_getchar(socket);
|
||||
c = s_getchar();
|
||||
}
|
||||
|
||||
if (tolower(c) == 'y') {
|
||||
|
Reference in New Issue
Block a user