This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.
magicka/bbs_list.c

225 lines
5.5 KiB
C
Raw Normal View History

2016-03-25 10:21:28 +00:00
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sqlite3.h>
#include <ctype.h>
#include "bbs.h"
extern struct bbs_config conf;
extern int mynode;
2016-08-06 04:36:36 +00:00
void add_bbs(struct user_record *user) {
2016-03-25 10:21:28 +00:00
char *create_sql = "CREATE TABLE IF NOT EXISTS bbslist ("
"id INTEGER PRIMARY KEY,"
"bbsname TEXT,"
"sysop TEXT,"
"telnet TEXT,"
"owner INTEGER);";
2016-03-25 10:21:28 +00:00
char *insert_sql = "INSERT INTO bbslist (bbsname, sysop, telnet, owner) VALUES(?,?, ?, ?)";
char bbsname[19];
char sysop[17];
char telnet[39];
char buffer[256];
char c;
char *err_msg = 0;
2016-03-25 10:21:28 +00:00
sqlite3 *db;
sqlite3_stmt *res;
int rc;
2016-08-06 04:36:36 +00:00
s_printf("\r\n\e[1;37mEnter the BBS Name: \e[0m");
s_readstring(bbsname, 18);
2016-08-06 04:36:36 +00:00
s_printf("\r\n\e[1;37mEnter the Sysop's Name: \e[0m");
s_readstring(sysop, 16);
2016-08-06 04:36:36 +00:00
s_printf("\r\n\e[1;37mEnter the Telnet URL: \e[0m");
s_readstring(telnet, 38);
2016-08-06 04:36:36 +00:00
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) :");
2016-08-06 04:36:36 +00:00
c = s_getc();
2016-03-25 10:21:28 +00:00
if (tolower(c) == 'y') {
sprintf(buffer, "%s/bbslist.sq3", conf.bbs_path);
2016-03-25 10:21:28 +00:00
rc = sqlite3_open(buffer, &db);
2016-03-25 10:21:28 +00:00
if (rc != SQLITE_OK) {
dolog("Cannot open database: %s", sqlite3_errmsg(db));
2016-03-25 10:21:28 +00:00
sqlite3_close(db);
2016-03-25 10:21:28 +00:00
exit(1);
}
2016-03-25 10:21:28 +00:00
rc = sqlite3_exec(db, create_sql, 0, 0, &err_msg);
if (rc != SQLITE_OK ) {
dolog("SQL error: %s", err_msg);
sqlite3_free(err_msg);
2016-03-25 10:21:28 +00:00
sqlite3_close(db);
2016-03-25 10:21:28 +00:00
return;
}
2016-03-25 10:21:28 +00:00
rc = sqlite3_prepare_v2(db, insert_sql, -1, &res, 0);
if (rc == SQLITE_OK) {
2016-03-25 10:21:28 +00:00
sqlite3_bind_text(res, 1, bbsname, -1, 0);
sqlite3_bind_text(res, 2, sysop, -1, 0);
sqlite3_bind_text(res, 3, telnet, -1, 0);
sqlite3_bind_int(res, 4, user->id);
2016-03-25 10:21:28 +00:00
} else {
dolog("Failed to execute statement: %s", sqlite3_errmsg(db));
2016-03-25 10:21:28 +00:00
}
2016-03-25 10:21:28 +00:00
rc = sqlite3_step(res);
2016-03-25 10:21:28 +00:00
if (rc != SQLITE_DONE) {
dolog("execution failed: %s", sqlite3_errmsg(db));
sqlite3_close(db);
2016-03-25 10:21:28 +00:00
exit(1);
}
sqlite3_finalize(res);
sqlite3_close(db);
2016-08-06 04:36:36 +00:00
s_printf("\r\n\e[1;32mAdded!\e[0m\r\n");
2016-03-25 10:21:28 +00:00
} else {
2016-08-06 04:36:36 +00:00
s_printf("\r\n\e[1;31mAborted!\e[0m\r\n");
2016-03-25 10:21:28 +00:00
}
}
2016-08-06 04:36:36 +00:00
void delete_bbs(struct user_record *user) {
2016-03-25 10:21:28 +00:00
char buffer[256];
sqlite3 *db;
2016-08-06 04:36:36 +00:00
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;
2016-08-06 04:36:36 +00:00
s_printf("\r\nPlease enter the id of the BBS you want to delete: ");
s_readstring(buffer, 5);
i = atoi(buffer);
2016-08-06 04:36:36 +00:00
sprintf(buffer, "%s/bbslist.sq3", conf.bbs_path);
2016-08-06 04:36:36 +00:00
rc = sqlite3_open(buffer, &db);
2016-03-25 10:21:28 +00:00
if (rc != SQLITE_OK) {
return;
}
2016-08-06 04:36:36 +00:00
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
2016-03-25 10:21:28 +00:00
if (rc == SQLITE_OK) {
sqlite3_bind_int(res, 1, i);
sqlite3_bind_int(res, 2, user->id);
} else {
sqlite3_close(db);
2016-08-06 04:36:36 +00:00
s_printf("\r\nThere are no BBSes in the list yet!\r\n");
2016-03-25 10:21:28 +00:00
return;
}
if (sqlite3_step(res) == SQLITE_ROW) {
2016-08-06 04:36:36 +00:00
s_printf("\r\nAre you sure you want to delete %s?\r\n", sqlite3_column_text(res, 0));
2016-03-25 10:21:28 +00:00
sqlite3_finalize(res);
2016-08-06 04:36:36 +00:00
c = s_getc();
2016-03-25 10:21:28 +00:00
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);
2016-08-06 04:36:36 +00:00
s_printf("\r\nThere are no BBSes in the list yet!\r\n");
2016-03-25 10:21:28 +00:00
return;
}
sqlite3_step(res);
2016-08-06 04:36:36 +00:00
s_printf("\r\n\e[1;32mDeleted!\e[0m\r\n");
2016-03-25 10:21:28 +00:00
sqlite3_finalize(res);
} else {
2016-08-06 04:36:36 +00:00
s_printf("\r\n\e[1;32mAborted!\e[0m\r\n");
2016-03-25 10:21:28 +00:00
}
} else {
sqlite3_finalize(res);
2016-08-06 04:36:36 +00:00
s_printf("\r\nThat BBS entry either doesn't exist or wasn't created by you.\r\n");
2016-03-25 10:21:28 +00:00
}
sqlite3_close(db);
}
2016-08-06 04:36:36 +00:00
void list_bbses() {
2016-03-25 10:21:28 +00:00
char buffer[256];
sqlite3 *db;
2016-08-06 04:36:36 +00:00
sqlite3_stmt *res;
int rc;
char *sql = "SELECT id,bbsname,sysop,telnet FROM bbslist";
int i;
2016-08-06 04:36:36 +00:00
sprintf(buffer, "%s/bbslist.sq3", conf.bbs_path);
2016-08-06 04:36:36 +00:00
rc = sqlite3_open(buffer, &db);
2016-03-25 10:21:28 +00:00
if (rc != SQLITE_OK) {
dolog("Cannot open database: %s", sqlite3_errmsg(db));
2016-03-25 10:21:28 +00:00
sqlite3_close(db);
exit(1);
}
rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
if (rc != SQLITE_OK) {
sqlite3_close(db);
2016-08-06 04:36:36 +00:00
s_printf("\r\nThere are no BBSes in the list yet!\r\n");
2016-03-25 10:21:28 +00:00
return;
}
i = 0;
2016-08-06 04:36:36 +00:00
s_printf("\r\n\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
2016-03-25 10:21:28 +00:00
while (sqlite3_step(res) == SQLITE_ROW) {
2016-08-06 04:36:36 +00:00
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));
2016-03-25 10:21:28 +00:00
i++;
if (i == 20) {
2016-08-06 04:36:36 +00:00
s_printf("Press any key to continue...\r\n");
s_getc();
2016-03-25 10:21:28 +00:00
i = 0;
}
2016-03-25 10:21:28 +00:00
}
2016-08-06 04:36:36 +00:00
s_printf("\e[1;30m-------------------------------------------------------------------------------\e[0m\r\n");
sqlite3_finalize(res);
sqlite3_close(db);
2016-08-06 04:36:36 +00:00
s_printf("Press any key to continue...\r\n");
s_getc();
2016-03-25 10:21:28 +00:00
}
2016-08-06 04:36:36 +00:00
void bbs_list(struct user_record *user) {
2016-03-25 10:21:28 +00:00
int doquit = 0;
char c;
2016-03-25 10:21:28 +00:00
while(!doquit) {
2016-08-06 04:36:36 +00:00
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");
2016-08-06 04:36:36 +00:00
c = s_getc();
2016-03-25 10:21:28 +00:00
switch(tolower(c)) {
case 'l':
2016-08-06 04:36:36 +00:00
list_bbses();
2016-03-25 10:21:28 +00:00
break;
case 'a':
2016-08-06 04:36:36 +00:00
add_bbs(user);
2016-03-25 10:21:28 +00:00
break;
case 'd':
2016-08-06 04:36:36 +00:00
delete_bbs(user);
2016-03-25 10:21:28 +00:00
break;
case 'q':
doquit = 1;
break;
}
}
}