2 /************************************************************************
3 * MXChange v0.2.1 Start: 02/12/2004 *
4 * ================ Last change: 01/07/2004 *
6 * -------------------------------------------------------------------- *
8 * -------------------------------------------------------------------- *
9 * Short description : *
10 * -------------------------------------------------------------------- *
11 * Kurzbeschreibung : *
12 * -------------------------------------------------------------------- *
14 * -------------------------------------------------------------------- *
15 * Copyright (c) 2003 - 2008 by Roland Haeder *
16 * For more information visit: http://www.mxchange.org *
18 * This program is free software; you can redistribute it and/or modify *
19 * it under the terms of the GNU General Public License as published by *
20 * the Free Software Foundation; either version 2 of the License, or *
21 * (at your option) any later version. *
23 * This program is distributed in the hope that it will be useful, *
24 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
26 * GNU General Public License for more details. *
28 * You should have received a copy of the GNU General Public License *
29 * along with this program; if not, write to the Free Software *
30 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *
32 ************************************************************************/
34 // Some security stuff...
35 if (!defined('__SECURITY')) {
36 $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";
38 } elseif (!IS_MEMBER()) {
39 LOAD_URL("modules.php?module=index");
40 } elseif ((!EXT_IS_ACTIVE("newsletter")) && (!IS_ADMIN())) {
41 addFatalMessage(EXTENSION_PROBLEM_EXT_INACTIVE, "newsletter");
45 // Add description as navigation point
46 ADD_DESCR("member", __FILE__);
49 $result = SQL_QUERY_ESC("SELECT nl_receive, nl_until, nl_timespan FROM `{!_MYSQL_PREFIX!}_user_data` WHERE userid=%s LIMIT 1",
50 array($GLOBALS['userid']), __FILE__, __LINE__);
51 list($status, $until, $span) = SQL_FETCHROW($result);
52 SQL_FREERESULT($result);
54 // Remember charge value
55 define('__CHARGE_VALUE', TRANSLATE_COMMA(getConfig('nl_charge')));
57 if ((isset($_POST['ok'])) && ($status == "Y") && ($span == "0")) {
59 SQL_QUERY_ESC("UPDATE `{!_MYSQL_PREFIX!}_user_data` SET nl_timespan='".(getConfig('one_day') * 30)."' WHERE userid=%s LIMIT 1",
60 array($GLOBALS['userid']), __FILE__, __LINE__);
63 $admin_msg = LOAD_EMAIL_TEMPLATE("admin_newsletter_request", array(), $GLOBALS['userid']);
66 SQL_QUERY_ESC("INSERT INTO `{!_MYSQL_PREFIX!}_task_system` (assigned_admin, status, task_type, subject, text, task_created, userid)
67 VALUES ('0','NEW','NL_UNSUBSCRIBE','{--ADMIN_NL_SUBJECT--}','".$admin_msg."', UNIX_TIMESTAMP(),'%s')", array($GLOBALS['userid']), __FILE__, __LINE__);
69 // Send mail to member
70 $msg = LOAD_EMAIL_TEMPLATE("member_newsletter_request", array(), $GLOBALS['userid']);
71 SEND_EMAIL($GLOBALS['userid'], getMessage('NL_MEMBER_SUBJECT'), $msg);
73 // Send mail to all admins
74 SEND_ADMIN_NOTIFICATION(getMessage('NL_ADMIN_SUBJECT'), "admin_newsletter_request", array(), $GLOBALS['userid']);
77 LOAD_TEMPLATE("admin_settings_saved", false, getMessage('NL_MEMBER_REQUEST_DONE'));
78 } elseif ($span > 0) {
80 LOAD_TEMPLATE("admin_settings_saved", false, getMessage('NL_MEMBER_REQUEST_ALREADY'));
82 // Load template for the note
83 define('NL_MEMBER_NOTE', LOAD_TEMPLATE("member_newsletter_note", true));
85 // Set status message and submit button
88 case "Y": // Receives the newsletter
89 define('__STATUS_VALUE', getMessage('NL_MEMBER_ON'));
90 define('__UNTIL_VALUE' , "");
91 define('NL_SUBMIT' , getMessage('NL_MEMBER_SUBMIT_OFF'));
94 case "N": // Does not receive the newsletter
95 define('__STATUS_VALUE', getMessage('NL_MEMBER_OFF'));
96 define('__UNTIL_VALUE' , MAKE_DATETIME($until, "2"));
97 define('NL_SUBMIT' , getMessage('NL_MEMBER_SUBMIT_ON'));
101 // Load template and member settings
102 LOAD_TEMPLATE("member_newsletter");