3 +--------------------------------------------------------------------+
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2018 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2018
33 class CRM_Mailing_Form_Optout
extends CRM_Core_Form
{
35 public function preProcess() {
37 $this->_type
= 'optout';
39 $this->_job_id
= $job_id = CRM_Utils_Request
::retrieve('jid', 'Integer', $this);
40 $this->_queue_id
= $queue_id = CRM_Utils_Request
::retrieve('qid', 'Integer', $this);
41 $this->_hash
= $hash = CRM_Utils_Request
::retrieve('h', 'String', $this);
47 CRM_Core_Error
::fatal(ts("Missing input parameters"));
50 // verify that the three numbers above match
51 $q = CRM_Mailing_Event_BAO_Queue
::verify($job_id, $queue_id, $hash);
53 CRM_Core_Error
::fatal(ts("There was an error in your request"));
56 list($displayName, $email) = CRM_Mailing_Event_BAO_Queue
::getContactInfo($queue_id);
57 $this->assign('display_name', $displayName);
58 $emailMasked = CRM_Utils_String
::maskEmail($email);
59 $this->assign('email_masked', $emailMasked);
60 $this->assign('email', $email);
61 $this->_email
= $email;
64 public function buildQuickForm() {
65 CRM_Utils_System
::addHTMLHead('<META NAME="ROBOTS" CONTENT="NOINDEX, NOFOLLOW">');
66 CRM_Utils_System
::setTitle(ts('Please Confirm Your Opt Out'));
68 $this->add('text', 'email_confirm', ts('Verify email address to opt out:'));
69 $this->addRule('email_confirm', ts('Email address is required to opt out.'), 'required');
74 'name' => ts('Opt Out'),
79 'name' => ts('Cancel'),
83 $this->addButtons($buttons);
86 public function postProcess() {
88 $values = $this->exportValues();
90 // check if EmailTyped matches Email address
91 $result = CRM_Utils_String
::compareStr($this->_email
, $values['email_confirm'], TRUE);
93 $job_id = $this->_job_id
;
94 $queue_id = $this->_queue_id
;
97 $confirmURL = CRM_Utils_System
::url("civicrm/mailing/{$this->_type}", "reset=1&jid={$job_id}&qid={$queue_id}&h={$hash}&confirm=1");
98 $this->assign('confirmURL', $confirmURL);
99 $session = CRM_Core_Session
::singleton();
100 $session->pushUserContext($confirmURL);
102 if ($result == TRUE) {
103 // Email address verified
104 if (CRM_Mailing_Event_BAO_Unsubscribe
::unsub_from_domain($job_id, $queue_id, $hash)) {
105 CRM_Mailing_Event_BAO_Unsubscribe
::send_unsub_response($queue_id, NULL, TRUE, $job_id);
108 $statusMsg = ts('Email: %1 has been successfully opted out',
109 array(1 => $values['email_confirm'])
112 CRM_Core_Session
::setStatus($statusMsg, '', 'success');
114 elseif ($result == FALSE) {
115 // Email address not verified
117 $statusMsg = ts('The email address: %1 you have entered does not match the email associated with this opt out request.',
118 array(1 => $values['email_confirm'])
121 CRM_Core_Session
::setStatus($statusMsg, '', 'fail');