%PDF- %PDF-
Direktori : /var/www/html/itworks/wp-content/plugins/wp-mail-smtp/src/Providers/Sendgrid/ |
Current File : /var/www/html/itworks/wp-content/plugins/wp-mail-smtp/src/Providers/Sendgrid/Mailer.php |
<?php namespace WPMailSMTP\Providers\Sendgrid; use WPMailSMTP\Providers\MailerAbstract; /** * Class Mailer. * * @since 1.0.0 */ class Mailer extends MailerAbstract { /** * Which response code from HTTP provider is considered to be successful? * * @var int */ protected $email_sent_code = 202; /** * URL to make an API request to. * * @var string */ protected $url = 'https://api.sendgrid.com/v3/mail/send'; /** * Mailer constructor. * * @since 1.0.0 * * @param \WPMailSMTP\MailCatcher $phpmailer */ public function __construct( $phpmailer ) { // We want to prefill everything from \WPMailSMTP\MailCatcher class, which extends \PHPMailer. parent::__construct( $phpmailer ); $this->set_header( 'Authorization', 'Bearer ' . $this->options->get( $this->mailer, 'api_key' ) ); $this->set_header( 'content-type', 'application/json' ); } /** * Redefine the way email body is returned. * By default we are sending an array of data. * SendGrid requires a JSON, so we encode the body. * * @since 1.0.0 */ public function get_body() { $body = parent::get_body(); return function_exists( 'wp_json_encode' ) ? wp_json_encode( $body ) : json_encode( $body ); // phpcs:ignore } /** * @inheritdoc */ public function set_from( $email, $name = '' ) { if ( ! filter_var( $email, FILTER_VALIDATE_EMAIL ) ) { return; } $from['email'] = $email; if ( ! empty( $name ) ) { $from['name'] = $name; } $this->set_body_param( array( 'from' => $from, ) ); } /** * @inheritdoc */ public function set_recipients( $recipients ) { if ( empty( $recipients ) ) { return; } // Allow for now only these recipient types. $default = array( 'to', 'cc', 'bcc' ); $data = array(); foreach ( $recipients as $type => $emails ) { if ( ! in_array( $type, $default, true ) || empty( $emails ) || ! is_array( $emails ) ) { continue; } $data[ $type ] = array(); // Iterate over all emails for each type. // There might be multiple cc/to/bcc emails. foreach ( $emails as $email ) { $holder = array(); $addr = isset( $email[0] ) ? $email[0] : false; $name = isset( $email[1] ) ? $email[1] : false; if ( ! filter_var( $addr, FILTER_VALIDATE_EMAIL ) ) { continue; } $holder['email'] = $addr; if ( ! empty( $name ) ) { $holder['name'] = $name; } array_push( $data[ $type ], $holder ); } } if ( ! empty( $data ) ) { $this->set_body_param( array( 'personalizations' => array( $data ), ) ); } } /** * @inheritdoc */ public function set_content( $content ) { if ( empty( $content ) ) { return; } if ( is_array( $content ) ) { $default = array( 'text', 'html' ); $data = array(); foreach ( $content as $type => $body ) { if ( ! in_array( $type, $default, true ) || empty( $body ) ) { continue; } $content_type = 'text/plain'; $content_value = $body; if ( $type === 'html' ) { $content_type = 'text/html'; } $data[] = array( 'type' => $content_type, 'value' => $content_value, ); } $this->set_body_param( array( 'content' => $data, ) ); } else { $data['type'] = 'text/html'; $data['value'] = $content; if ( $this->phpmailer->ContentType === 'text/plain' ) { $data['type'] = 'text/plain'; } $this->set_body_param( array( 'content' => array( $data ), ) ); } } /** * SendGrid accepts an array of files content in body, so we will include all files and send. * Doesn't handle exceeding the limits etc, as this is done and reported be SendGrid API. * * @since 1.0.0 * * @param array $attachments */ public function set_attachments( $attachments ) { if ( empty( $attachments ) ) { return; } $data = array(); foreach ( $attachments as $attachment ) { $file = false; /* * We are not using WP_Filesystem API as we can't reliably work with it. * It is not always available, same as credentials for FTP. */ try { if ( is_file( $attachment[0] ) && is_readable( $attachment[0] ) ) { $file = file_get_contents( $attachment[0] ); } } catch ( \Exception $e ) { $file = false; } if ( $file === false ) { continue; } $data[] = array( 'content' => base64_encode( $file ), 'type' => $attachment[4], 'filename' => $attachment[2], 'disposition' => $attachment[6], ); } if ( ! empty( $data ) ) { $this->set_body_param( array( 'attachments' => $data, ) ); } } /** * @inheritdoc */ public function set_reply_to( $reply_to ) { if ( empty( $reply_to ) ) { return; } $data = array(); foreach ( $reply_to as $key => $emails ) { if ( empty( $emails ) || ! is_array( $emails ) ) { continue; } $addr = isset( $emails[0] ) ? $emails[0] : false; $name = isset( $emails[1] ) ? $emails[1] : false; if ( ! filter_var( $addr, FILTER_VALIDATE_EMAIL ) ) { continue; } $data['email'] = $addr; if ( ! empty( $name ) ) { $data['name'] = $name; } break; } if ( ! empty( $data ) ) { $this->set_body_param( array( 'reply_to' => $data, ) ); } } /** * SendGrid doesn't support sender or return_path params. * So we do nothing. * * @since 1.0.0 * * @param string $email */ public function set_return_path( $email ) { } /** * Get a SendGrid-specific response with a helpful error. * * @since 1.2.0 * * @return string */ protected function get_response_error() { $body = (array) wp_remote_retrieve_body( $this->response ); $error_text = array(); if ( ! empty( $body['errors'] ) ) { foreach ( $body['errors'] as $error ) { if ( property_exists( $error, 'message' ) ) { // Prepare additional information from SendGrid API. $extra = ''; if ( property_exists( $error, 'field' ) && ! empty( $error->field ) ) { $extra .= $error->field . '; '; } if ( property_exists( $error, 'help' ) && ! empty( $error->help ) ) { $extra .= $error->help; } // Assign both the main message and perhaps extra information, if exists. $error_text[] = $error->message . ( ! empty( $extra ) ? ' - ' . $extra : '' ); } } } return implode( '<br>', array_map( 'esc_textarea', $error_text ) ); } /** * @inheritdoc */ public function get_debug_info() { $mg_text = array(); $options = new \WPMailSMTP\Options(); $mailgun = $options->get_group( 'sendgrid' ); $mg_text[] = '<strong>Api Key:</strong> ' . ( ! empty( $mailgun['api_key'] ) ? 'Yes' : 'No' ); return implode( '<br>', $mg_text ); } /** * @inheritdoc */ public function is_mailer_complete() { $options = $this->options->get_group( $this->mailer ); // API key is the only required option. if ( ! empty( $options['api_key'] ) ) { return true; } return false; } }