2 * Functions which manage expire policy for rooms
3 * Copyright (c) 1987-2015 by the citadel.org team
5 * This program is open source software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License, version 3.
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
14 #include "../../sysdep.h"
23 #include <libcitadel.h>
24 #include "../../citadel_defs.h"
25 #include "../../server.h"
26 #include "../../database.h"
27 #include "../../config.h"
28 #include "../../room_ops.h"
29 #include "../../sysdep_decls.h"
30 #include "../../support.h"
31 #include "../../msgbase.h"
32 #include "../../citserver.h"
33 #include "../../ctdl_module.h"
34 #include "../../user_ops.h"
37 * Retrieve the applicable expire policy for a specific room
39 void GetExpirePolicy(struct ExpirePolicy *epbuf, struct ctdlroom *qrbuf) {
42 /* If the room has its own policy, return it */
43 if (qrbuf->QRep.expire_mode != 0) {
44 memcpy(epbuf, &qrbuf->QRep, sizeof(struct ExpirePolicy));
48 /* (non-mailbox rooms)
49 * If the floor has its own policy, return it
51 if ( (qrbuf->QRflags & QR_MAILBOX) == 0) {
52 fl = CtdlGetCachedFloor(qrbuf->QRfloor);
53 if (fl->f_ep.expire_mode != 0) {
54 memcpy(epbuf, &fl->f_ep, sizeof(struct ExpirePolicy));
60 * If there is a default policy for mailbox rooms, return it
62 if (qrbuf->QRflags & QR_MAILBOX) {
63 if (CtdlGetConfigInt("c_mbxep_mode") != 0) {
64 epbuf->expire_mode = CtdlGetConfigInt("c_mbxep_mode");
65 epbuf->expire_value = CtdlGetConfigInt("c_mbxep_value");
70 /* Otherwise, fall back on the system default */
71 epbuf->expire_mode = CtdlGetConfigInt("c_ep_mode");
72 epbuf->expire_value = CtdlGetConfigInt("c_ep_value");
79 void cmd_gpex(char *argbuf) {
80 struct ExpirePolicy exp;
84 memset(&exp, 0, sizeof(struct ExpirePolicy));
85 extract_token(which, argbuf, 0, '|', sizeof which);
86 if (!strcasecmp(which, strof(roompolicy)) || !strcasecmp(which, "room")) {
87 memcpy(&exp, &CC->room.QRep, sizeof(struct ExpirePolicy));
89 else if (!strcasecmp(which, strof(floorpolicy)) || !strcasecmp(which, "floor")) {
90 fl = CtdlGetCachedFloor(CC->room.QRfloor);
91 memcpy(&exp, &fl->f_ep, sizeof(struct ExpirePolicy));
93 else if (!strcasecmp(which, strof(mailboxespolicy)) || !strcasecmp(which, "mailboxes")) {
94 exp.expire_mode = CtdlGetConfigInt("c_mbxep_mode");
95 exp.expire_value = CtdlGetConfigInt("c_mbxep_value");
97 else if (!strcasecmp(which, strof(sitepolicy)) || !strcasecmp(which, "site")) {
98 exp.expire_mode = CtdlGetConfigInt("c_ep_mode");
99 exp.expire_value = CtdlGetConfigInt("c_ep_value");
102 cprintf("%d Invalid keyword \"%s\"\n", ERROR + ILLEGAL_VALUE, which);
106 cprintf("%d %d|%d\n", CIT_OK, exp.expire_mode, exp.expire_value);
113 void cmd_spex(char *argbuf) {
114 struct ExpirePolicy exp;
118 memset(&exp, 0, sizeof(struct ExpirePolicy));
119 extract_token(which, argbuf, 0, '|', sizeof which);
120 exp.expire_mode = extract_int(argbuf, 1);
121 exp.expire_value = extract_int(argbuf, 2);
123 if ((exp.expire_mode < 0) || (exp.expire_mode > 3)) {
124 cprintf("%d Invalid policy.\n", ERROR + ILLEGAL_VALUE);
128 if ((!strcasecmp(which, strof(roompolicy))) || (!strcasecmp(which, "room")))
130 if (!is_room_aide()) {
131 cprintf("%d Higher access required.\n", ERROR + HIGHER_ACCESS_REQUIRED);
134 CtdlGetRoomLock(&CC->room, CC->room.QRname);
135 memcpy(&CC->room.QRep, &exp, sizeof(struct ExpirePolicy));
136 CtdlPutRoomLock(&CC->room);
137 cprintf("%d Room expire policy for '%s' has been updated.\n", CIT_OK, CC->room.QRname);
138 syslog(LOG_DEBUG, "Room: %s , Policy: %d , Value: %d",
146 if (CC->user.axlevel < AxAideU) {
147 cprintf("%d Higher access required.\n", ERROR + HIGHER_ACCESS_REQUIRED);
151 if ((!strcasecmp(which, strof(floorpolicy))) || (!strcasecmp(which, "floor")))
153 lgetfloor(&flbuf, CC->room.QRfloor);
154 memcpy(&flbuf.f_ep, &exp, sizeof(struct ExpirePolicy));
155 lputfloor(&flbuf, CC->room.QRfloor);
156 cprintf("%d Floor expire policy has been updated.\n", CIT_OK);
160 else if ((!strcasecmp(which, strof(mailboxespolicy))) || (!strcasecmp(which, "mailboxes")))
162 CtdlSetConfigInt("c_mbxep_mode", exp.expire_mode);
163 CtdlSetConfigInt("c_mbxep_value", exp.expire_value);
164 cprintf("%d Default expire policy for mailboxes set.\n", CIT_OK);
168 else if ((!strcasecmp(which, strof(sitepolicy))) || (!strcasecmp(which, "site")))
170 if (exp.expire_mode == EXPIRE_NEXTLEVEL) {
171 cprintf("%d Invalid policy (no higher level)\n", ERROR + ILLEGAL_VALUE);
174 CtdlSetConfigInt("c_ep_mode", exp.expire_mode);
175 CtdlSetConfigInt("c_ep_value", exp.expire_value);
176 cprintf("%d Site expire policy has been updated.\n", CIT_OK);
180 cprintf("%d Invalid keyword '%s'\n", ERROR + ILLEGAL_VALUE, which);