HEX
Server: Apache
System: Linux ecngx285.inmotionhosting.com 4.18.0-553.79.1.lve.el8.x86_64 #1 SMP Wed Oct 15 17:59:35 UTC 2025 x86_64
User: zeusxp5 (3862)
PHP: 8.3.30
Disabled: NONE
Upload Files
File: /home/zeusxp5/tour.kamille.us/wp-content/plugins/surecart/app/src/Models/Charge.php
<?php

namespace SureCart\Models;

use SureCart\Models\Traits\HasCustomer;
use SureCart\Models\Traits\HasDates;
use SureCart\Models\Traits\HasDisputes;
use SureCart\Models\Traits\HasOrder;
use SureCart\Models\Traits\HasPaymentMethod;
use SureCart\Models\Traits\HasSubscription;
use SureCart\Models\Traits\HasPaymentIntent;
use SureCart\Support\Currency;

/**
 * Subscription model
 */
class Charge extends Model {
	use HasCustomer;
	use HasOrder;
	use HasSubscription;
	use HasDates;
	use HasPaymentMethod;
	use HasPaymentIntent;
	use HasDisputes;

	/**
	 * Rest API endpoint
	 *
	 * @var string
	 */
	protected $endpoint = 'charges';

	/**
	 * Object name
	 *
	 * @var string
	 */
	protected $object_name = 'charge';

	/**
	 * Refund this specific charge
	 *
	 * @return \SureCart\Models\Refund
	 */
	protected function refund() {
		return new Refund( [ 'charge' => $this->id ] );
	}

	/**
	 * Get the display amount attribute.
	 *
	 * @return string
	 */
	protected function getDisplayAmountAttribute() {
		return Currency::format( $this->amount, $this->currency );
	}

	/**
	 * Get the human discount attribute.
	 *
	 * @return string|null
	 */
	public function getExternalChargeLinkAttribute() {
		if ( ! $this->payment_method || ! $this->payment_method->processor_type ) {
			return null;
		}

		$payment_type = $this->payment_method->processor_type;

		if ( ! in_array( $payment_type, [ 'stripe', 'paypal' ], true ) ) {
			return null;
		}

		if ( ! $this->external_charge_id ) {
			return null;
		}

		$external_charge_id = $this->external_charge_id;
		$is_live_mode       = $this->live_mode;

		if ( 'stripe' === $payment_type ) {
			return 'https://dashboard.stripe.com/' . ( ! $is_live_mode ? 'test/' : '' ) . 'charges/' . $external_charge_id;
		}
		if ( 'paypal' === $payment_type ) {
			return 'https://www.' . ( ! $is_live_mode ? 'sandbox.' : '' ) . 'paypal.com/activity/payment/' . $external_charge_id;
		}
	}

	/**
	 * Get the display amount attribute.
	 *
	 * @return string
	 */
	public function getAmountDisplayAmountAttribute() {
		return Currency::format( $this->amount, $this->currency );
	}

	/**
	 * Get the refunded display amount attribute.
	 *
	 * @return string
	 */
	public function getRefundedDisplayAmountAttribute() {
		return Currency::format( $this->refunded_amount, $this->currency );
	}

	/**
	 * Get the dispute status attribute.
	 *
	 * @return string
	 */
	public function getDisputeStatusAttribute(): string {
		if ( ! $this->disputed_amount ) {
			return '';
		}

		if ( ! empty( $this->disputes->data ) && count( $this->disputes->data ) > 1 ) {
			return __( 'Multiple Disputes', 'surecart' );
		}

		return $this->disputes->data[0]->status_display ?? '';
	}

	/**
	 * Get the dispute status type attribute.
	 *
	 * @return string
	 */
	public function getDisputeStatusTypeAttribute(): string {
		if ( ! $this->disputed_amount ) {
			return '';
		}

		if ( ! empty( $this->disputes->data ) && count( $this->disputes->data ) > 1 ) {
			return 'warning';
		}

		return $this->disputes->data[0]->status_type ?? '';
	}

	/**
	 * Get the disputed amount attribute.
	 *
	 * @return string
	 */
	public function getDisputedDisplayAmountAttribute(): string {
		return ! empty( $this->disputed_amount ) ? Currency::format( $this->disputed_amount, $this->currency ) : '';
	}

	/**
	 * Get the fully disputed attribute.
	 *
	 * @return bool
	 */
	public function getFullyDisputedAttribute(): bool {
		return $this->disputed_amount && ( $this->disputed_amount >= $this->amount );
	}
}