+++ /dev/null
-/*
- * Functions which manage expire policy for rooms
- * Copyright (c) 1987-2015 by the citadel.org team
- *
- * This program is open source software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License, version 3.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include "sysdep.h"
-#include <stdlib.h>
-#include <unistd.h>
-#include <stdio.h>
-#include <sys/stat.h>
-#include <string.h>
-
-#include <time.h>
-#include <limits.h>
-#include <libcitadel.h>
-#include "citadel.h"
-#include "server.h"
-#include "database.h"
-#include "config.h"
-#include "room_ops.h"
-#include "sysdep_decls.h"
-#include "support.h"
-#include "msgbase.h"
-#include "citserver.h"
-#include "ctdl_module.h"
-#include "user_ops.h"
-
-/*
- * Retrieve the applicable expire policy for a specific room
- */
-void GetExpirePolicy(struct ExpirePolicy *epbuf, struct ctdlroom *qrbuf) {
- struct floor *fl;
-
- /* If the room has its own policy, return it */
- if (qrbuf->QRep.expire_mode != 0) {
- memcpy(epbuf, &qrbuf->QRep, sizeof(struct ExpirePolicy));
- return;
- }
-
- /* (non-mailbox rooms)
- * If the floor has its own policy, return it
- */
- if ( (qrbuf->QRflags & QR_MAILBOX) == 0) {
- fl = CtdlGetCachedFloor(qrbuf->QRfloor);
- if (fl->f_ep.expire_mode != 0) {
- memcpy(epbuf, &fl->f_ep, sizeof(struct ExpirePolicy));
- return;
- }
- }
-
- /* (Mailbox rooms)
- * If there is a default policy for mailbox rooms, return it
- */
- if (qrbuf->QRflags & QR_MAILBOX) {
- if (CtdlGetConfigInt("c_mbxep_mode") != 0) {
- epbuf->expire_mode = CtdlGetConfigInt("c_mbxep_mode");
- epbuf->expire_value = CtdlGetConfigInt("c_mbxep_value");
- return;
- }
- }
-
- /* Otherwise, fall back on the system default */
- epbuf->expire_mode = CtdlGetConfigInt("c_ep_mode");
- epbuf->expire_value = CtdlGetConfigInt("c_ep_value");
-}
-
-
-/*
- * Get Policy EXpire
- */
-void cmd_gpex(char *argbuf) {
- struct ExpirePolicy exp;
- struct floor *fl;
- char which[128];
-
- memset(&exp, 0, sizeof(struct ExpirePolicy));
- extract_token(which, argbuf, 0, '|', sizeof which);
- if (!strcasecmp(which, strof(roompolicy)) || !strcasecmp(which, "room")) {
- memcpy(&exp, &CC->room.QRep, sizeof(struct ExpirePolicy));
- }
- else if (!strcasecmp(which, strof(floorpolicy)) || !strcasecmp(which, "floor")) {
- fl = CtdlGetCachedFloor(CC->room.QRfloor);
- memcpy(&exp, &fl->f_ep, sizeof(struct ExpirePolicy));
- }
- else if (!strcasecmp(which, strof(mailboxespolicy)) || !strcasecmp(which, "mailboxes")) {
- exp.expire_mode = CtdlGetConfigInt("c_mbxep_mode");
- exp.expire_value = CtdlGetConfigInt("c_mbxep_value");
- }
- else if (!strcasecmp(which, strof(sitepolicy)) || !strcasecmp(which, "site")) {
- exp.expire_mode = CtdlGetConfigInt("c_ep_mode");
- exp.expire_value = CtdlGetConfigInt("c_ep_value");
- }
- else {
- cprintf("%d Invalid keyword \"%s\"\n", ERROR + ILLEGAL_VALUE, which);
- return;
- }
-
- cprintf("%d %d|%d\n", CIT_OK, exp.expire_mode, exp.expire_value);
-}
-
-
-/*
- * Set Policy EXpire
- */
-void cmd_spex(char *argbuf) {
- struct ExpirePolicy exp;
- struct floor flbuf;
- char which[128];
-
- memset(&exp, 0, sizeof(struct ExpirePolicy));
- extract_token(which, argbuf, 0, '|', sizeof which);
- exp.expire_mode = extract_int(argbuf, 1);
- exp.expire_value = extract_int(argbuf, 2);
-
- if ((exp.expire_mode < 0) || (exp.expire_mode > 3)) {
- cprintf("%d Invalid policy.\n", ERROR + ILLEGAL_VALUE);
- return;
- }
-
- if ((!strcasecmp(which, strof(roompolicy))) || (!strcasecmp(which, "room")))
- {
- if (!is_room_aide()) {
- cprintf("%d Higher access required.\n", ERROR + HIGHER_ACCESS_REQUIRED);
- return;
- }
- CtdlGetRoomLock(&CC->room, CC->room.QRname);
- memcpy(&CC->room.QRep, &exp, sizeof(struct ExpirePolicy));
- CtdlPutRoomLock(&CC->room);
- cprintf("%d Room expire policy for '%s' has been updated.\n", CIT_OK, CC->room.QRname);
- syslog(LOG_DEBUG, "Room: %s , Policy: %d , Value: %d",
- CC->room.QRname,
- exp.expire_mode,
- exp.expire_value
- );
- return;
- }
-
- if (CC->user.axlevel < AxAideU) {
- cprintf("%d Higher access required.\n", ERROR + HIGHER_ACCESS_REQUIRED);
- return;
- }
-
- if ((!strcasecmp(which, strof(floorpolicy))) || (!strcasecmp(which, "floor")))
- {
- lgetfloor(&flbuf, CC->room.QRfloor);
- memcpy(&flbuf.f_ep, &exp, sizeof(struct ExpirePolicy));
- lputfloor(&flbuf, CC->room.QRfloor);
- cprintf("%d Floor expire policy has been updated.\n", CIT_OK);
- return;
- }
-
- else if ((!strcasecmp(which, strof(mailboxespolicy))) || (!strcasecmp(which, "mailboxes")))
- {
- CtdlSetConfigInt("c_mbxep_mode", exp.expire_mode);
- CtdlSetConfigInt("c_mbxep_value", exp.expire_value);
- cprintf("%d Default expire policy for mailboxes set.\n", CIT_OK);
- return;
- }
-
- else if ((!strcasecmp(which, strof(sitepolicy))) || (!strcasecmp(which, "site")))
- {
- if (exp.expire_mode == EXPIRE_NEXTLEVEL) {
- cprintf("%d Invalid policy (no higher level)\n", ERROR + ILLEGAL_VALUE);
- return;
- }
- CtdlSetConfigInt("c_ep_mode", exp.expire_mode);
- CtdlSetConfigInt("c_ep_value", exp.expire_value);
- cprintf("%d Site expire policy has been updated.\n", CIT_OK);
- return;
- }
-
- cprintf("%d Invalid keyword '%s'\n", ERROR + ILLEGAL_VALUE, which);
-}