#include <limits.h>
#include "citadel.h"
#include "server.h"
-#include "serv_extensions.h"
#include "config.h"
struct config config;
-/* CTDLDIR */
-char ctdl_home_directory[PATH_MAX] = "";
-char ctdl_bio_dir[PATH_MAX]="bio";
-char ctdl_bb_dir[PATH_MAX]="bitbucket";
-char ctdl_data_dir[PATH_MAX]="data";
-char ctdl_file_dir[PATH_MAX]="files";
-char ctdl_hlp_dir[PATH_MAX]="help";
-char ctdl_image_dir[PATH_MAX]="images";
-char ctdl_info_dir[PATH_MAX]="info";
-char ctdl_key_dir[PATH_MAX]="keys";
-char ctdl_message_dir[PATH_MAX]="messages";
-char ctdl_usrpic_dir[PATH_MAX]="userpics";
-char ctdl_etc_dir[PATH_MAX]="";
-char ctdl_run_dir[PATH_MAX]="";
-char ctdl_spool_dir[PATH_MAX]="network";
-char ctdl_netout_dir[PATH_MAX]="network/spoolout";
-char ctdl_netin_dir[PATH_MAX]="network/spoolin";
-
-int home_specified = 0;
/*
* get_config() is called during the initialization of any program which
FILE *cfp;
struct stat st;
- if (chdir(home_specified ? ctdl_home_directory : CTDLDIR) != 0) {
+ if (chdir(ctdl_bbsbase_dir) != 0) {
fprintf(stderr,
"This program could not be started.\n"
"Unable to change directory to %s\n"
"Error: %s\n",
- (home_specified ? ctdl_home_directory : CTDLDIR),
+ ctdl_bbsbase_dir,
strerror(errno));
- exit(1);
+ exit(CTDLEXIT_HOME);
}
- cfp = fopen(
-#ifndef HAVE_ETC_DIR
- "."
-#else
- ETC_DIR
-#endif
- "/citadel.config", "rb");
+ cfp = fopen(file_citadel_config, "rb");
if (cfp == NULL) {
fprintf(stderr, "This program could not be started.\n"
- "Unable to open %s/citadel.config\n"
- "Error: %s\n",
- (home_specified ? ctdl_home_directory : CTDLDIR),
- strerror(errno));
- exit(1);
+ "Unable to open %s\n"
+ "Error: %s\n",
+ file_citadel_config,
+ strerror(errno));
+ exit(CTDLEXIT_CONFIG);
}
fread((char *) &config, sizeof(struct config), 1, cfp);
if (fstat(fileno(cfp), &st)) {
- perror("citadel.config");
- exit(1);
+ perror(file_citadel_config);
+ exit(CTDLEXIT_CONFIG);
}
#ifndef __CYGWIN__
- if (st.st_uid != CTDLUID || st.st_mode != (S_IFREG | S_IRUSR | S_IWUSR)) {
- fprintf(stderr, "check the permissions on citadel.config\n");
- exit(1);
+ if (st.st_uid != CTDLUID) {
+ fprintf(stderr, "%s must be owned by uid="F_UID_T" but "F_UID_T" owns it!\n",
+ file_citadel_config, CTDLUID, st.st_uid);
+ exit(CTDLEXIT_CONFIG);
+ }
+ int desired_mode = (S_IFREG | S_IRUSR | S_IWUSR) ;
+ if (st.st_mode != desired_mode) {
+ fprintf(stderr, "%s must be set to permissions mode %03o but they are %03o\n",
+ file_citadel_config, desired_mode, st.st_mode);
+ exit(CTDLEXIT_CONFIG);
}
#endif
fclose(cfp);
" Data files are currently at %d.%02d\n",
(config.c_setup_level / 100),
(config.c_setup_level % 100));
- exit(1);
+ exit(CTDLEXIT_OOD);
}
/* Default maximum message length is 10 megabytes. This is site
config.c_net_freq = 3600L; /* once per hour default */
if (config.c_net_freq < 300L)
config.c_net_freq = 300L;
+
+ /* "create new user" only works with native authentication mode */
+ if (config.c_auth_mode != AUTHMODE_NATIVE) {
+ config.c_disable_newu = 1;
+ }
}
{
FILE *cfp;
- if ((cfp = fopen(
-#ifndef HAVE_ETC_DIR
- "."
-#else
- ETC_DIR
-#endif
- "/citadel.config", "rb+")) == NULL)
- perror("citadel.config");
+ if ((cfp = fopen(file_citadel_config, "rb+")) == NULL)
+ perror(file_citadel_config);
else {
fwrite((char *) &config, sizeof(struct config), 1, cfp);
fclose(cfp);