147 lines
3.3 KiB
PHP
147 lines
3.3 KiB
PHP
<?php
|
|
/**
|
|
* @package Freemius
|
|
* @copyright Copyright (c) 2015, Freemius, Inc.
|
|
* @license https://www.gnu.org/licenses/gpl-3.0.html GNU General Public License Version 3
|
|
* @since 1.0.9
|
|
*/
|
|
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
exit;
|
|
}
|
|
|
|
class FS_Subscription extends FS_Entity {
|
|
|
|
#region Properties
|
|
|
|
/**
|
|
* @var number
|
|
*/
|
|
public $user_id;
|
|
/**
|
|
* @var number
|
|
*/
|
|
public $install_id;
|
|
/**
|
|
* @var number
|
|
*/
|
|
public $plan_id;
|
|
/**
|
|
* @var number
|
|
*/
|
|
public $license_id;
|
|
/**
|
|
* @var float
|
|
*/
|
|
public $total_gross;
|
|
/**
|
|
* @var float
|
|
*/
|
|
public $amount_per_cycle;
|
|
/**
|
|
* @var int # of months
|
|
*/
|
|
public $billing_cycle;
|
|
/**
|
|
* @var float
|
|
*/
|
|
public $outstanding_balance;
|
|
/**
|
|
* @var int
|
|
*/
|
|
public $failed_payments;
|
|
/**
|
|
* @var string
|
|
*/
|
|
public $gateway;
|
|
/**
|
|
* @var string
|
|
*/
|
|
public $external_id;
|
|
/**
|
|
* @var string|null
|
|
*/
|
|
public $trial_ends;
|
|
/**
|
|
* @var string|null Datetime of the next payment, or null if cancelled.
|
|
*/
|
|
public $next_payment;
|
|
/**
|
|
* @since 2.3.1
|
|
*
|
|
* @var string|null Datetime of the cancellation.
|
|
*/
|
|
public $canceled_at;
|
|
/**
|
|
* @var string|null
|
|
*/
|
|
public $vat_id;
|
|
/**
|
|
* @var string Two characters country code
|
|
*/
|
|
public $country_code;
|
|
|
|
#endregion Properties
|
|
|
|
/**
|
|
* @param object|bool $subscription
|
|
*/
|
|
function __construct( $subscription = false ) {
|
|
parent::__construct( $subscription );
|
|
}
|
|
|
|
static function get_type() {
|
|
return 'subscription';
|
|
}
|
|
|
|
/**
|
|
* Check if subscription is active.
|
|
*
|
|
* @author Vova Feldman (@svovaf)
|
|
* @since 1.0.9
|
|
*
|
|
* @return bool
|
|
*/
|
|
function is_active() {
|
|
if ( $this->is_canceled() ) {
|
|
return false;
|
|
}
|
|
|
|
return (
|
|
! empty( $this->next_payment ) &&
|
|
strtotime( $this->next_payment ) > WP_FS__SCRIPT_START_TIME
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @author Vova Feldman (@svovaf)
|
|
* @since 2.3.1
|
|
*
|
|
* @return bool
|
|
*/
|
|
function is_canceled() {
|
|
return ! is_null( $this->canceled_at );
|
|
}
|
|
|
|
/**
|
|
* Subscription considered to be new without any payments
|
|
* if the next payment should be made within less than 24 hours
|
|
* from the subscription creation.
|
|
*
|
|
* @author Vova Feldman (@svovaf)
|
|
* @since 1.0.9
|
|
*
|
|
* @return bool
|
|
*/
|
|
function is_first_payment_pending() {
|
|
return ( WP_FS__TIME_24_HOURS_IN_SEC >= strtotime( $this->next_payment ) - strtotime( $this->created ) );
|
|
}
|
|
|
|
/**
|
|
* @author Vova Feldman (@svovaf)
|
|
* @since 1.1.7
|
|
*/
|
|
function has_trial() {
|
|
return ! is_null( $this->trial_ends );
|
|
}
|
|
} |