2 * Functions which manage expire policy for rooms
3 * Copyright (c) 1987-2012 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.
21 #if TIME_WITH_SYS_TIME
22 # include <sys/time.h>
26 # include <sys/time.h>
33 #include <libcitadel.h>
39 #include "sysdep_decls.h"
42 #include "citserver.h"
44 #include "ctdl_module.h"
48 * Retrieve the applicable expire policy for a specific room
50 void GetExpirePolicy(struct ExpirePolicy *epbuf, struct ctdlroom *qrbuf) {
53 /* If the room has its own policy, return it */
54 if (qrbuf->QRep.expire_mode != 0) {
55 memcpy(epbuf, &qrbuf->QRep, sizeof(struct ExpirePolicy));
59 /* (non-mailbox rooms)
60 * If the floor has its own policy, return it
62 if ( (qrbuf->QRflags & QR_MAILBOX) == 0) {
63 fl = CtdlGetCachedFloor(qrbuf->QRfloor);
64 if (fl->f_ep.expire_mode != 0) {
65 memcpy(epbuf, &fl->f_ep, sizeof(struct ExpirePolicy));
71 * If there is a default policy for mailbox rooms, return it
73 if (qrbuf->QRflags & QR_MAILBOX) {
74 if (config.c_mbxep.expire_mode != 0) {
75 memcpy(epbuf, &config.c_mbxep,
76 sizeof(struct ExpirePolicy));
81 /* Otherwise, fall back on the system default */
82 memcpy(epbuf, &config.c_ep, sizeof(struct ExpirePolicy));
89 void cmd_gpex(char *argbuf) {
90 struct ExpirePolicy exp;
94 extract_token(which, argbuf, 0, '|', sizeof which);
95 if (!strcasecmp(which, strof(roompolicy))||
96 !strcasecmp(which, "room")) { /* Deprecated version */
97 memcpy(&exp, &CC->room.QRep, sizeof(struct ExpirePolicy));
99 else if (!strcasecmp(which, strof(floorpolicy))||
100 !strcasecmp(which, "floor")) { /* Deprecated version */
101 fl = CtdlGetCachedFloor(CC->room.QRfloor);
102 memcpy(&exp, &fl->f_ep, sizeof(struct ExpirePolicy));
104 else if (!strcasecmp(which, strof(mailboxespolicy))||
105 !strcasecmp(which, "mailboxes")) {/* Deprecated version */
106 memcpy(&exp, &config.c_mbxep, sizeof(struct ExpirePolicy));
108 else if (!strcasecmp(which, strof(sitepolicy))||
109 !strcasecmp(which, "site")) {/* Deprecated version */
110 memcpy(&exp, &config.c_ep, sizeof(struct ExpirePolicy));
113 cprintf("%d Invalid keyword \"%s\"\n", ERROR + ILLEGAL_VALUE, which);
117 cprintf("%d %d|%d\n", CIT_OK, exp.expire_mode, exp.expire_value);
124 void cmd_spex(char *argbuf) {
125 struct ExpirePolicy exp;
129 memset(&exp, 0, sizeof(struct ExpirePolicy));
130 extract_token(which, argbuf, 0, '|', sizeof which);
131 exp.expire_mode = extract_int(argbuf, 1);
132 exp.expire_value = extract_int(argbuf, 2);
134 if ((exp.expire_mode < 0) || (exp.expire_mode > 3)) {
135 cprintf("%d Invalid policy.\n", ERROR + ILLEGAL_VALUE);
139 if ( (!strcasecmp(which, strof(roompolicy)))
140 || (!strcasecmp(which, "room"))
142 if (!is_room_aide()) {
143 cprintf("%d Higher access required.\n", ERROR + HIGHER_ACCESS_REQUIRED);
146 CtdlGetRoomLock(&CC->room, CC->room.QRname);
147 memcpy(&CC->room.QRep, &exp, sizeof(struct ExpirePolicy));
148 CtdlPutRoomLock(&CC->room);
149 cprintf("%d Room expire policy for '%s' has been updated.\n", CIT_OK, CC->room.QRname);
150 syslog(LOG_DEBUG, "Room: %s , Policy: %d , Value: %d",
158 if (CC->user.axlevel < AxAideU) {
159 cprintf("%d Higher access required.\n", ERROR + HIGHER_ACCESS_REQUIRED);
163 if ( (!strcasecmp(which, strof(floorpolicy)))
164 || (!strcasecmp(which, "floor"))
166 lgetfloor(&flbuf, CC->room.QRfloor);
167 memcpy(&flbuf.f_ep, &exp, sizeof(struct ExpirePolicy));
168 lputfloor(&flbuf, CC->room.QRfloor);
169 cprintf("%d Floor expire policy has been updated.\n", CIT_OK);
173 else if ( (!strcasecmp(which, strof(mailboxespolicy)))
174 || (!strcasecmp(which, "mailboxes"))
176 memcpy(&config.c_mbxep, &exp, sizeof(struct ExpirePolicy));
178 cprintf("%d Default expire policy for mailboxes set.\n", CIT_OK);
182 else if ( (!strcasecmp(which, strof(sitepolicy)))
183 || (!strcasecmp(which, "site"))
185 if (exp.expire_mode == EXPIRE_NEXTLEVEL) {
186 cprintf("%d Invalid policy (no higher level)\n",
187 ERROR + ILLEGAL_VALUE);
190 memcpy(&config.c_ep, &exp, sizeof(struct ExpirePolicy));
192 cprintf("%d Site expire policy has been updated.\n", CIT_OK);
196 cprintf("%d Invalid keyword '%s'\n", ERROR + ILLEGAL_VALUE, which);