Source: includes/internal/emails/generators/class-email-generators-abstract.php

<?php
/**
 * File containing the Email_Generators_Abstract class.
 *
 * @package sensei
 */

namespace Sensei\Internal\Emails\Generators;

use Sensei\Internal\Emails\Email_Repository;

if ( ! defined( 'ABSPATH' ) ) {
	exit;
}

/**
 * Class Email_Generators_Abstract
 *
 * @internal
 *
 * @since 4.12.0
 */
abstract class Email_Generators_Abstract {

	/**
	 * Identifier of the email.
	 *
	 * @var string
	 */
	const IDENTIFIER_NAME = '';

	/**
	 * Identifier used in usage tracking.
	 *
	 * @var string
	 */
	const USAGE_TRACKING_TYPE = '';

	/**
	 * Email_Repository instance.
	 *
	 * @var Email_Repository
	 */
	protected $repository;

	/**
	 * All registered actions.
	 *
	 * @var array
	 */
	private $actions = [];

	/**
	 * Email_Generators_Abstract constructor.
	 *
	 * @param Email_Repository $repository Email_Repository instance.
	 *
	 * @since 4.12.0
	 *
	 * @internal
	 */
	public function __construct( $repository ) {
		$this->repository = $repository;
	}

	/**
	 * Initialize the email hooks.
	 *
	 * @access public
	 * @since 4.12.0
	 *
	 * @return void
	 */
	abstract public function init();

	/**
	 * Check if email exists and is published.
	 *
	 * @since 4.12.0
	 *
	 * @internal
	 *
	 * @return boolean Indicates if the email is published or not
	 */
	public function is_email_active() {
		$email = $this->repository->get( $this->get_identifier() );
		return $email && 'publish' === $email->post_status;
	}

	/**
	 * Add action if email is active.
	 *
	 * @since 4.18.0
	 *
	 * @internal
	 *
	 * @param string   $action        Action name.
	 * @param callable $callback      Callback.
	 * @param int      $priority      Priority.
	 * @param int      $accepted_args Accepted arguments.
	 */
	protected function maybe_add_action( $action, $callback, $priority = 10, $accepted_args = 1 ) {
		$this->actions[ $action ] = [
			'callback'      => $callback,
			'priority'      => $priority,
			'accepted_args' => $accepted_args,
		];

		add_action( $action, [ $this, 'add_action_if_email_active' ], 1 );
	}

	/**
	 * Add action if email is active.
	 *
	 * @since 4.18.0
	 *
	 * @internal
	 */
	public function add_action_if_email_active() {
		$current_action_name = current_filter();

		if ( $this->is_email_active() && array_key_exists( $current_action_name, $this->actions ) ) {
			$action = $this->actions[ $current_action_name ];
			add_action( $current_action_name, $action['callback'], $action['priority'], $action['accepted_args'] );
		}
	}

	/**
	 * Get name of the identifier of the Email.
	 *
	 * @since 4.12.0
	 *
	 * @internal
	 *
	 * @return string Identifier name.
	 */
	public function get_identifier() {
		return static::IDENTIFIER_NAME;
	}

	/**
	 * Invokes the sensei_send_html_email action.
	 *
	 * @param array $replacements The replacements.
	 *
	 * @access protected
	 *
	 * @internal
	 *
	 * @since 4.12.0
	 */
	protected function send_email_action( $replacements ) {
		/**
		 * Send HTML email.
		 *
		 * @since 4.12.0
		 *
		 * @hook sensei_email_send
		 *
		 * @param {string} $email_name          The email name.
		 * @param {Array}  $replacements        The replacements.
		 * @param {string} $usage_tracking_type Usage tracking type.
		 */
		do_action( 'sensei_email_send', $this->get_identifier(), $replacements, static::USAGE_TRACKING_TYPE );
	}

	/**
	 * Return recipients' email addresses based on given user IDs.
	 *
	 * @param array $user_ids User IDs.
	 * @return array Array of email addresses.
	 */
	protected function get_recipients( $user_ids ): array {
		$recipients = array();
		foreach ( $user_ids as $user_id ) {
			$user         = new \WP_User( $user_id );
			$recipients[] = stripslashes( $user->user_email );
		}
		return $recipients;
	}
}