citserver.c clientsocket.c config.c control.c $(DATABASE) \
domain.c serv_extensions.c file_ops.c genstamp.c getutline.c \
housekeeping.c ical_dezonify.c internet_addressing.c ecrash.c \
- locate_host.c md5.c auth.c msgbase.c parsedate.c policy.c \
+ locate_host.c md5.c auth.c msgbase.c parsedate.c \
room_ops.c euidindex.c server_main.c snprintf.c ldap.c \
support.c sysdep.c user_ops.c journaling.c threads.c \
context.c
SERV_OBJS = server_main.o utillib/citadel_dirs.o\
user_ops.o citserver.o sysdep.o serv_extensions.o \
$(DATABASE:.c=.o) domain.o \
- control.o policy.o config.o support.o room_ops.o \
+ control.o config.o support.o room_ops.o \
file_ops.o msgbase.o euidindex.o \
locate_host.o housekeeping.o \
internet_addressing.o journaling.o \
#include "locate_host.h"
#include "room_ops.h"
#include "file_ops.h"
-#include "policy.h"
#include "control.h"
#include "euidindex.h"
#include "context.h"
+citadel (7.79-87) stable; urgency=low
+
+ * beta
+
+ -- Wilfried Goesgens <w.goesgens@outgesourced.org> Mon, 22 Dec 2009 22:00:00 +0001
+
citadel (7.70-87) stable; urgency=low
* new upstream version
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "citserver.h"
#include "support.h"
#include "config.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
--- /dev/null
+/*
+ * $Id$
+ *
+ * Functions which manage policy for rooms (such as message expiry)
+ */
+
+#include "sysdep.h"
+#include <stdlib.h>
+#include <unistd.h>
+#include <stdio.h>
+#include <sys/stat.h>
+#include <string.h>
+
+#if TIME_WITH_SYS_TIME
+# include <sys/time.h>
+# include <time.h>
+#else
+# if HAVE_SYS_TIME_H
+# include <sys/time.h>
+# else
+# include <time.h>
+# endif
+#endif
+
+#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 "user_ops.h"
+#include "msgbase.h"
+#include "citserver.h"
+
+#include "ctdl_module.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 (config.c_mbxep.expire_mode != 0) {
+ memcpy(epbuf, &config.c_mbxep,
+ sizeof(struct ExpirePolicy));
+ return;
+ }
+ }
+
+ /* Otherwise, fall back on the system default */
+ memcpy(epbuf, &config.c_ep, sizeof(struct ExpirePolicy));
+}
+
+
+/*
+ * Get Policy EXpire
+ */
+void cmd_gpex(char *argbuf) {
+ struct ExpirePolicy exp;
+ struct floor *fl;
+ char which[128];
+
+ extract_token(which, argbuf, 0, '|', sizeof which);
+ if (!strcasecmp(which, strof(room))) {
+ memcpy(&exp, &CC->room.QRep, sizeof(struct ExpirePolicy));
+ }
+ else if (!strcasecmp(which, strof(floorpolicy))) {
+ fl = CtdlGetCachedFloor(CC->room.QRfloor);
+ memcpy(&exp, &fl->f_ep, sizeof(struct ExpirePolicy));
+ }
+ else if (!strcasecmp(which, strof(mailboxespolicy))) {
+ memcpy(&exp, &config.c_mbxep, sizeof(struct ExpirePolicy));
+ }
+ else if (!strcasecmp(which, strof(sitepolicy))) {
+ memcpy(&exp, &config.c_ep, sizeof(struct ExpirePolicy));
+ }
+ 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, "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 has been updated.\n", CIT_OK);
+ return;
+ }
+
+ if (CC->user.axlevel < AxAideU) {
+ cprintf("%d Higher access required.\n",
+ ERROR + HIGHER_ACCESS_REQUIRED);
+ return;
+ }
+
+ if (!strcasecmp(which, strof(floorpolicy))) {
+ 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))) {
+ memcpy(&config.c_mbxep, &exp, sizeof(struct ExpirePolicy));
+ put_config();
+ cprintf("%d Default expire policy for mailboxes set.\n",
+ CIT_OK);
+ return;
+ }
+
+ else if (!strcasecmp(which, strof(sitepolicy))) {
+ if (exp.expire_mode == EXPIRE_NEXTLEVEL) {
+ cprintf("%d Invalid policy (no higher level)\n",
+ ERROR + ILLEGAL_VALUE);
+ return;
+ }
+ memcpy(&config.c_ep, &exp, sizeof(struct ExpirePolicy));
+ put_config();
+ cprintf("%d Site expire policy has been updated.\n", CIT_OK);
+ return;
+ }
+
+ else {
+ cprintf("%d Invalid keyword \"%s\"\n", ERROR + ILLEGAL_VALUE, which);
+ return;
+ }
+
+}
+
--- /dev/null
+/* $Id$ */
+void GetExpirePolicy(struct ExpirePolicy *epbuf, struct ctdlroom *qrbuf);
+void cmd_gpex(char *argbuf);
+void cmd_spex(char *argbuf);
{
/* CtdlRegisterProtoHook(cmd_fsck, "FSCK", "Check message ref counts"); */
CtdlRegisterProtoHook(cmd_tdap, "TDAP", "Manually initiate auto-purger");
+
+ CtdlRegisterProtoHook(cmd_gpex, "GPEX", "Autoconverted. TODO: document me.");
+ CtdlRegisterProtoHook(cmd_spex, "SPEX", "Autoconverted. TODO: document me.");
}
else
CtdlThreadCreate("Auto Purger", CTDLTHREAD_BIGSTACK, purge_databases, NULL);
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "serv_network.h" /* Needed for defenition of FilterList */
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "citserver.h"
#include "support.h"
#include "config.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
#include "config.h"
#include "control.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "euidindex.h"
#include "support.h"
#include "config.h"
#include "user_ops.h"
-#include "policy.h"
#include "database.h"
#include "msgbase.h"
#include "internet_addressing.h"
+++ /dev/null
-/*
- * $Id$
- *
- * Functions which manage policy for rooms (such as message expiry)
- */
-
-#include "sysdep.h"
-#include <stdlib.h>
-#include <unistd.h>
-#include <stdio.h>
-#include <sys/stat.h>
-#include <string.h>
-
-#if TIME_WITH_SYS_TIME
-# include <sys/time.h>
-# include <time.h>
-#else
-# if HAVE_SYS_TIME_H
-# include <sys/time.h>
-# else
-# include <time.h>
-# endif
-#endif
-
-#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 "user_ops.h"
-#include "msgbase.h"
-#include "citserver.h"
-
-#include "ctdl_module.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 (config.c_mbxep.expire_mode != 0) {
- memcpy(epbuf, &config.c_mbxep,
- sizeof(struct ExpirePolicy));
- return;
- }
- }
-
- /* Otherwise, fall back on the system default */
- memcpy(epbuf, &config.c_ep, sizeof(struct ExpirePolicy));
-}
-
-
-/*
- * Get Policy EXpire
- */
-void cmd_gpex(char *argbuf) {
- struct ExpirePolicy exp;
- struct floor *fl;
- char which[128];
-
- extract_token(which, argbuf, 0, '|', sizeof which);
- if (!strcasecmp(which, strof(room))) {
- memcpy(&exp, &CC->room.QRep, sizeof(struct ExpirePolicy));
- }
- else if (!strcasecmp(which, strof(floorpolicy))) {
- fl = CtdlGetCachedFloor(CC->room.QRfloor);
- memcpy(&exp, &fl->f_ep, sizeof(struct ExpirePolicy));
- }
- else if (!strcasecmp(which, strof(mailboxespolicy))) {
- memcpy(&exp, &config.c_mbxep, sizeof(struct ExpirePolicy));
- }
- else if (!strcasecmp(which, strof(sitepolicy))) {
- memcpy(&exp, &config.c_ep, sizeof(struct ExpirePolicy));
- }
- 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, "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 has been updated.\n", CIT_OK);
- return;
- }
-
- if (CC->user.axlevel < AxAideU) {
- cprintf("%d Higher access required.\n",
- ERROR + HIGHER_ACCESS_REQUIRED);
- return;
- }
-
- if (!strcasecmp(which, strof(floorpolicy))) {
- 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))) {
- memcpy(&config.c_mbxep, &exp, sizeof(struct ExpirePolicy));
- put_config();
- cprintf("%d Default expire policy for mailboxes set.\n",
- CIT_OK);
- return;
- }
-
- else if (!strcasecmp(which, strof(sitepolicy))) {
- if (exp.expire_mode == EXPIRE_NEXTLEVEL) {
- cprintf("%d Invalid policy (no higher level)\n",
- ERROR + ILLEGAL_VALUE);
- return;
- }
- memcpy(&config.c_ep, &exp, sizeof(struct ExpirePolicy));
- put_config();
- cprintf("%d Site expire policy has been updated.\n", CIT_OK);
- return;
- }
-
- else {
- cprintf("%d Invalid keyword \"%s\"\n", ERROR + ILLEGAL_VALUE, which);
- return;
- }
-
-}
-
-/*****************************************************************************/
-/* MODULE INITIALIZATION STUFF */
-/*****************************************************************************/
-
-CTDL_MODULE_INIT(policy)
-{
- if (!threading) {
- CtdlRegisterProtoHook(cmd_gpex, "GPEX", "Autoconverted. TODO: document me.");
- CtdlRegisterProtoHook(cmd_spex, "SPEX", "Autoconverted. TODO: document me.");
- }
- /* return our Subversion id for the Log */
- return "$Id$";
-}
+++ /dev/null
-/* $Id$ */
-void GetExpirePolicy(struct ExpirePolicy *epbuf, struct ctdlroom *qrbuf);
-void cmd_gpex(char *argbuf);
-void cmd_spex(char *argbuf);
CtdlLogPrintf (CTDL_INFO, "%s\n", CTDL_INIT_CALL(euidindex));
CtdlLogPrintf (CTDL_INFO, "%s\n", CTDL_INIT_CALL(file_ops));
CtdlLogPrintf (CTDL_INFO, "%s\n", CTDL_INIT_CALL(msgbase));
- CtdlLogPrintf (CTDL_INFO, "%s\n", CTDL_INIT_CALL(policy));
CtdlLogPrintf (CTDL_INFO, "%s\n", CTDL_INIT_CALL(room_ops));
CtdlLogPrintf (CTDL_INFO, "%s\n", CTDL_INIT_CALL(user_ops));
/* dynamic modules: */
CTDL_MODULE_INIT(euidindex);
CTDL_MODULE_INIT(file_ops);
CTDL_MODULE_INIT(msgbase);
- CTDL_MODULE_INIT(policy);
CTDL_MODULE_INIT(room_ops);
CTDL_MODULE_INIT(user_ops);
EOF