X-Git-Url: https://code.citadel.org/?p=citadel.git;a=blobdiff_plain;f=citadel%2Fmodules%2Fexpire%2Fexpire_policy.c;fp=citadel%2Fmodules%2Fexpire%2Fexpire_policy.c;h=76c6acb44a2a3ed10605da80491fefc41756bd03;hp=bc4b772a72c1c28626a7b743d864d82ca8dcdbcb;hb=7c94d5bb68f1c448770d31205ec5ae12bd8a02ed;hpb=c8c89455faeb5a76d6ee2264f497b8f790e0e392 diff --git a/citadel/modules/expire/expire_policy.c b/citadel/modules/expire/expire_policy.c index bc4b772a7..76c6acb44 100644 --- a/citadel/modules/expire/expire_policy.c +++ b/citadel/modules/expire/expire_policy.c @@ -1,6 +1,6 @@ /* * Functions which manage expire policy for rooms - * Copyright (c) 1987-2012 by the citadel.org team + * 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. @@ -40,7 +40,6 @@ #include "support.h" #include "msgbase.h" #include "citserver.h" - #include "ctdl_module.h" #include "user_ops.h" @@ -71,15 +70,16 @@ void GetExpirePolicy(struct ExpirePolicy *epbuf, struct ctdlroom *qrbuf) { * If there is a default policy for mailbox rooms, return it */ if (qrbuf->QRflags & QR_MAILBOX) { - if (config.c_mbxep.expire_mode != 0) { - memcpy(epbuf, &config.c_mbxep, - sizeof(struct ExpirePolicy)); + 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 */ - memcpy(epbuf, &config.c_ep, sizeof(struct ExpirePolicy)); + epbuf->expire_mode = CtdlGetConfigInt("c_ep_mode"); + epbuf->expire_value = CtdlGetConfigInt("c_ep_value"); } @@ -91,23 +91,22 @@ void cmd_gpex(char *argbuf) { 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")) { /* Deprecated version */ + 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")) { /* Deprecated version */ + 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")) {/* Deprecated version */ - memcpy(&exp, &config.c_mbxep, 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")) {/* Deprecated version */ - memcpy(&exp, &config.c_ep, sizeof(struct ExpirePolicy)); + 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); @@ -136,9 +135,8 @@ void cmd_spex(char *argbuf) { return; } - if ( (!strcasecmp(which, strof(roompolicy))) - || (!strcasecmp(which, "room")) - ) { + if ((!strcasecmp(which, strof(roompolicy))) || (!strcasecmp(which, "room"))) + { if (!is_room_aide()) { cprintf("%d Higher access required.\n", ERROR + HIGHER_ACCESS_REQUIRED); return; @@ -160,9 +158,8 @@ void cmd_spex(char *argbuf) { return; } - if ( (!strcasecmp(which, strof(floorpolicy))) - || (!strcasecmp(which, "floor")) - ) { + 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); @@ -170,25 +167,22 @@ void cmd_spex(char *argbuf) { return; } - else if ( (!strcasecmp(which, strof(mailboxespolicy))) - || (!strcasecmp(which, "mailboxes")) - ) { - memcpy(&config.c_mbxep, &exp, sizeof(struct ExpirePolicy)); - put_config(); + 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")) - ) { + 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); + cprintf("%d Invalid policy (no higher level)\n", ERROR + ILLEGAL_VALUE); return; } - memcpy(&config.c_ep, &exp, sizeof(struct ExpirePolicy)); - put_config(); + 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; }