| Server IP : 195.134.90.114 / Your IP : 216.73.216.86 Web Server : Apache/2.4.58 System : Linux nepub 6.8.0-88-generic #89-Ubuntu SMP PREEMPT_DYNAMIC Sat Oct 11 01:02:46 UTC 2025 x86_64 User : www-data ( 33) PHP Version : 8.2.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /var/www/html/public_html/lib/pkp/classes/payment/ |
Upload File : |
<?php
/**
* @file classes/payment/PaymentManager.inc.php
*
* Copyright (c) 2014-2021 Simon Fraser University
* Copyright (c) 2000-2021 John Willinsky
* Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
*
* @class PaymentManager
* @ingroup payment
* @see Payment
*
* @brief Provides payment management functions.
*
*/
abstract class PaymentManager {
/** @var Context */
var $_context;
/**
* Constructor
* @param $context Context
*/
function __construct($context) {
$this->_context = $context;
}
/**
* Queue a payment for receipt.
* @param $queuedPayment object
* @param $expiryDate date optional
* @return mixed Queued payment ID for new payment, or false if fails
*/
function queuePayment($queuedPayment, $expiryDate = null) {
if (!$this->isConfigured()) return false;
$queuedPaymentDao = DAORegistry::getDAO('QueuedPaymentDAO'); /* @var $queuedPaymentDao QueuedPaymentDAO */
$queuedPaymentId = $queuedPaymentDao->insertObject($queuedPayment, $expiryDate);
// Perform periodic cleanup
if (time() % 100 == 0) $queuedPaymentDao->deleteExpired();
return $queuedPaymentId;
}
/**
* Abstract method for fetching the payment plugin
* @return object
*/
abstract function getPaymentPlugin();
/**
* Check if there is a payment plugin and if is configured
* @return bool
*/
function isConfigured() {
$paymentPlugin = $this->getPaymentPlugin();
if ($paymentPlugin !== null) return $paymentPlugin->isConfigured($this->_context);
return false;
}
/**
* Get the payment form for the configured payment plugin and specified payment.
* @param $queuedPayment QueuedPayment
* @return Form
*/
function getPaymentForm($queuedPayment) {
$paymentPlugin = $this->getPaymentPlugin();
if ($paymentPlugin !== null && $paymentPlugin->isConfigured($this->_context)) return $paymentPlugin->getPaymentForm($this->_context, $queuedPayment);
return false;
}
/**
* Call the payment plugin's settings display method
* @return boolean
*/
function displayConfigurationForm() {
$paymentPlugin = $this->getPaymentPlugin();
if ($paymentPlugin !== null && $paymentPlugin->isConfigured($this->_context)) return $paymentPlugin->displayConfigurationForm();
return false;
}
/**
* Fetch a queued payment
* @param $queuedPaymentId int
* @return QueuedPayment
*/
function getQueuedPayment($queuedPaymentId) {
$queuedPaymentDao = DAORegistry::getDAO('QueuedPaymentDAO'); /* @var $queuedPaymentDao QueuedPaymentDAO */
$queuedPayment = $queuedPaymentDao->getById($queuedPaymentId);
return $queuedPayment;
}
/**
* Fulfill a queued payment
* @param $request PKPRequest
* @param $queuedPayment QueuedPayment
* @return boolean success/failure
*/
abstract function fulfillQueuedPayment($request, $queuedPayment);
}