More work on Mail, and New System Info

This commit is contained in:
Andrew Pamment 2016-03-23 10:14:31 +10:00
parent 2a5a18bc8b
commit 76e2fc999f
3 changed files with 289 additions and 112 deletions

52
bbs.c
View File

@ -7,6 +7,7 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/fcntl.h> #include <sys/fcntl.h>
#include <signal.h> #include <signal.h>
#include <sys/utsname.h>
#include "inih/ini.h" #include "inih/ini.h"
#include "bbs.h" #include "bbs.h"
@ -187,6 +188,14 @@ char s_getchar(int socket) {
disconnect(socket); disconnect(socket);
} }
} }
if (c == '\r' || c == '\n') {
len = read(socket, &c, 1);
if (len == 0) {
disconnect(socket);
}
}
usertimeout = 10; usertimeout = 10;
return (char)c; return (char)c;
} }
@ -202,6 +211,8 @@ void s_readstring(int socket, char *buffer, int max) {
int i; int i;
char c; char c;
memset(buffer, 0, max);
for (i=0;i<max;i++) { for (i=0;i<max;i++) {
c = s_getchar(socket); c = s_getchar(socket);
if ((c == '\b' || c == 127) && i > 0) { if ((c == '\b' || c == 127) && i > 0) {
@ -212,7 +223,6 @@ void s_readstring(int socket, char *buffer, int max) {
} }
if (c == '\n' || c == '\r') { if (c == '\n' || c == '\r') {
c = s_getchar(socket);
return; return;
} }
s_putchar(socket, c); s_putchar(socket, c);
@ -236,7 +246,6 @@ void s_readpass(int socket, char *buffer, int max) {
} }
if (c == '\n' || c == '\r') { if (c == '\n' || c == '\r') {
c = s_getchar(socket);
return; return;
} }
s_putchar(socket, '*'); s_putchar(socket, '*');
@ -256,6 +265,39 @@ void disconnect(int socket) {
exit(0); exit(0);
} }
void display_info(int socket) {
char buffer[256];
struct utsname name;
int mailwaiting;
mailwaiting = mail_getemailcount(gUser);
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;32mMail Waiting: \e[1;37m%d\r\n", mailwaiting);
s_putstring(socket, buffer);
sprintf(buffer, "\e[1;30m----------------------------------------------\e[0m\r\n");
s_putstring(socket, buffer);
sprintf(buffer, "Press any key to continue...\r\n");
s_putstring(socket, buffer);
s_getc(socket);
}
void runbbs(int socket, char *config_path) { void runbbs(int socket, char *config_path) {
char buffer[256]; char buffer[256];
char password[17]; char password[17];
@ -403,6 +445,12 @@ void runbbs(int socket, char *config_path) {
} }
gUser = user; gUser = user;
// bulletins
// external login cmd
// display info
display_info(socket);
// main menu // main menu
main_menu(socket, user); main_menu(socket, user);

2
bbs.h
View File

@ -70,6 +70,7 @@ extern char s_getchar(int socket);
extern void s_readstring(int socket, char *buffer, int max); extern void s_readstring(int socket, char *buffer, int max);
extern char s_getc(int socket); extern char s_getc(int socket);
extern void disconnect(int socket); extern void disconnect(int socket);
extern void display_info(int socket);
extern int save_user(struct user_record *user); extern int save_user(struct user_record *user);
extern int check_user(char *loginname); extern int check_user(char *loginname);
@ -79,5 +80,6 @@ extern struct user_record *check_user_pass(int socket, char *loginname, char *pa
extern void main_menu(int socket, struct user_record *user); extern void main_menu(int socket, struct user_record *user);
extern int mail_getemailcount(struct user_record *user);
extern int mail_menu(int socket, struct user_record *user); extern int mail_menu(int socket, struct user_record *user);
#endif #endif

View File

@ -42,6 +42,7 @@ char *editor(int socket, char *quote, char *from) {
char **quotecontent; char **quotecontent;
int lineat=0; int lineat=0;
int qfrom,qto; int qfrom,qto;
int z;
if (quote != NULL) { if (quote != NULL) {
for (i=0;i<strlen(quote);i++) { for (i=0;i<strlen(quote);i++) {
@ -57,17 +58,18 @@ char *editor(int socket, char *quote, char *from) {
sprintf(quotecontent[quotelines], "%c> %s", from[0], linebuffer); sprintf(quotecontent[quotelines], "%c> %s", from[0], linebuffer);
quotelines++; quotelines++;
lineat = 0; lineat = 0;
linebuffer[0] = '\0';
} else { } else {
linebuffer[lineat++] = quote[i]; linebuffer[lineat++] = quote[i];
linebuffer[lineat] = '\0'; linebuffer[lineat] = '\0';
} }
} }
} }
s_putstring(socket, "\r\nMagicka Internal Editor, Type /S to Save, /A to abort and /? for help\r\n"); 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, "-------------------------------------------------------------------------------"); s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m");
while(!doquit) { while(!doquit) {
sprintf(prompt, "\r\n[%3d]: ", lines); sprintf(prompt, "\r\n\e[1;30m[\e[1;34m%3d\e[1;30m]: \e[0m", lines);
s_putstring(socket, prompt); s_putstring(socket, prompt);
s_readstring(socket, linebuffer, 70); s_readstring(socket, linebuffer, 70);
if (linebuffer[0] == '/') { if (linebuffer[0] == '/') {
@ -113,7 +115,7 @@ char *editor(int socket, char *quote, char *from) {
} else { } else {
s_putstring(socket, "\r\n"); s_putstring(socket, "\r\n");
for (i=0;i<quotelines;i++) { for (i=0;i<quotelines;i++) {
sprintf(buffer, "[%3d] %s\r\n", i, quotecontent[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_putstring(socket, buffer);
} }
@ -146,26 +148,92 @@ char *editor(int socket, char *quote, char *from) {
lines++; lines++;
} }
s_putstring(socket, "\r\nMagicka Internal Editor, Type /S to Save, /A to abort and /? for help\r\n"); 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, "-------------------------------------------------------------------------------\r\n"); s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m");
for (i=0;i<lines;i++) { for (i=0;i<lines;i++) {
sprintf(buffer, "[%3d]: %s\r\n", i, content[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_putstring(socket, buffer);
} }
} }
} else if (toupper(linebuffer[1]) == 'L') { } else if (toupper(linebuffer[1]) == 'L') {
s_putstring(socket, "\r\nMagicka Internal Editor, Type /S to Save, /A to abort and /? for help\r\n"); 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, "-------------------------------------------------------------------------------\r\n"); s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m");
for (i=0;i<lines;i++) { for (i=0;i<lines;i++) {
sprintf(buffer, "[%3d]: %s\r\n", i, content[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_putstring(socket, buffer);
} }
} else if (linebuffer[1] == '?') { } else if (linebuffer[1] == '?') {
s_putstring(socket, "\r\nHELP\r\n"); s_putstring(socket, "\e[1;33m\r\nHELP\r\n");
s_putstring(socket, "/S - Save Message\r\n"); s_putstring(socket, "/S - Save Message\r\n");
s_putstring(socket, "/A - Abort Message\r\n"); s_putstring(socket, "/A - Abort Message\r\n");
s_putstring(socket, "/Q - Quote Message\r\n"); s_putstring(socket, "/Q - Quote Message\r\n");
s_putstring(socket, "/L - Relist 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");
} else if (toupper(linebuffer[1]) == 'D') {
s_putstring(socket, "\r\nWhich line do you want to delete? ");
s_readstring(socket, buffer, 6);
if (strlen(buffer) == 0) {
s_putstring(socket, "\r\nAborted...\r\n");
} else {
z = atoi(buffer);
if (z < 0 || z >= lines) {
s_putstring(socket, "\r\nAborted...\r\n");
} else {
for (i=z;i<lines-1;i++) {
free(content[i]);
content[i] = strdup(content[i+1]);
}
free(content[i]);
lines--;
content = (char **)realloc(content, sizeof(char *) * lines);
}
}
} else if (toupper(linebuffer[1]) == 'E') {
s_putstring(socket, "\r\nWhich line do you want to edit? ");
s_readstring(socket, buffer, 6);
if (strlen(buffer) == 0) {
s_putstring(socket, "\r\nAborted...\r\n");
} else {
z = atoi(buffer);
if (z < 0 || z >= lines) {
s_putstring(socket, "\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);
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);
if (strlen(buffer) == 0) {
s_putstring(socket, "\r\nAborted...\r\n");
} else {
z = atoi(buffer);
if (z < 0 || z >= lines) {
s_putstring(socket, "\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);
lines++;
content = (char **)realloc(content, sizeof(char *) * lines);
for (i=lines;i>z;i--) {
content[i] = content[i-1];
}
content[z] = strdup(linebuffer);
}
}
} }
} else { } else {
if (lines == 0) { if (lines == 0) {
@ -196,6 +264,7 @@ void read_message(int socket, struct user_record *user, int mailno) {
s_JamSubfield jsf; s_JamSubfield jsf;
char buffer[256]; char buffer[256];
int z; int z;
struct tm msg_date;
char *subject = NULL; char *subject = NULL;
char *from = NULL; char *from = NULL;
@ -233,13 +302,21 @@ void read_message(int socket, struct user_record *user, int mailno) {
memcpy(to, jsp->Fields[z]->Buffer, jsp->Fields[z]->DatLen); memcpy(to, jsp->Fields[z]->Buffer, jsp->Fields[z]->DatLen);
} }
} }
sprintf(buffer, "\e[2JFrom : %s\r\n", from);
sprintf(buffer, "\e[2J\e[1;32mFrom : \e[1;37m%s\r\n", from);
s_putstring(socket, buffer); s_putstring(socket, buffer);
sprintf(buffer, "To : %s\r\n", to); sprintf(buffer, "\e[1;32mTo : \e[1;37m%s\r\n", to);
s_putstring(socket, buffer); s_putstring(socket, buffer);
sprintf(buffer, "Subject : %s\r\n", subject); sprintf(buffer, "\e[1;32mSubject : \e[1;37m%s\r\n", subject);
s_putstring(socket, buffer); s_putstring(socket, buffer);
s_putstring(socket, "-------------------------------------------------------------------------------\r\n"); localtime_r((time_t *)&jmh.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);
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
body = (char *)malloc(jmh.TxtLen); body = (char *)malloc(jmh.TxtLen);
@ -523,14 +600,14 @@ int mail_menu(int socket, struct user_record *user) {
break; break;
} else { } else {
JAM_ReadMBHeader(jb, &jbh); JAM_ReadMBHeader(jb, &jbh);
if (jbh.ActiveMsgs > 0) {
sprintf(buffer, "Start at message [0-%d] ? ", jbh.ActiveMsgs - 1); sprintf(buffer, "Start at message [0-%d] ? ", jbh.ActiveMsgs - 1);
s_putstring(socket, buffer); s_putstring(socket, buffer);
s_readstring(socket, buffer, 6); s_readstring(socket, buffer, 6);
i = atoi(buffer); i = atoi(buffer);
closed = 0; closed = 0;
s_putstring(socket, "\r\n"); s_putstring(socket, "\e[2J\e[1;37;44m[MSG#] Subject From To Date \r\n\e[0m");
for (j=i;j<jbh.ActiveMsgs;j++) { for (j=i;j<jbh.ActiveMsgs;j++) {
z = JAM_ReadMsgHeader(jb, j, &jmh, &jsp); z = JAM_ReadMsgHeader(jb, j, &jmh, &jsp);
if (z != 0) { if (z != 0) {
@ -571,7 +648,7 @@ int mail_menu(int socket, struct user_record *user) {
localtime_r((time_t *)&jmh.DateWritten, &msg_date); localtime_r((time_t *)&jmh.DateWritten, &msg_date);
sprintf(buffer, "[%4d] %-25s %-15s %-15s %02d:%02d %02d-%02d-%02d\r\n", j, subject, from, to, msg_date.tm_hour, msg_date.tm_min, msg_date.tm_mday, msg_date.tm_mon + 1, msg_date.tm_year - 100); sprintf(buffer, "\e[1;30m[\e[1;34m%4d\e[1;30m] \e[1;37m%-25s \e[1;32m%-15s \e[1;33m%-15s \e[1;35m%02d:%02d %02d-%02d-%02d\e[0m\r\n", j, subject, from, 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); s_putstring(socket, buffer);
JAM_DelSubPacket(jsp); JAM_DelSubPacket(jsp);
if (subject != NULL) { if (subject != NULL) {
@ -618,6 +695,9 @@ int mail_menu(int socket, struct user_record *user) {
break; break;
} }
} }
} else {
s_putstring(socket, "\r\nThere is no mail in this area\r\n");
}
} }
if (closed == 0) { if (closed == 0) {
JAM_CloseMB(jb); JAM_CloseMB(jb);
@ -798,16 +878,19 @@ int mail_menu(int socket, struct user_record *user) {
lastmsg = 0; lastmsg = 0;
while (JAM_FindUser(jb, jam_crc, lastmsg, &currmsg) == 0) { while (JAM_FindUser(jb, jam_crc, lastmsg, &currmsg) == 0) {
if (JAM_ReadMsgHeader(jb, currmsg, &jmh, &jsp) != 0) { if (JAM_ReadMsgHeader(jb, currmsg, &jmh, &jsp) != 0) {
lastmsg = currmsg + 1;
continue; continue;
} }
if (jmh.Attribute & MSG_DELETED) { if (jmh.Attribute & MSG_DELETED) {
JAM_DelSubPacket(jsp); JAM_DelSubPacket(jsp);
lastmsg = currmsg + 1;
continue; continue;
} }
if (jmh.Attribute & MSG_NODISP) { if (jmh.Attribute & MSG_NODISP) {
JAM_DelSubPacket(jsp); JAM_DelSubPacket(jsp);
lastmsg = currmsg + 1;
continue; continue;
} }
subject = NULL; subject = NULL;
@ -833,7 +916,7 @@ int mail_menu(int socket, struct user_record *user) {
free(from); free(from);
} }
s_putstring(socket, buffer); s_putstring(socket, buffer);
JAM_DelSubPacket(jsp);
lastmsg = currmsg + 1; lastmsg = currmsg + 1;
} }
@ -884,14 +967,18 @@ int mail_menu(int socket, struct user_record *user) {
} }
if (strcasecmp(from, user->loginname) == 0) { if (strcasecmp(from, user->loginname) == 0) {
sprintf(buffer, "\e[2JFrom : %s\r\n", from); sprintf(buffer, "\e[2J\e[1;32mFrom : \e[1;37m%s\r\n", from);
s_putstring(socket, buffer); s_putstring(socket, buffer);
sprintf(buffer, "To : %s\r\n", to); sprintf(buffer, "\e[1;32mTo : \e[1;37m%s\r\n", to);
s_putstring(socket, buffer); s_putstring(socket, buffer);
sprintf(buffer, "Subject : %s\r\n", subject); sprintf(buffer, "\e[1;32mSubject : \e[1;37m%s\r\n", subject);
s_putstring(socket, buffer); s_putstring(socket, buffer);
s_putstring(socket, "-------------------------------------------------------------------------------\r\n"); localtime_r((time_t *)&jmh.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);
s_putstring(socket, "\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
body = (char *)malloc(jmh.TxtLen); body = (char *)malloc(jmh.TxtLen);
JAM_ReadMsgText(jb, jmh.TxtOffset, jmh.TxtLen, (uchar *)body); JAM_ReadMsgText(jb, jmh.TxtOffset, jmh.TxtLen, (uchar *)body);
@ -1060,3 +1147,43 @@ int mail_menu(int socket, struct user_record *user) {
return doquit; return doquit;
} }
int mail_getemailcount(struct user_record *user) {
s_JamBase *jb;
s_JamBaseHeader jbh;
s_JamMsgHeader jmh;
s_JamSubPacket* jsp;
s_JamSubfield jsf;
ulong jam_crc;
ulong lastmsg, currmsg;
int msg_count = 0;
jb = open_jam_base(conf.email_path);
if (!jb) {
printf("Error opening JAM base.. %s\n", conf.mail_conferences[user->cur_mail_conf]->mail_areas[user->cur_mail_area]->path);
} else {
jam_crc = JAM_Crc32((uchar *)user->loginname, strlen(user->loginname));
lastmsg = 0;
while (JAM_FindUser(jb, jam_crc, lastmsg, &currmsg) == 0) {
if (JAM_ReadMsgHeader(jb, currmsg, &jmh, &jsp) != 0) {
continue;
}
if (jmh.Attribute & MSG_DELETED) {
JAM_DelSubPacket(jsp);
continue;
}
if (jmh.Attribute & MSG_NODISP) {
JAM_DelSubPacket(jsp);
continue;
}
JAM_DelSubPacket(jsp);
msg_count++;
lastmsg = currmsg + 1;
}
JAM_CloseMB(jb);
}
return msg_count;
}