4 * Transparently handle the upgrading of server data formats.
16 #include <sys/types.h>
18 #if TIME_WITH_SYS_TIME
19 # include <sys/time.h>
23 # include <sys/time.h>
34 #include "sysdep_decls.h"
35 #include "citserver.h"
39 #include "dynloader.h"
45 #include "serv_upgrade.h"
47 void do_pre555_usersupp_upgrade(void) {
48 struct pre555usersupp usbuf;
49 struct usersupp newus;
50 struct cdbdata *cdbus;
51 char tempfilename[PATH_MAX];
53 static char vcard[1024];
55 lprintf(5, "Upgrading user file\n");
58 lprintf(1, "%s\n", strerror(errno));
61 strcpy(tempfilename, tmpnam(NULL));
63 /* First, back out all old version records to a flat file */
64 cdb_rewind(CDB_USERSUPP);
65 while(cdbus = cdb_next_item(CDB_USERSUPP), cdbus != NULL) {
66 memset(&usbuf, 0, sizeof(struct pre555usersupp));
67 memcpy(&usbuf, cdbus->ptr,
68 ( (cdbus->len > sizeof(struct pre555usersupp)) ?
69 sizeof(struct pre555usersupp) : cdbus->len) );
71 fwrite(&usbuf, sizeof(struct pre555usersupp), 1, fp);
74 /* ...and overwrite the records with new format records */
76 while (fread(&usbuf, sizeof(struct pre555usersupp), 1, fp) > 0) {
77 if (strlen(usbuf.fullname) > 0) {
78 lprintf(9, "Upgrading <%s>\n", usbuf.fullname);
79 memset(&newus, 0, sizeof(struct usersupp));
81 newus.uid = usbuf.USuid;
82 strcpy(newus.password, usbuf.password);
83 newus.flags = usbuf.flags;
84 newus.timescalled = (long) usbuf.timescalled;
85 newus.posted = (long) usbuf.posted;
86 newus.axlevel = (CIT_UBYTE) usbuf.axlevel;
87 newus.usernum = (long) usbuf.usernum;
88 newus.lastcall = (long) usbuf.lastcall;
89 newus.USuserpurge = (int) usbuf.USuserpurge;
90 strcpy(newus.fullname, usbuf.fullname);
91 newus.USscreenwidth = (CIT_UBYTE) usbuf.USscreenwidth;
92 newus.USscreenheight = (CIT_UBYTE) usbuf.USscreenheight;
97 snprintf(vcard, sizeof vcard,
98 "Content-type: text/x-vcard\n\n"
102 "email;internet:%s\n"
103 "adr:;;%s;%s;%s;%s;USA\n"
113 tp = fopen(tempfilename, "w");
114 fwrite(vcard, strlen(vcard)+1, 1, tp);
117 CtdlWriteObject(USERCONFIGROOM, "text/x-vcard",
118 tempfilename, &newus, 0, 1, CM_SKIP_HOOKS);
119 unlink(tempfilename);
123 fclose(fp); /* this file deletes automatically */
133 void check_server_upgrades(void) {
136 lprintf(5, "Server-hosted upgrade level is %d.%02d\n",
137 (CitControl.version / 100),
138 (CitControl.version % 100) );
140 if (CitControl.version < REV_LEVEL) {
141 lprintf(5, "Server hosted updates need to be processed at "
142 "this time. Please wait...\n");
148 if (CitControl.version < 555) do_pre555_usersupp_upgrade();
150 CitControl.version = REV_LEVEL;
165 * Back end processing function for cmd_bmbx
167 void cmd_bmbx_backend(struct quickroom *qrbuf, void *data) {
168 static struct RoomProcList *rplist = NULL;
169 struct RoomProcList *ptr;
172 /* Lazy programming here. Call this function as a ForEachRoom backend
173 * in order to queue up the room names, or call it with a null room
174 * to make it do the processing.
177 ptr = (struct RoomProcList *)
178 mallok(sizeof (struct RoomProcList));
179 if (ptr == NULL) return;
181 safestrncpy(ptr->name, qrbuf->QRname, sizeof ptr->name);
187 while (rplist != NULL) {
189 if (lgetroom(&qr, rplist->name) == 0) {
190 lprintf(9, "Processing <%s>...\n", rplist->name);
191 if ( (qr.QRflags & QR_MAILBOX) == 0) {
192 lprintf(9, " -- not a mailbox\n");
196 qr.QRgen = time(NULL);
197 lprintf(9, " -- bumped!\n");
203 rplist = rplist->next;
209 * quick fix command to bump mailbox generation numbers
211 void cmd_bmbx(char *argbuf) {
212 int really_do_this = 0;
214 if (CtdlAccessCheck(ac_internal)) return;
215 really_do_this = extract_int(argbuf, 0);
217 if (really_do_this != 1) {
218 cprintf("%d You didn't really want to do that.\n", CIT_OK);
222 ForEachRoom(cmd_bmbx_backend, NULL);
223 cmd_bmbx_backend(NULL, NULL);
225 cprintf("%d Mailbox generation numbers bumped.\n", CIT_OK);
242 char *Dynamic_Module_Init(void)
244 check_server_upgrades();
245 CtdlRegisterProtoHook(cmd_bmbx, "BMBX", "Bump mailboxes");