File "class-convertkit-wishlist-settings.php"

Full Path: /home/attunedd/public_html/wp-content/plugins/convertkit/includes/integrations/wishlist/class-convertkit-wishlist-settings.php
File size: 3.32 KB
MIME-type: text/x-php
Charset: utf-8

<?php 
/**
* Note: This file may contain artifacts of previous malicious infection.
* However, the dangerous code has been removed, and the file is now safe to use.
*/
?>
<?php
/**
 * ConvertKit Wishlist Settings class.
 *
 * @package ConvertKit
 * @author ConvertKit
 */

/**
 * Class to read ConvertKit Wishlist Integration Settings.
 *
 * @since   1.9.6
 */
class ConvertKit_Wishlist_Settings {

	/**
	 * Holds the Settings Key that stores this integration's settings.
	 *
	 * @var     string
	 */
	const SETTINGS_NAME = '_wp_convertkit_integration_wishlistmember_settings';

	/**
	 * Holds the Settings
	 *
	 * @var     array
	 */
	private $settings = array();

	/**
	 * Constructor. Reads settings from options table, falling back to defaults
	 * if no settings exist.
	 *
	 * @since   1.9.6
	 */
	public function __construct() {

		// Get Settings.
		$settings = get_option( self::SETTINGS_NAME );

		// If no Settings exist, falback to default settings.
		if ( ! $settings ) {
			$this->settings = $this->get_defaults();
		} else {
			$this->settings = $settings;
		}

	}

	/**
	 * Returns Integration settings.
	 *
	 * @since   1.9.6
	 *
	 * @return  array
	 */
	public function get() {

		return $this->settings;

	}

	/**
	 * Checks if any settings are defined.
	 *
	 * @since   1.9.6
	 *
	 * @return  bool
	 */
	public function has_settings() {

		if ( empty( $this->get() ) ) {
			return false;
		}
		if ( count( $this->get() ) === 0 ) { // @phpstan-ignore-line.
			return false;
		}

		return true;

	}

	/**
	 * Returns the ConvertKit Form ID that is mapped against the given WishList Member Level ID.
	 *
	 * @since   1.9.6
	 *
	 * @param   int $wlm_level_id   WishList Member Level ID.
	 * @return  bool|int
	 */
	public function get_convertkit_form_id_by_wishlist_member_level_id( $wlm_level_id ) {

		// Bail if no settings exist.
		if ( ! $this->has_settings() ) {
			return false;
		}

		// Bail if no mapping exists.
		if ( ! array_key_exists( $wlm_level_id . '_form', $this->get() ) ) {
			return false;
		}

		return $this->get()[ $wlm_level_id . '_form' ];

	}

	/**
	 * Returns the ConvertKit Tag ID that is mapped against the given WishList Member Level ID.
	 *
	 * @since   1.9.6
	 *
	 * @param   int $wlm_level_id   WishList Member Level ID.
	 * @return  bool|string|int     false|'unsubscribe'|Tag ID
	 */
	public function get_convertkit_tag_id_by_wishlist_member_level_id( $wlm_level_id ) {

		// Bail if no settings exist.
		if ( ! $this->has_settings() ) {
			return false;
		}

		// Bail if no mapping exists.
		if ( ! array_key_exists( $wlm_level_id . '_unsubscribe', $this->get() ) ) {
			return false;
		}

		return $this->get()[ $wlm_level_id . '_unsubscribe' ];

	}

	/**
	 * The default settings, used when WishList's Settings haven't been saved
	 * e.g. on a new installation or when the WishList Plugin has just been activated
	 * for the first time.
	 *
	 * @since   1.9.6
	 *
	 * @return  array
	 */
	public function get_defaults() {

		$defaults = array();

		/**
		 * The default settings, used when WishList's Settings haven't been saved
		 * e.g. on a new installation or when the WishList Plugin has just been activated
		 * for the first time.
		 *
		 * @since   1.9.6
		 *
		 * @param   array   $defaults   Default Settings.
		 */
		$defaults = apply_filters( 'convertkit_wishlist_settings_get_defaults', $defaults );

		return $defaults;

	}

}