Here is the complete “how to” to display different templates, based on the given campaign, as a result for the opt-in click.
First there are a few updates to the module campaign needed:
Inside studio add a new field called “campaign_optin_template_c” to the campaign module. This will hold the template information for the Opt-In response itself and overrides the default file “include/EntryPointConfirmOptIn.tpl”. You can place your templates in the following location:
custom/include/
Just keep in mind to name it correctly to match the content of the field “campaign_optin_template_c” inside your campaign.
Now on to the code additions which are needed.
- Create a new entry point that overrides the default mechanism for “ConfirmOptIn” in the following folder:
custom/Extension/application/Ext/EntryPointRegistry/
I´ve called the file “extOptIn.php” . This overrides the original entry point “ConfirmOptIn”, which is located here: include/MVC/Controller/entry_point_registry.php
<?php
$entry_point_registry['ConfirmOptIn'] = array(
'file' => 'custom/include/entryPointOptInConnector.php',
'auth' => false,
);
- Create a custom connector for the override in the following location:
custom/include/
I´ve called the file “entryPointOptInConnector.php”.
<?php
if (!defined('sugarEntry') || !sugarEntry) {
die('Not A Valid Entry Point');
}
require_once __DIR__ . '/../include/EntryPointConfirmOptInHandler.php';
new EntryPointConfirmOptInHandler();
- Create a handler for the new connector inside the following location:
custom/include/
I´ve called the file “EntryPointConfirmOptInHandler.php”
The code is based on the original code from “include/EntryPointConfirmOptInHandler.php”, but modified.
<?php
if (!defined('sugarEntry') || !sugarEntry) {
die('Not A Valid Entry Point');
}
/**
* Class EntryPointConfirmOptInHandler
*/
class EntryPointConfirmOptInHandler
{
/**
* @var EmailAddress $emailAddress
*/
private $emailAddress;
/**
*
* @param array $request
* @param array $post
*/
public function __construct($request = null, $post = null)
{
if (is_null($request)) {
$request = $_REQUEST;
}
if (is_null($post)) {
$post = $_POST;
}
$method = isset($request['method']) && $request['method'] ? $request['method'] : null;
$output = $this->callMethod($method, $post, $request);
echo $output;
sugar_cleanup();
}
/**
*
* @param string $method
* @param array $post
* @param array $request
* @return string
*/
protected function callMethod($method, $post, $request)
{
switch ($method) {
case 'confirmOptInSelected':
$output = $this->methodConfirmOptInSelected($post);
break;
default:
$output = $this->methodConfirmOptInUser($request);
break;
}
return $output;
}
/**
* @global array $app_strings
* @param array $post
* @return string|boolean
*/
private function methodConfirmOptInSelected($post)
{
global $app_strings;
$configurator = new Configurator();
if (!$configurator->isConfirmOptInEnabled()) {
return false;
}
$module = $post['module'];
$uids = explode(',', $post['uid']);
$confirmedOptInEmailsSent = 0;
$errors = 0;
$warnings = 0;
$msg = '';
foreach ($uids as $uid) {
$emailMan = new EmailMan();
if (!$emailMan->addOptInEmailToEmailQueue($module, $uid)) {
$errors++;
} elseif ($emailMan->getLastOptInWarn()) {
$warnings++;
} else {
$confirmedOptInEmailsSent++;
}
}
if ($confirmedOptInEmailsSent > 0) {
$msg .= sprintf($app_strings['RESPONSE_SEND_CONFIRM_OPT_IN_EMAIL'], $confirmedOptInEmailsSent);
}
if ($warnings > 0) {
$msg .= sprintf($app_strings['RESPONSE_SEND_CONFIRM_OPT_IN_EMAIL_NOT_OPT_IN'], $warnings);
}
if ($errors > 0) {
$msg .= sprintf($app_strings['RESPONSE_SEND_CONFIRM_OPT_IN_EMAIL_MISSING_EMAIL_ADDRESS_ID'], $errors);
}
return $msg;
}
/**
* Confirm Opt In User
*
* @param array $request
* @return string
*/
private function methodConfirmOptInUser($request)
{
$emailAddress = BeanFactory::getBean('EmailAddresses');
$this->emailAddress = $emailAddress->retrieve_by_string_fields([
'confirm_opt_in_token' => $request['from']
]);
if ($this->emailAddress) {
$this->emailAddress->confirmOptIn();
$this->emailAddress->save();
$people = $this->getIDs($this->emailAddress->email_address, 'Contacts');
if ($people) {
$this->setLawfulBasisForEachPerson($people, 'Contacts');
$personid=$people;
}
$people = $this->getIDs($this->emailAddress->email_address, 'Leads');
if ($people) {
$this->setLawfulBasisForEachPerson($people, 'Leads');
$personid=$people;
}
$people = $this->getIDs($this->emailAddress->email_address, 'Prospects');
if ($people) {
$this->setLawfulBasisForEachPerson($people, 'Prospects');
$personid=$people;
}
}
$template = new Sugar_Smarty();
$template->assign('FOCUS', $this->emailAddress);
$optInUser = BeanFactory::getBean('Contacts',current($personid));
$targetCampaign = BeanFactory::getBean('Campaigns', $optInUser->campaign_id);
if ( empty ( $targetCampaign->campaign_optin_template_c ) ){
return $template->fetch('include/EntryPointConfirmOptIn.tpl');
}else{
return $template->fetch($targetCampaign->campaign_optin_template_c);
}
}
/**
* @param String $email
* @param String $module
*
* @return array|bool
*/
private function getIDs($email, $module) {
$people = $this->emailAddress->getRelatedId($email, $module);
return $people;
}
/**
* @param array $people
*/
private function setLawfulBasisForEachPerson(array $people, $module) {
/** @var Person $person */
foreach ($people as $person) {
$bean = BeanFactory::getBean($module, $person);
if($bean) {
if(!$bean->setLawfulBasis('consent', 'email')){
LoggerManager::getLogger()->warn('Lawful basis saving failed for record ' . $bean->name);
}
}
}
}
}
The magic itself happens in the following part of the code, which needs to be modified:
private function methodConfirmOptInUser($request)
{
$emailAddress = BeanFactory::getBean('EmailAddresses');
$this->emailAddress = $emailAddress->retrieve_by_string_fields([
'confirm_opt_in_token' => $request['from']
]);
if ($this->emailAddress) {
$this->emailAddress->confirmOptIn();
$this->emailAddress->save();
$people = $this->getIDs($this->emailAddress->email_address, 'Contacts');
if ($people) {
$this->setLawfulBasisForEachPerson($people, 'Contacts');
$personid=$people;
}
$people = $this->getIDs($this->emailAddress->email_address, 'Leads');
if ($people) {
$this->setLawfulBasisForEachPerson($people, 'Leads');
$personid=$people;
}
$people = $this->getIDs($this->emailAddress->email_address, 'Prospects');
if ($people) {
$this->setLawfulBasisForEachPerson($people, 'Prospects');
$personid=$people;
}
}
$template = new Sugar_Smarty();
$template->assign('FOCUS', $this->emailAddress);
$optInUser = BeanFactory::getBean('Contacts',current($personid));
$targetCampaign = BeanFactory::getBean('Campaigns', $optInUser->campaign_id);
if ( empty ( $targetCampaign->campaign_optin_template_c ) ){
return $template->fetch('include/EntryPointConfirmOptIn.tpl');
}else{
return $template->fetch($targetCampaign->campaign_optin_template_c);
}
}
This function now fetches the correct template given by the confirm_opt_in_token. That´s it.