--- lbbs/src/init.c 2004/10/18 08:44:54 1.2 +++ lbbs/src/init.c 2004/10/20 07:46:32 1.5 @@ -1,5 +1,5 @@ /*************************************************************************** - bbsd.c - description + init.c - description ------------------- begin : Mon Oct 18 2004 copyright : (C) 2004 by Leaflet @@ -15,8 +15,8 @@ * * ***************************************************************************/ +#include "bbs.h" #include "common.h" -#include void init_daemon (void) @@ -38,10 +38,90 @@ init_daemon (void) for (i = 0; i < NOFILE; ++i) close (i); - chdir ("/tmp"); + chdir (app_home_dir); umask (0); signal (SIGCHLD, SIG_IGN); return; } + +int +load_conf (const char *conf_file) +{ + char temp[256]; + + // Load configuration + char c_name[256]; + FILE *fin; + + if ((fin = fopen (conf_file, "r")) == NULL) + { + log_error ("Open bbsd.conf failed"); + return -1; + } + + while (fscanf (fin, "%s", c_name) != EOF) + { + if (c_name[0] == '#') + { + fgets(temp, 256, fin); + continue; + } + fscanf (fin, "%*c"); + if (strcmp (c_name, "bbs_id") == 0) + { + fscanf (fin, "%s", BBS_id); + } + if (strcmp (c_name, "bbs_name") == 0) + { + fscanf (fin, "%s", BBS_name); + } + if (strcmp (c_name, "bbs_server") == 0) + { + fscanf (fin, "%s", BBS_server); + } + if (strcmp (c_name, "bbs_address") == 0) + { + fscanf (fin, "%s", BBS_address); + } + if (strcmp (c_name, "bbs_port") == 0) + { + fscanf (fin, "%ud", &BBS_port); + } + if (strcmp (c_name, "bbs_max_client") == 0) + { + fscanf (fin, "%d", &BBS_max_client); + } + if (strcmp (c_name, "bbs_max_user") == 0) + { + fscanf (fin, "%d", &BBS_max_user); + } + if (strcmp (c_name, "bbs_start_dt") == 0) + { + int y = 0, m = 0, d = 0; + fscanf (fin, "%d-%d-%d", &y, &m, &d); + sprintf (BBS_start_dt, "%4dÄê%2dÔÂ%2dÈÕ",y,m,d); + } + if (strcmp (c_name, "db_host") == 0) + { + fscanf (fin, "%s", DB_host); + } + if (strcmp (c_name, "db_username") == 0) + { + fscanf (fin, "%s", DB_username); + } + if (strcmp (c_name, "db_password") == 0) + { + fscanf (fin, "%s", DB_password); + } + if (strcmp (c_name, "db_database") == 0) + { + fscanf (fin, "%s", DB_database); + } + } + + fclose (fin); + + return 0; +}