????JFIF??x?x????'
| Server IP : 172.67.174.47  /  Your IP : 216.73.216.145 Web Server : LiteSpeed System : Linux premium151.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 User : tempvsty ( 647) PHP Version : 8.0.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /proc/thread-self/./cwd/wp-content/plugins/optinmonster/OMAPI/ | 
| Upload File : | 
<?php
/**
 * Easy Digital Downloads class.
 *
 * @since 2.6.13
 *
 * @package OMAPI
 * @author  Thomas Griffin
 */
// Exit if accessed directly.
if ( ! defined( 'ABSPATH' ) ) {
	exit;
}
/**
 * The Easy Digital Downloads class.
 *
 * @since 2.6.13
 */
class OMAPI_EasyDigitalDownloads extends OMAPI_Integrations_Base {
	/**
	 * The minimum EDD version required.
	 *
	 * @since 2.8.0
	 *
	 * @var string
	 */
	const MINIMUM_VERSION = '2.1.0';
	/**
	 * OMAPI_EasyDigitalDownloads_Save object
	 *
	 * @since 2.8.0
	 *
	 * @var OMAPI_EasyDigitalDownloads_Save
	 */
	public $save;
	/**
	 * The OMAPI_EasyDigitalDownloads_RestApi instance.
	 *
	 * @since 2.13.0
	 *
	 * @var null|OMAPI_EasyDigitalDownloads_RestApi
	 */
	public $rest = null;
	/**
	 * Primary class constructor.
	 *
	 * @since 2.6.13
	 */
	public function __construct() {
		parent::__construct();
		// Set our object.
		$this->save = new OMAPI_EasyDigitalDownloads_Save( $this );
		add_action( 'optin_monster_api_rest_register_routes', array( $this, 'maybe_init_rest_routes' ) );
		add_filter( 'optin_monster_display_rules_data_output', array( $this, 'maybe_add_edd_data' ) );
		// Revenue attribution support. We load on shutdown because we need access
		// to the $_COOKIE data, which will not be available for any action triggered
		// by cron. This attempts at the last possible moment to avoid interfering
		// with anything else happening with the payment.
		add_action( 'shutdown', array( $this, 'maybe_store_revenue_attribution' ) );
		add_action( 'edd_update_payment_status', array( $this, 'maybe_store_revenue_attribution_on_payment_status_update' ), 10, 2 );
	}
	/**
	 * Maybe stores revenue attribution data when a purchase is successful.
	 *
	 * @since 2.6.13
	 *
	 * @param int  $payment_id The EDD payment ID.
	 * @param bool $force      Flag to force sending the revenue attribution data.
	 *
	 * @return void
	 */
	public function maybe_store_revenue_attribution( $payment_id = 0, $force = false ) {
		if ( ! class_exists( 'EDD_Payment' ) ) {
			return;
		}
		// If we don't have a payment ID passed, try to grab one.
		if ( ! $payment_id ) {
			// If we don't have the right EDD function to grab session data, return early.
			if ( ! function_exists( 'edd_get_purchase_session' ) ) {
				return;
			}
			// If we are not on the success page, return early.
			if ( function_exists( 'edd_is_success_page' ) && ! edd_is_success_page() ) {
				return;
			}
			// Grab the purchase session. If we can't find it, return early.
			$session = edd_get_purchase_session();
			if ( empty( $session['purchase_key'] ) ) {
				return;
			}
			// Grab the payment ID from the purchase session. If we can't find
			// it, return early.
			$payment_id = edd_get_purchase_id_by_key( $session['purchase_key'] );
			if ( ! $payment_id ) {
				return;
			}
		}
		// If we have already stored revenue attribution data before, return early.
		$stored = get_post_meta( $payment_id, '_om_revenue_attribution_complete', true );
		if ( $stored ) {
			return;
		}
		// Grab the payment. If we can't, return early.
		$payment = new EDD_Payment( $payment_id );
		if ( ! $payment ) {
			return;
		}
		// Grab some necessary data to send.
		$data_on_payment = get_post_meta( $payment_id, '_om_revenue_attribution_data', true );
		$data            = wp_parse_args(
			array(
				'transaction_id' => absint( $payment_id ),
				'value'          => esc_html( $payment->total ),
				'test'           => 'live' !== $payment->mode,
			),
			! empty( $data_on_payment ) ? $data_on_payment : $this->base->revenue->get_revenue_data()
		);
		// If the status is not complete, return early.
		// This will happen for payments where further
		// work is required (such as checks, etc.). In those
		// instances, we need to store the data to be processed
		// at a later time.
		if (
			! in_array( $payment->status, array( 'complete', 'completed', 'publish' ), true )
			&& ! $force
		) {
			update_post_meta( $payment_id, '_om_revenue_attribution_data', $data );
			return;
		}
		// Attempt to make the revenue attribution request.
		// It checks to determine if campaigns are set, etc.
		$ret = $this->base->revenue->store( $data );
		if ( ! $ret || is_wp_error( $ret ) ) {
			return;
		}
		// Update the payment meta for storing revenue attribution data.
		update_post_meta( $payment_id, '_om_revenue_attribution_complete', time() );
	}
	/**
	 * Maybe stores revenue attribution data when a purchase is successful.
	 *
	 * @since 2.6.13
	 *
	 * @param int    $payment_id The EDD payment ID.
	 * @param string $new_status The new payment status.
	 *
	 * @return void
	 */
	public function maybe_store_revenue_attribution_on_payment_status_update( $payment_id, $new_status ) {
		// If we don't have the proper new status, return early.
		if ( 'publish' !== $new_status && 'complete' !== $new_status && 'completed' !== $new_status ) {
			return;
		}
		// Maybe store the revenue attribution data.
		return $this->maybe_store_revenue_attribution( $payment_id, true );
	}
	/**
	 * Connects EDD to OptinMonster.
	 *
	 * @param array $data The array of key / token.
	 *
	 * @since 2.8.0
	 *
	 * @return WP_Error|bool True if success, or WP_Error if any error was encountered.
	 */
	public function connect( $data ) {
		if ( empty( $data['public_key'] ) || empty( $data['token'] ) ) {
			return new WP_Error(
				'omapi-invalid-edd-keys',
				esc_html__( 'The EDD key or token appears to be invalid. Try again.', 'optin-monster-api' )
			);
		}
		// Setup the request payload.
		$payload = array_merge(
			array(
				'key'   => $data['public_key'],
				'token' => $data['token'],
				'shop'  => $data['url'],
				'name'  => esc_html( get_bloginfo( 'name' ) ),
			),
			OMAPI_Api::get_url_args()
		);
		// Get the OptinMonster API credentials.
		$creds = $this->base->get_api_credentials();
		// Initialize the API class.
		$api = new OMAPI_Api( 'edd/shop', $creds, 'POST', 'v2' );
		$body = $api->request( $payload );
		if ( is_wp_error( $body ) ) {
			$message = isset( $body->message )
				? $body->message
				: esc_html__( 'EDD could not be connected to OptinMonster. The OptinMonster API returned with the following response: ', 'optin-monster-api' ) . $body->get_error_message();
			return new WP_Error( 'omapi-error-edd-api-connect', $message );
		}
		return $body;
	}
	/**
	 * Disconnects EDD from OptinMonster.
	 *
	 * @since 2.8.0
	 *
	 * @return WP_Error|string Empty string if success, or WP_Error if any error was encountered.
	 */
	public function disconnect() {
		// Get the OptinMonster API credentials.
		$creds = $this->base->get_api_credentials();
		// Get the shop.
		$shop = esc_attr( $this->base->get_option( 'edd', 'shop' ) );
		if ( empty( $shop ) ) {
			return true;
		}
		// Initialize the API class.
		$api = new OMAPI_Api( 'edd/shop/' . rawurlencode( $shop ), $creds, 'DELETE', 'v2' );
		$body = $api->request();
		if ( is_wp_error( $body ) ) {
			$message = isset( $body->message )
				? $body->message
				: esc_html__( 'EDD could not be disconnected to OptinMonster. The OptinMonster API returned with the following response: ', 'optin-monster-api' ) . $body->get_error_message();
			return new WP_Error( 'omapi-error-api-disconnect', $message );
		}
		return empty( $body ) ? true : $body;
	}
	/**
	 * Checks if current user can manage the shop
	 *
	 * @since 2.8.0
	 *
	 * @return bool True if it can, false if not.
	 */
	public static function can_manage_shop() {
		return current_user_can( 'manage_shop_settings' );
	}
	/**
	 * Return the EDD Plugin version string.
	 *
	 * @since 2.8.0
	 *
	 * @return string
	 */
	public static function version() {
		return defined( 'EDD_VERSION' ) ? EDD_VERSION : '0.0.0';
	}
	/**
	 * Check if the EDD plugin is active.
	 *
	 * @since 2.8.0
	 *
	 * @return bool
	 */
	public static function is_active() {
		return class_exists( 'Easy_Digital_Downloads', true ) && function_exists( 'EDD' );
	}
	/**
	 * Check if the EDD plugin is connected.
	 *
	 * @since 2.8.0
	 *
	 * @return bool If it is currently connected.
	 */
	public static function is_connected() {
		// If not active, then it is not connected as well.
		if ( ! self::is_active() ) {
			return false;
		}
		// Get any options we have stored.
		$option = OMAPI::get_instance()->get_option( 'edd' );
		// If the option is empty, then it was never connected or it was disconnected.
		if ( empty( $option ) ) {
			return false;
		}
		$shop = isset( $option['shop'] ) ? $option['shop'] : '';
		if ( empty( $shop ) ) {
			return false;
		}
		// Check if the saved key and token are not empty.
		$key = isset( $option['key'] ) ? $option['key'] : '';
		if ( empty( $key ) ) {
			return false;
		}
		// Finally, check if the public_key is still active in user.
		$user_id = EDD()->api->get_user( $key );
		return ! empty( $user_id );
	}
	/**
	 * Initiate our REST routes for EDD if EDD active.
	 *
	 * @since 2.13.0
	 *
	 * @return void
	 */
	public function maybe_init_rest_routes() {
		if ( self::is_active() ) {
			$this->rest = new OMAPI_EasyDigitalDownloads_RestApi( $this );
		}
	}
	/**
	 * If EDD active, add our EDD cart data for use in Display Rules.
	 *
	 * @since 2.13.0
	 *
	 * @param  array $output Array of data for use in Display Rules.
	 *
	 * @return array Array of data for use in Display Rules.
	 */
	public function maybe_add_edd_data( $output = array() ) {
		if ( self::is_active() ) {
			$edd           = new OMAPI_EasyDigitalDownloads_Output( $this );
			$output['edd'] = $edd->display_rules_data();
		}
		return $output;
	}
}