X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Flistsub.c;h=d445d05bd16cacdda9da0a7fe2850b02968100e7;hb=HEAD;hp=28300597317bd9501d49ee207622154f8aaddc2d;hpb=ae7836a788b07db74d31b532c21090ad8de417f4;p=citadel.git
diff --git a/webcit/listsub.c b/webcit/listsub.c
index 283005973..95f9ecfdb 100644
--- a/webcit/listsub.c
+++ b/webcit/listsub.c
@@ -1,227 +1,137 @@
-/*
- * $Id$
- *
- * Web forms for handling mailing list subscribe/unsubscribe requests.
- *
- */
+// Web forms for handling mailing list subscribe/unsubscribe requests.
+//
+// Copyright (c) 1996-2022 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 "webcit.h"
+// List subscription handling
+int Conditional_LISTSUB_EXECUTE_SUBSCRIBE(StrBuf *Target, WCTemplputParams *TP) {
+ int rc;
+ StrBuf *Line;
+ const char *ImpMsg;
+ const StrBuf *Room, *Email;
+ if (strcmp(bstr("cmd"), "subscribe")) {
+ return 0;
+ }
-/*
- * List subscription handling
- */
-void do_listsub(void)
-{
- char cmd[256];
- char room[256];
- char token[256];
- char email[256];
- char subtype[256];
- char escaped_email[256];
- char escaped_room[256];
-
- char buf[SIZ];
- int self;
- char sroom[SIZ];
-
- strcpy(WC->wc_username, "");
- strcpy(WC->wc_password, "");
- strcpy(WC->wc_roomname, "");
-
- output_headers(1, 0, 0, 1, 1, 0);
- begin_burst();
-
- wprintf("
");
- wprintf(_("You are subscribing %s"
- " to the %s mailing list. "
- "The listserver has "
- "sent you an e-mail with one additional "
- "Web link for you to click on to confirm "
- "your subscription. This extra step is for "
- "your protection, as it prevents others from "
- "being able to subscribe you to lists "
- "without your consent.
"
- "Please click on the link which is being "
- "e-mailed to you and your subscription will "
- "be confirmed. \n"),
- escaped_email, escaped_room);
- wprintf("%s
"
- "You are unsubscribing ");
- escputs(email);
- wprintf(" from the "");
- escputs(room);
- wprintf("" mailing list. The listserver has "
- "sent you an e-mail with one additional "
- "Web link for you to click on to confirm "
- "your unsubscription. This extra step is for "
- "your protection, as it prevents others from "
- "being able to unsubscribe you from "
- "lists without your consent.
"
- "Please click on the link which is being "
- "e-mailed to you and your unsubscription will "
- "be confirmed. \n"
- "Back...
You waited too long to confirm your "
- "subscribe/unsubscribe request (the "
- "confirmation link is only valid for three "
- "days)\n
You have already "
- "successfully confirmed your "
- "subscribe/unsubscribe request and are "
- "attempting to do it again.
\n"
- "The error returned by the server was: "
- );
- }
- wprintf("%s
\n", &buf[4]);
+
+int Conditional_LISTSUB_EXECUTE_CONFIRMUNSUBSCRIBE(StrBuf *Target, WCTemplputParams *TP) {
+ if (strcmp(bstr("cmd"), "confirm_unsubscribe")) {
+ return 0;
}
+ return(confirm_sub_or_unsub("confirm_unsubscribe", Target, TP));
+}
- /*
- * Any other (invalid) command causes the form to be displayed
- */
- else {
-FORM: wprintf("\n"
- );
-
- wprintf(" When you attempt to subscribe or unsubscribe to "
- "a mailing list, you will receive an e-mail containing"
- " one additional web link to click on for final "
- "confirmation. This extra step is for your "
- "protection, as it prevents others from being able to "
- "subscribe or unsubscribe you to lists. \n"
- );
+void do_listsub(void) {
+ if (!havebstr("cmd")) {
+ putbstr("cmd", NewStrBufPlain(HKEY("choose")));
}
+ output_headers(1, 0, 0, 0, 1, 0);
+ do_template("listsub_display");
+ end_burst();
+}
+
- wprintf("\n");
- wDumpContent(0);
- end_webcit_session();
+void
+InitModule_LISTSUB
+(void)
+{
+ RegisterConditional("COND:LISTSUB:EXECUTE:SUBSCRIBE", 0, Conditional_LISTSUB_EXECUTE_SUBSCRIBE, CTX_NONE);
+ RegisterConditional("COND:LISTSUB:EXECUTE:UNSUBSCRIBE", 0, Conditional_LISTSUB_EXECUTE_UNSUBSCRIBE, CTX_NONE);
+ RegisterConditional("COND:LISTSUB:EXECUTE:CONFIRMSUBSCRIBE", 0, Conditional_LISTSUB_EXECUTE_CONFIRMSUBSCRIBE, CTX_NONE);
+ RegisterConditional("COND:LISTSUB:EXECUTE:CONFIRMUNSUBSCRIBE", 0, Conditional_LISTSUB_EXECUTE_CONFIRMUNSUBSCRIBE, CTX_NONE);
+ WebcitAddUrlHandler(HKEY("listsub"), "", 0, do_listsub, ANONYMOUS|COOKIEUNNEEDED|FORCE_SESSIONCLOSE);
}