Remove functions from EmailCommon that were moved to the trait
authoreileen <emcnaughton@wikimedia.org>
Mon, 14 Dec 2020 19:40:50 +0000 (08:40 +1300)
committereileen <emcnaughton@wikimedia.org>
Mon, 14 Dec 2020 23:49:22 +0000 (12:49 +1300)
CRM/Contact/Form/Task/EmailCommon.php

index 1244b44f3a0db7d23f2d55c09b09349e48e98bbf..02a4df9d54593b0f8ebecaa190a799b732f44142 100644 (file)
  */
 class CRM_Contact_Form_Task_EmailCommon {
 
-  const MAX_EMAILS_KILL_SWITCH = 50;
-
-  public $_contactDetails = [];
-
-  public $_allContactDetails = [];
-
-  public $_toContactEmails = [];
-
   /**
    * Pre Process Form Addresses to be used in Quickform
    *
@@ -79,243 +71,6 @@ class CRM_Contact_Form_Task_EmailCommon {
     $form->setDefaults($defaults);
   }
 
-  /**
-   * Build the form object.
-   *
-   * @param CRM_Core_Form $form
-   *
-   * @throws \CRM_Core_Exception
-   */
-  public static function buildQuickForm(&$form) {
-    CRM_Core_Error::deprecatedFunctionWarning('This code is no longer used in core and will be removed');
-    $toArray = $ccArray = $bccArray = [];
-    $suppressedEmails = 0;
-    //here we are getting logged in user id as array but we need target contact id. CRM-5988
-    $cid = $form->get('cid');
-    if ($cid) {
-      $form->_contactIds = explode(',', $cid);
-    }
-    if (count($form->_contactIds) > 1) {
-      $form->_single = FALSE;
-    }
-    CRM_Contact_Form_Task_EmailCommon::bounceIfSimpleMailLimitExceeded(count($form->_contactIds));
-
-    $emailAttributes = [
-      'class' => 'huge',
-    ];
-    $to = $form->add('text', 'to', ts('To'), $emailAttributes, TRUE);
-    $cc = $form->add('text', 'cc_id', ts('CC'), $emailAttributes);
-    $bcc = $form->add('text', 'bcc_id', ts('BCC'), $emailAttributes);
-
-    if ($to->getValue()) {
-      $form->_toContactIds = $form->_contactIds = [];
-    }
-    $setDefaults = TRUE;
-    if (property_exists($form, '_context') && $form->_context == 'standalone') {
-      $setDefaults = FALSE;
-    }
-
-    $elements = ['to', 'cc', 'bcc'];
-    $form->_allContactIds = $form->_toContactIds = $form->_contactIds;
-    foreach ($elements as $element) {
-      if ($$element->getValue()) {
-
-        foreach (self::getEmails($$element) as $value) {
-          $contactId = $value['contact_id'];
-          $email = $value['email'];
-          if ($contactId) {
-            switch ($element) {
-              case 'to':
-                $form->_contactIds[] = $form->_toContactIds[] = $contactId;
-                $form->_toContactEmails[] = $email;
-                break;
-
-              case 'cc':
-                $form->_ccContactIds[] = $contactId;
-                break;
-
-              case 'bcc':
-                $form->_bccContactIds[] = $contactId;
-                break;
-            }
-
-            $form->_allContactIds[] = $contactId;
-          }
-        }
-
-        $setDefaults = TRUE;
-      }
-    }
-
-    //get the group of contacts as per selected by user in case of Find Activities
-    if (!empty($form->_activityHolderIds)) {
-      $contact = $form->get('contacts');
-      $form->_allContactIds = $form->_contactIds = $contact;
-    }
-
-    // check if we need to setdefaults and check for valid contact emails / communication preferences
-    if (is_array($form->_allContactIds) && $setDefaults) {
-      $returnProperties = [
-        'sort_name' => 1,
-        'email' => 1,
-        'do_not_email' => 1,
-        'is_deceased' => 1,
-        'on_hold' => 1,
-        'display_name' => 1,
-        'preferred_mail_format' => 1,
-      ];
-
-      // get the details for all selected contacts ( to, cc and bcc contacts )
-      list($form->_contactDetails) = CRM_Utils_Token::getTokenDetails($form->_allContactIds,
-        $returnProperties,
-        FALSE,
-        FALSE
-      );
-
-      // make a copy of all contact details
-      $form->_allContactDetails = $form->_contactDetails;
-
-      // perform all validations on unique contact Ids
-      foreach (array_unique($form->_allContactIds) as $key => $contactId) {
-        $value = $form->_contactDetails[$contactId];
-        if ($value['do_not_email'] || empty($value['email']) || !empty($value['is_deceased']) || $value['on_hold']) {
-          $suppressedEmails++;
-
-          // unset contact details for contacts that we won't be sending email. This is prevent extra computation
-          // during token evaluation etc.
-          unset($form->_contactDetails[$contactId]);
-        }
-        else {
-          $email = $value['email'];
-
-          // build array's which are used to setdefaults
-          if (in_array($contactId, $form->_toContactIds)) {
-            $form->_toContactDetails[$contactId] = $form->_contactDetails[$contactId];
-            // If a particular address has been specified as the default, use that instead of contact's primary email
-            if (!empty($form->_toEmail) && $form->_toEmail['contact_id'] == $contactId) {
-              $email = $form->_toEmail['email'];
-            }
-            $toArray[] = [
-              'text' => '"' . $value['sort_name'] . '" <' . $email . '>',
-              'id' => "$contactId::{$email}",
-            ];
-          }
-          elseif (in_array($contactId, $form->_ccContactIds)) {
-            $ccArray[] = [
-              'text' => '"' . $value['sort_name'] . '" <' . $email . '>',
-              'id' => "$contactId::{$email}",
-            ];
-          }
-          elseif (in_array($contactId, $form->_bccContactIds)) {
-            $bccArray[] = [
-              'text' => '"' . $value['sort_name'] . '" <' . $email . '>',
-              'id' => "$contactId::{$email}",
-            ];
-          }
-        }
-      }
-
-      if (empty($toArray)) {
-        CRM_Core_Error::statusBounce(ts('Selected contact(s) do not have a valid email address, or communication preferences specify DO NOT EMAIL, or they are deceased or Primary email address is On Hold.'));
-      }
-    }
-
-    $form->assign('toContact', json_encode($toArray));
-    $form->assign('ccContact', json_encode($ccArray));
-    $form->assign('bccContact', json_encode($bccArray));
-
-    $form->assign('suppressedEmails', $suppressedEmails);
-
-    $form->assign('totalSelectedContacts', count($form->_contactIds));
-
-    $form->add('text', 'subject', ts('Subject'), 'size=50 maxlength=254', TRUE);
-
-    $form->add('select', 'from_email_address', ts('From'), $form->_fromEmails, TRUE);
-
-    CRM_Mailing_BAO_Mailing::commonCompose($form);
-
-    // add attachments
-    CRM_Core_BAO_File::buildAttachment($form, NULL);
-
-    if ($form->_single) {
-      // also fix the user context stack
-      if ($form->_caseId) {
-        $ccid = CRM_Core_DAO::getFieldValue('CRM_Case_DAO_CaseContact', $form->_caseId,
-          'contact_id', 'case_id'
-        );
-        $url = CRM_Utils_System::url('civicrm/contact/view/case',
-          "&reset=1&action=view&cid={$ccid}&id={$form->_caseId}"
-        );
-      }
-      elseif ($form->_context) {
-        $url = CRM_Utils_System::url('civicrm/dashboard', 'reset=1');
-      }
-      else {
-        $url = CRM_Utils_System::url('civicrm/contact/view',
-          "&show=1&action=browse&cid={$form->_contactIds[0]}&selectedChild=activity"
-        );
-      }
-
-      $session = CRM_Core_Session::singleton();
-      $session->replaceUserContext($url);
-      $form->addDefaultButtons(ts('Send Email'), 'upload', 'cancel');
-    }
-    else {
-      $form->addDefaultButtons(ts('Send Email'), 'upload');
-    }
-
-    $fields = [
-      'followup_assignee_contact_id' => [
-        'type' => 'entityRef',
-        'label' => ts('Assigned to'),
-        'attributes' => [
-          'multiple' => TRUE,
-          'create' => TRUE,
-          'api' => ['params' => ['is_deceased' => 0]],
-        ],
-      ],
-      'followup_activity_type_id' => [
-        'type' => 'select',
-        'label' => ts('Followup Activity'),
-        'attributes' => ['' => '- ' . ts('select activity') . ' -'] + CRM_Core_PseudoConstant::ActivityType(FALSE),
-        'extra' => ['class' => 'crm-select2'],
-      ],
-      'followup_activity_subject' => [
-        'type' => 'text',
-        'label' => ts('Subject'),
-        'attributes' => CRM_Core_DAO::getAttribute('CRM_Activity_DAO_Activity',
-          'subject'
-        ),
-      ],
-    ];
-
-    //add followup date
-    $form->add('datepicker', 'followup_date', ts('in'));
-
-    foreach ($fields as $field => $values) {
-      if (!empty($fields[$field])) {
-        $attribute = $values['attributes'] ?? NULL;
-        $required = !empty($values['required']);
-
-        if ($values['type'] == 'select' && empty($attribute)) {
-          $form->addSelect($field, ['entity' => 'activity'], $required);
-        }
-        elseif ($values['type'] == 'entityRef') {
-          $form->addEntityRef($field, $values['label'], $attribute, $required);
-        }
-        else {
-          $form->add($values['type'], $field, $values['label'], $attribute, $required, CRM_Utils_Array::value('extra', $values));
-        }
-      }
-    }
-
-    //Added for CRM-15984: Add campaign field
-    CRM_Campaign_BAO_Campaign::addCampaign($form);
-
-    $form->addFormRule(['CRM_Contact_Form_Task_EmailCommon', 'formRule'], $form);
-    CRM_Core_Resources::singleton()->addScriptFile('civicrm', 'templates/CRM/Contact/Form/Task/EmailCommon.js', 0, 'html-header');
-  }
-
   /**
    * Form rule.
    *
@@ -346,280 +101,4 @@ class CRM_Contact_Form_Task_EmailCommon {
     return empty($errors) ? TRUE : $errors;
   }
 
-  /**
-   * Process the form after the input has been submitted and validated.
-   *
-   * @param CRM_Core_Form $form
-   *
-   * @throws \CRM_Core_Exception
-   * @throws \CiviCRM_API3_Exception
-   * @throws \Civi\API\Exception\UnauthorizedException
-   */
-  public static function postProcess(&$form) {
-    CRM_Core_Error::deprecatedFunctionWarning('This code is no longer used in core and will be removed');
-
-    self::bounceIfSimpleMailLimitExceeded(count($form->_contactIds));
-
-    // check and ensure that
-    $formValues = $form->controller->exportValues($form->getName());
-    self::submit($form, $formValues);
-  }
-
-  /**
-   * Submit the form values.
-   *
-   * This is also accessible for testing.
-   *
-   * @param CRM_Core_Form $form
-   * @param array $formValues
-   *
-   * @throws \CRM_Core_Exception
-   * @throws \CiviCRM_API3_Exception
-   * @throws \Civi\API\Exception\UnauthorizedException
-   */
-  public static function submit(&$form, $formValues) {
-    CRM_Core_Error::deprecatedFunctionWarning('This code is no longer used in core and will be removed');
-
-    self::saveMessageTemplate($formValues);
-
-    $from = $formValues['from_email_address'] ?? NULL;
-    // dev/core#357 User Emails are keyed by their id so that the Signature is able to be added
-    // If we have had a contact email used here the value returned from the line above will be the
-    // numerical key where as $from for use in the sendEmail in Activity needs to be of format of "To Name" <toemailaddress>
-    $from = CRM_Utils_Mail::formatFromAddress($from);
-    $subject = $formValues['subject'];
-
-    // CRM-13378: Append CC and BCC information at the end of Activity Details and format cc and bcc fields
-    $elements = ['cc_id', 'bcc_id'];
-    $additionalDetails = NULL;
-    $ccValues = $bccValues = [];
-    foreach ($elements as $element) {
-      if (!empty($formValues[$element])) {
-        $allEmails = explode(',', $formValues[$element]);
-        foreach ($allEmails as $value) {
-          list($contactId, $email) = explode('::', $value);
-          $contactURL = CRM_Utils_System::url('civicrm/contact/view', "reset=1&force=1&cid={$contactId}", TRUE);
-          switch ($element) {
-            case 'cc_id':
-              $ccValues['email'][] = '"' . $form->_contactDetails[$contactId]['sort_name'] . '" <' . $email . '>';
-              $ccValues['details'][] = "<a href='{$contactURL}'>" . $form->_contactDetails[$contactId]['display_name'] . "</a>";
-              break;
-
-            case 'bcc_id':
-              $bccValues['email'][] = '"' . $form->_contactDetails[$contactId]['sort_name'] . '" <' . $email . '>';
-              $bccValues['details'][] = "<a href='{$contactURL}'>" . $form->_contactDetails[$contactId]['display_name'] . "</a>";
-              break;
-          }
-        }
-      }
-    }
-
-    $cc = $bcc = '';
-    if (!empty($ccValues)) {
-      $cc = implode(',', $ccValues['email']);
-      $additionalDetails .= "\ncc : " . implode(", ", $ccValues['details']);
-    }
-    if (!empty($bccValues)) {
-      $bcc = implode(',', $bccValues['email']);
-      $additionalDetails .= "\nbcc : " . implode(", ", $bccValues['details']);
-    }
-
-    // CRM-5916: prepend case id hash to CiviCase-originating emails’ subjects
-    if (isset($form->_caseId) && is_numeric($form->_caseId)) {
-      $hash = substr(sha1(CIVICRM_SITE_KEY . $form->_caseId), 0, 7);
-      $subject = "[case #$hash] $subject";
-    }
-
-    $attachments = [];
-    CRM_Core_BAO_File::formatAttachment($formValues,
-      $attachments,
-      NULL, NULL
-    );
-
-    // format contact details array to handle multiple emails from same contact
-    $formattedContactDetails = [];
-    $tempEmails = [];
-    foreach ($form->_contactIds as $key => $contactId) {
-      // if we dont have details on this contactID, we should ignore
-      // potentially this is due to the contact not wanting to receive email
-      if (!isset($form->_contactDetails[$contactId])) {
-        continue;
-      }
-      $email = $form->_toContactEmails[$key];
-      // prevent duplicate emails if same email address is selected CRM-4067
-      // we should allow same emails for different contacts
-      $emailKey = "{$contactId}::{$email}";
-      if (!in_array($emailKey, $tempEmails)) {
-        $tempEmails[] = $emailKey;
-        $details = $form->_contactDetails[$contactId];
-        $details['email'] = $email;
-        unset($details['email_id']);
-        $formattedContactDetails[] = $details;
-      }
-    }
-
-    $contributionIds = [];
-    if ($form->getVar('_contributionIds')) {
-      $contributionIds = $form->getVar('_contributionIds');
-    }
-
-    // send the mail
-    list($sent, $activityId) = CRM_Activity_BAO_Activity::sendEmail(
-      $formattedContactDetails,
-      $subject,
-      $formValues['text_message'],
-      $formValues['html_message'],
-      NULL,
-      NULL,
-      $from,
-      $attachments,
-      $cc,
-      $bcc,
-      array_keys($form->_toContactDetails),
-      $additionalDetails,
-      $contributionIds,
-      CRM_Utils_Array::value('campaign_id', $formValues),
-      $form->getVar('_caseId')
-    );
-
-    $followupStatus = '';
-    if ($sent) {
-      $followupActivity = NULL;
-      if (!empty($formValues['followup_activity_type_id'])) {
-        $params['followup_activity_type_id'] = $formValues['followup_activity_type_id'];
-        $params['followup_activity_subject'] = $formValues['followup_activity_subject'];
-        $params['followup_date'] = $formValues['followup_date'];
-        $params['target_contact_id'] = $form->_contactIds;
-        $params['followup_assignee_contact_id'] = explode(',', $formValues['followup_assignee_contact_id']);
-        $followupActivity = CRM_Activity_BAO_Activity::createFollowupActivity($activityId, $params);
-        $followupStatus = ts('A followup activity has been scheduled.');
-
-        if (Civi::settings()->get('activity_assignee_notification')) {
-          if ($followupActivity) {
-            $mailToFollowupContacts = [];
-            $assignee = [$followupActivity->id];
-            $assigneeContacts = CRM_Activity_BAO_ActivityAssignment::getAssigneeNames($assignee, TRUE, FALSE);
-            foreach ($assigneeContacts as $values) {
-              $mailToFollowupContacts[$values['email']] = $values;
-            }
-
-            $sentFollowup = CRM_Activity_BAO_Activity::sendToAssignee($followupActivity, $mailToFollowupContacts);
-            if ($sentFollowup) {
-              $followupStatus .= '<br />' . ts("A copy of the follow-up activity has also been sent to follow-up assignee contacts(s).");
-            }
-          }
-        }
-      }
-
-      $count_success = count($form->_toContactDetails);
-      CRM_Core_Session::setStatus(ts('One message was sent successfully. ', [
-        'plural' => '%count messages were sent successfully. ',
-        'count' => $count_success,
-      ]) . $followupStatus, ts('Message Sent', ['plural' => 'Messages Sent', 'count' => $count_success]), 'success');
-    }
-
-    // Display the name and number of contacts for those email is not sent.
-    // php 5.4 throws out a notice since the values of these below arrays are arrays.
-    // the behavior is not documented in the php manual, but it does the right thing
-    // suppressing the notices to get things in good shape going forward
-    $emailsNotSent = @array_diff_assoc($form->_allContactDetails, $form->_contactDetails);
-
-    if ($emailsNotSent) {
-      $not_sent = [];
-      foreach ($emailsNotSent as $contactId => $values) {
-        $displayName = $values['display_name'];
-        $email = $values['email'];
-        $contactViewUrl = CRM_Utils_System::url('civicrm/contact/view', "reset=1&cid=$contactId");
-        $not_sent[] = "<a href='$contactViewUrl' title='$email'>$displayName</a>" . ($values['on_hold'] ? '(' . ts('on hold') . ')' : '');
-      }
-      $status = '(' . ts('because no email address on file or communication preferences specify DO NOT EMAIL or Contact is deceased or Primary email address is On Hold') . ')<ul><li>' . implode('</li><li>', $not_sent) . '</li></ul>';
-      CRM_Core_Session::setStatus($status, ts('One Message Not Sent', [
-        'count' => count($emailsNotSent),
-        'plural' => '%count Messages Not Sent',
-      ]), 'info');
-    }
-
-    if (isset($form->_caseId)) {
-      // if case-id is found in the url, create case activity record
-      $cases = explode(',', $form->_caseId);
-      foreach ($cases as $key => $val) {
-        if (is_numeric($val)) {
-          $caseParams = [
-            'activity_id' => $activityId,
-            'case_id' => $val,
-          ];
-          CRM_Case_BAO_Case::processCaseActivity($caseParams);
-        }
-      }
-    }
-  }
-
-  /**
-   * Save the template if update selected.
-   *
-   * @param array $formValues
-   *
-   * @throws \CiviCRM_API3_Exception
-   * @throws \Civi\API\Exception\UnauthorizedException
-   */
-  protected static function saveMessageTemplate($formValues) {
-    CRM_Core_Error::deprecatedFunctionWarning('This code is no longer used in core and will be removed');
-
-    if (!empty($formValues['saveTemplate']) || !empty($formValues['updateTemplate'])) {
-      $messageTemplate = [
-        'msg_text' => $formValues['text_message'],
-        'msg_html' => $formValues['html_message'],
-        'msg_subject' => $formValues['subject'],
-        'is_active' => TRUE,
-      ];
-
-      if (!empty($formValues['saveTemplate'])) {
-        $messageTemplate['msg_title'] = $formValues['saveTemplateName'];
-        CRM_Core_BAO_MessageTemplate::add($messageTemplate);
-      }
-
-      if (!empty($formValues['template']) && !empty($formValues['updateTemplate'])) {
-        $messageTemplate['id'] = $formValues['template'];
-        unset($messageTemplate['msg_title']);
-        CRM_Core_BAO_MessageTemplate::add($messageTemplate);
-      }
-    }
-  }
-
-  /**
-   * Bounce if there are more emails than permitted.
-   *
-   * @param int $count
-   *  The number of emails the user is attempting to send
-   */
-  public static function bounceIfSimpleMailLimitExceeded($count) {
-    CRM_Core_Error::deprecatedFunctionWarning('This code is no longer used in core and will be removed');
-
-    $limit = Civi::settings()->get('simple_mail_limit');
-    if ($count > $limit) {
-      CRM_Core_Error::statusBounce(ts('Please do not use this task to send a lot of emails (greater than %1). Many countries have legal requirements when sending bulk emails and the CiviMail framework has opt out functionality and domain tokens to help meet these.',
-        [1 => $limit]
-      ));
-    }
-  }
-
-  /**
-   * Get the emails from the added element.
-   *
-   * @param HTML_QuickForm_Element $element
-   *
-   * @return array
-   */
-  protected static function getEmails($element): array {
-    CRM_Core_Error::deprecatedFunctionWarning('This code is no longer used in core and will be removed');
-
-    $allEmails = explode(',', $element->getValue());
-    $return = [];
-    foreach ($allEmails as $value) {
-      $values = explode('::', $value);
-      $return[] = ['contact_id' => $values[0], 'email' => $values[1]];
-    }
-    return $return;
-  }
-
 }