HEX
Server: Apache/2.4.65 (Debian)
System: Linux wordpress-7cb4c6b6f6-qgbk2 5.15.0-131-generic #141-Ubuntu SMP Fri Jan 10 21:18:28 UTC 2025 x86_64
User: www-data (33)
PHP: 8.3.27
Disabled: NONE
Upload Files
File: /var/www/html/wp-content/plugins/post-smtp/Postman/Postman-Mail/PostmanResendTransport.php
<?php
if ( ! defined( 'ABSPATH' ) ) {
    exit; // Exit if accessed directly
}

require_once 'PostmanModuleTransport.php';

/**
 * Postman Resend Transport
 * 
 * @since 3.2.0
 * @version 1.0
 */
if( !class_exists( 'PostmanResendTransport' ) ):
class PostmanResendTransport extends PostmanAbstractModuleTransport implements PostmanModuleTransport {

    const SLUG = 'resend_api';
    const PORT = 443;
    const HOST = 'api.resend.com';
    const PRIORITY = 49000;
    const RESEND_AUTH_OPTIONS = 'postman_resend_auth_options';
    const RESEND_AUTH_SECTION = 'postman_resend_auth_section';

    /**
     * PostmanResendTransport constructor.
     * @param $rootPluginFilenameAndPath
     * @since 3.2.0
     * @version 1.0
     */
    public function __construct( $rootPluginFilenameAndPath ) {

        parent::__construct( $rootPluginFilenameAndPath );

        // add a hook on the plugins_loaded event
        add_action( 'admin_init', array( $this, 'on_admin_init' ) );

    }

    public function getProtocol() {
        return 'https';
    }

    // this should be standard across all transports
    public function getSlug() {
        return self::SLUG;
    }

    public function getName() {
        return __( 'Resend API', 'post-smtp' );
    }

    /**
     * v0.2.1
     *
     * @return string
     */
    public function getHostname() {
        return self::HOST;
    }

    /**
     * v0.2.1
     *
     * @return int
     */
    public function getPort() {
        return self::PORT;
    }

