2 * Functions which manage policy for rooms (such as message expiry)
12 #if TIME_WITH_SYS_TIME
13 # include <sys/time.h>
17 # include <sys/time.h>
24 #include <libcitadel.h>
30 #include "sysdep_decls.h"
33 #include "citserver.h"
35 #include "ctdl_module.h"
39 * Retrieve the applicable expire policy for a specific room
41 void GetExpirePolicy(struct ExpirePolicy *epbuf, struct ctdlroom *qrbuf) {
44 /* If the room has its own policy, return it */
45 if (qrbuf->QRep.expire_mode != 0) {
46 memcpy(epbuf, &qrbuf->QRep, sizeof(struct ExpirePolicy));
50 /* (non-mailbox rooms)
51 * If the floor has its own policy, return it
53 if ( (qrbuf->QRflags & QR_MAILBOX) == 0) {
54 fl = CtdlGetCachedFloor(qrbuf->QRfloor);
55 if (fl->f_ep.expire_mode != 0) {
56 memcpy(epbuf, &fl->f_ep, sizeof(struct ExpirePolicy));
62 * If there is a default policy for mailbox rooms, return it
64 if (qrbuf->QRflags & QR_MAILBOX) {
65 if (config.c_mbxep.expire_mode != 0) {
66 memcpy(epbuf, &config.c_mbxep,
67 sizeof(struct ExpirePolicy));
72 /* Otherwise, fall back on the system default */
73 memcpy(epbuf, &config.c_ep, sizeof(struct ExpirePolicy));
80 void cmd_gpex(char *argbuf) {
81 struct ExpirePolicy exp;
85 extract_token(which, argbuf, 0, '|', sizeof which);
86 if (!strcasecmp(which, strof(roompolicy))||
87 !strcasecmp(which, "room")) { /* Deprecated version */
88 memcpy(&exp, &CC->room.QRep, sizeof(struct ExpirePolicy));
90 else if (!strcasecmp(which, strof(floorpolicy))||
91 !strcasecmp(which, "floor")) { /* Deprecated version */
92 fl = CtdlGetCachedFloor(CC->room.QRfloor);
93 memcpy(&exp, &fl->f_ep, sizeof(struct ExpirePolicy));
95 else if (!strcasecmp(which, strof(mailboxespolicy))||
96 !strcasecmp(which, "mailboxes")) {/* Deprecated version */
97 memcpy(&exp, &config.c_mbxep, sizeof(struct ExpirePolicy));
99 else if (!strcasecmp(which, strof(sitepolicy))||
100 !strcasecmp(which, "site")) {/* Deprecated version */
101 memcpy(&exp, &config.c_ep, sizeof(struct ExpirePolicy));
104 cprintf("%d Invalid keyword \"%s\"\n", ERROR + ILLEGAL_VALUE, which);
108 cprintf("%d %d|%d\n", CIT_OK, exp.expire_mode, exp.expire_value);
115 void cmd_spex(char *argbuf) {
116 struct ExpirePolicy exp;
120 memset(&exp, 0, sizeof(struct ExpirePolicy));
121 extract_token(which, argbuf, 0, '|', sizeof which);
122 exp.expire_mode = extract_int(argbuf, 1);
123 exp.expire_value = extract_int(argbuf, 2);
125 if ((exp.expire_mode < 0) || (exp.expire_mode > 3)) {
126 cprintf("%d Invalid policy.\n", ERROR + ILLEGAL_VALUE);
130 if (!strcasecmp(which, strof(roompolicy))||
131 !strcasecmp(which, "room")) {
132 if (!is_room_aide()) {
133 cprintf("%d Higher access required.\n",
134 ERROR + HIGHER_ACCESS_REQUIRED);
137 CtdlGetRoomLock(&CC->room, CC->room.QRname);
138 memcpy(&CC->room.QRep, &exp, sizeof(struct ExpirePolicy));
139 CtdlPutRoomLock(&CC->room);
140 cprintf("%d Room expire policy has been updated.\n", CIT_OK);
144 if (CC->user.axlevel < AxAideU) {
145 cprintf("%d Higher access required.\n",
146 ERROR + HIGHER_ACCESS_REQUIRED);
150 if (!strcasecmp(which, strof(floorpolicy))||
151 !strcasecmp(which, "floor")) { /* deprecated version */
152 lgetfloor(&flbuf, CC->room.QRfloor);
153 memcpy(&flbuf.f_ep, &exp, sizeof(struct ExpirePolicy));
154 lputfloor(&flbuf, CC->room.QRfloor);
155 cprintf("%d Floor expire policy has been updated.\n", CIT_OK);
159 else if (!strcasecmp(which, strof(mailboxespolicy))||
160 !strcasecmp(which, "mailboxes")) {
161 memcpy(&config.c_mbxep, &exp, sizeof(struct ExpirePolicy));
163 cprintf("%d Default expire policy for mailboxes set.\n",
168 else if (!strcasecmp(which, strof(sitepolicy))||
169 !strcasecmp(which, "site")) {/* deprecated version */
170 if (exp.expire_mode == EXPIRE_NEXTLEVEL) {
171 cprintf("%d Invalid policy (no higher level)\n",
172 ERROR + ILLEGAL_VALUE);
175 memcpy(&config.c_ep, &exp, sizeof(struct ExpirePolicy));
177 cprintf("%d Site expire policy has been updated.\n", CIT_OK);
182 cprintf("%d Invalid keyword \"%s\"\n", ERROR + ILLEGAL_VALUE, which);