4 * This module handles states which are global to the entire server.
25 #include "sysdep_decls.h"
32 struct CitControl CitControl;
34 FILE *control_fp = NULL;
37 * get_control - read the control record into memory.
39 void get_control(void) {
41 /* Zero it out. If the control record on disk is missing or short,
42 * the system functions with all control record fields initialized
45 memset(&CitControl, 0, sizeof(struct CitControl));
46 if (control_fp == NULL)
47 control_fp = fopen("citadel.control", "rb+");
48 if (control_fp == NULL) {
49 control_fp = fopen("citadel.control", "wb+");
50 if (control_fp != NULL) {
51 memset(&CitControl, 0, sizeof(struct CitControl));
52 fwrite(&CitControl, sizeof(struct CitControl),
57 if (control_fp == NULL) {
58 lprintf(1, "ERROR opening citadel.control: %s\n",
64 fread(&CitControl, sizeof(struct CitControl), 1, control_fp);
68 * put_control - write the control record to disk.
70 void put_control(void) {
72 if (control_fp != NULL) {
74 fwrite(&CitControl, sizeof(struct CitControl), 1, control_fp);
81 * get_new_message_number() - Obtain a new, unique ID to be used for a message.
83 long get_new_message_number(void) {
84 begin_critical_section(S_CONTROL);
86 ++CitControl.MMhighest;
88 end_critical_section(S_CONTROL);
89 return(CitControl.MMhighest);
94 * get_new_user_number() - Obtain a new, unique ID to be used for a user.
96 long get_new_user_number(void) {
97 begin_critical_section(S_CONTROL);
99 ++CitControl.MMnextuser;
101 end_critical_section(S_CONTROL);
102 return(CitControl.MMnextuser);
108 * get_new_room_number() - Obtain a new, unique ID to be used for a room.
110 long get_new_room_number(void) {
111 begin_critical_section(S_CONTROL);
113 ++CitControl.MMnextroom;
115 end_critical_section(S_CONTROL);
116 return(CitControl.MMnextroom);
122 * Get or set global configuration options
124 void cmd_conf(char *argbuf) {
129 if (!(CC->logged_in)) {
130 cprintf("%d Not logged in.\n",ERROR+NOT_LOGGED_IN);
134 if (CC->usersupp.axlevel < 6) {
135 cprintf("%d Higher access required.\n",
136 ERROR+HIGHER_ACCESS_REQUIRED);
140 extract(cmd, argbuf, 0);
141 if (!strcasecmp(cmd, "GET")) {
142 cprintf("%d Configuration...\n", LISTING_FOLLOWS);
143 cprintf("%s\n", config.c_nodename);
144 cprintf("%s\n", config.c_fqdn);
145 cprintf("%s\n", config.c_humannode);
146 cprintf("%s\n", config.c_phonenum);
147 cprintf("%d\n", config.c_creataide);
148 cprintf("%d\n", config.c_sleeping);
149 cprintf("%d\n", config.c_initax);
150 cprintf("%d\n", config.c_regiscall);
151 cprintf("%d\n", config.c_twitdetect);
152 cprintf("%s\n", config.c_twitroom);
153 cprintf("%s\n", config.c_moreprompt);
154 cprintf("%d\n", config.c_restrict);
155 cprintf("%s\n", config.c_bbs_city);
156 cprintf("%s\n", config.c_sysadm);
157 cprintf("%d\n", config.c_maxsessions);
158 cprintf("%s\n", config.c_net_password);
159 cprintf("%d\n", config.c_userpurge);
160 cprintf("%d\n", config.c_roompurge);
161 cprintf("%s\n", config.c_logpages);
162 cprintf("%d\n", config.c_createax);
163 cprintf("%d\n", config.c_maxmsglen);
167 else if (!strcasecmp(cmd, "SET")) {
168 cprintf("%d Send configuration...\n", SEND_LISTING);
170 while (client_gets(buf), strcmp(buf, "000")) {
172 case 0: safestrncpy(config.c_nodename, buf,
173 sizeof config.c_nodename);
175 case 1: safestrncpy(config.c_fqdn, buf,
176 sizeof config.c_fqdn);
178 case 2: safestrncpy(config.c_humannode, buf,
179 sizeof config.c_humannode);
181 case 3: safestrncpy(config.c_phonenum, buf,
182 sizeof config.c_phonenum);
184 case 4: config.c_creataide = atoi(buf);
186 case 5: config.c_sleeping = atoi(buf);
188 case 6: config.c_initax = atoi(buf);
189 if (config.c_initax < 1) config.c_initax = 1;
190 if (config.c_initax > 6) config.c_initax = 6;
192 case 7: config.c_regiscall = atoi(buf);
193 if (config.c_regiscall != 0)
194 config.c_regiscall = 1;
196 case 8: config.c_twitdetect = atoi(buf);
197 if (config.c_twitdetect != 0)
198 config.c_twitdetect = 1;
200 case 9: safestrncpy(config.c_twitroom, buf,
201 sizeof config.c_twitroom);
203 case 10: safestrncpy(config.c_moreprompt, buf,
204 sizeof config.c_moreprompt);
206 case 11: config.c_restrict = atoi(buf);
207 if (config.c_restrict != 0)
208 config.c_restrict = 1;
210 case 12: safestrncpy(config.c_bbs_city, buf,
211 sizeof config.c_bbs_city);
213 case 13: safestrncpy(config.c_sysadm, buf,
214 sizeof config.c_sysadm);
216 case 14: config.c_maxsessions = atoi(buf);
217 if (config.c_maxsessions < 1)
218 config.c_maxsessions = 1;
220 case 15: safestrncpy(config.c_net_password, buf,
221 sizeof config.c_net_password);
223 case 16: config.c_userpurge = atoi(buf);
225 case 17: config.c_roompurge = atoi(buf);
227 case 18: safestrncpy(config.c_logpages, buf,
228 sizeof config.c_logpages);
230 case 19: config.c_createax = atoi(buf);
231 if (config.c_createax < 1)
232 config.c_createax = 1;
233 if (config.c_createax > 6)
234 config.c_createax = 6;
236 case 20: if (atoi(buf) >= 8192)
237 config.c_maxmsglen = atoi(buf);
243 snprintf(buf,sizeof buf,
244 "Global system configuration edited by %s\n",
248 if (strlen(config.c_logpages) > 0)
249 create_room(config.c_logpages, 4, "", 0);
253 cprintf("%d The only valid options are GET and SET.\n",
254 ERROR+ILLEGAL_VALUE);