    /**
     * v1.7.0
     *
     * @return string
     */
    public function getTransportType() {
        return 'resend_api';
    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function getConfigurationBid( PostmanWizardSocket $hostData, $userAuthOverride, $originalSmtpServer ) {

        $recommendation = array();
        $recommendation ['priority'] = 0;
        $recommendation ['transport'] = self::SLUG;
        $recommendation ['hostname'] = null; // scribe looks this
        $recommendation ['label'] = $this->getName();
        $recommendation['logo_url'] = $this->getLogoURL();
        
        if ($hostData->hostname == self::HOST && $hostData->port == self::PORT) {
            $recommendation ['priority'] = self::PRIORITY;
            /* translators: where variables are (1) transport name (2) host and (3) port */
            $recommendation ['message'] = sprintf ( __ ( ('Postman recommends the %1$s to host %2$s on port %3$d.') ), $this->getName(), self::HOST, self::PORT );
        }

        return $recommendation;

    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function createMailEngine() {

        $api_key = $this->options->getResendApiKey();
        require_once 'PostmanResendMailEngine.php';
        $engine = new PostmanResendMailEngine( $api_key );

        return $engine;

    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function getDeliveryDetails() {
        /* translators: where (1) is the secure icon and (2) is the transport name */
        return sprintf ( __ ( 'Postman will send mail via the <b>%1$s %2$s</b>.', 'post-smtp' ), '🔐', $this->getName () );
    }

    /**
     * @param PostmanWizardSocket $socket
     * @param $winningRecommendation
     * @param $userSocketOverride
     * @param $userAuthOverride
     * @return array
     * @since 3.2.0
     * @version 1.0
     */
    public function populateConfiguration( $hostname ) {

        $response = parent::populateConfiguration( $hostname );
        $response [PostmanOptions::TRANSPORT_TYPE] = $this->getSlug();
        $response [PostmanOptions::PORT] = $this->getPort();
        $response [PostmanOptions::HOSTNAME] = $this->getHostname();
        $response [PostmanOptions::SECURITY_TYPE] = PostmanOptions::SECURITY_TYPE_SMTPS;
        $response [PostmanOptions::AUTHENTICATION_TYPE] = PostmanOptions::AUTHENTICATION_TYPE_OAUTH2;

        return $response;

    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function on_admin_init() {
        $this->addSettings();
        $this->registerStylesAndScripts();
    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function addSettings()
    {

        add_settings_section(
            self::RESEND_AUTH_SECTION,
            __('Authentication', 'post-smtp'),
            array( $this, 'printResendAuthSectionInfo' ),
            self::RESEND_AUTH_OPTIONS
        );

        add_settings_field(
            PostmanOptions::RESEND_API_KEY,
            __( 'API Key', 'post-smtp' ),
            array( $this, 'resend_api_key_callback' ),
            self::RESEND_AUTH_OPTIONS,
            self::RESEND_AUTH_SECTION
        );

    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function printResendAuthSectionInfo() {

        printf (
            '<p id="wizard_resend_auth_help">%s</p>', sprintf ( __ ( 'Create an account at <a href="%1$s" target="_blank">%2$s</a> and enter <a href="%3$s" target="_blank">an API key</a> below.', 'post-smtp' ),
                'https://resend.com/', 'resend.com', 'https://resend.com/api-keys' )
        );

    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function resend_api_key_callback() {

        printf(
            '<input type="password" autocomplete="off" id="resend_api_key" name="postman_options[resend_api_key]" value="%s" size="60" class="required ps-input ps-w-75" placeholder="%s"/>',
            null !== $this->options->getResendApiKey() ? esc_attr( PostmanUtils::obfuscatePassword( $this->options->getResendApiKey() ) ) : '',
            __( 'Required', 'post-smtp' )
        );
        print ' <input type="button" id="toggleResendApiKey" value="Show Password" class="button button-secondary" style="visibility:hidden" />';

    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function registerStylesAndScripts() {

        // register the stylesheet and javascript external resources
        $pluginData = apply_filters ( 'postman_get_plugin_metadata', null );
        wp_register_script (
            'postman-resend',
            plugins_url ( 'Postman/Postman-Mail/postman-resend.js', $this->rootPluginFilenameAndPath ),
            array (
                PostmanViewController::JQUERY_SCRIPT,
                'jquery_validation',
                PostmanViewController::POSTMAN_SCRIPT
            ),
            $pluginData['version']
        );

    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function enqueueScript() {

        wp_enqueue_script( 'postman-resend' );

    }

    /**
     * @since 3.2.0
     * @version 1.0
     */
    public function printWizardAuthenticationStep() {
        print '<section class="wizard_resend">';
        $this->printResendAuthSectionInfo();
        printf ( '<label for="api_key">%s</label>', __ ( 'API Key', 'post-smtp' ) );
        print '<br />';
        print $this->resend_api_key_callback();
        print '</section>';
    }

    /**
     * Get Resend's logo
     * 
     * @since 3.2.0
     * @version 1.0
     */
    public function getLogoURL() {

        return POST_SMTP_ASSETS . "images/logos/resend.png";

    }

    /**
     * Returns true, to prevent from errors because it's default Module Transport.
     * 
     * @since 3.2.0
     * @version 1.0
     */
    public function has_granted() {

        return true;

    }

    /**
     * (non-PHPdoc)
     *
     * @see PostmanTransport::getMisconfigurationMessage()
     * @since 3.2.0
     * @version 1.0
     */
    protected function validateTransportConfiguration() {
        $messages = parent::validateTransportConfiguration ();
        $apiKey = $this->options->getResendApiKey ();
        if (empty ( $apiKey )) {
            array_push ( $messages, __ ( 'API Key can not be empty', 'post-smtp' ) . '.' );
            $this->setNotConfiguredAndReady ();
        }
        if (! $this->isSenderConfigured ()) {
            array_push ( $messages, __ ( 'Message From Address can not be empty', 'post-smtp' ) . '.' );
            $this->setNotConfiguredAndReady ();
        }
        return $messages;
    }

    /**
     *
     * @param mixed $data     
     * @since 3.2.0
     * @version 1.0   	
     */
    public function prepareOptionsForExport($data) {
        $data = parent::prepareOptionsForExport ( $data );
        $data [PostmanOptions::RESEND_API_KEY] = PostmanOptions::getInstance ()->getResendApiKey ();
        return $data;
    }
}
endif;