You are here

class MolliePaymentMethodController in Mollie Payment 7

Same name and namespace in other branches
  1. 7.2 includes/mollie_payment.class.inc \MolliePaymentMethodController

Mollie payment method controller.

Hierarchy

Expanded class hierarchy of MolliePaymentMethodController

5 string references to 'MolliePaymentMethodController'
mollie_payment_entity_load in ./mollie_payment.module
Implements hook_entity_load().
mollie_payment_payment_method_controller_info in ./mollie_payment.module
Implements hook_payment_method_controller_info().
mollie_payment_payment_method_delete in ./mollie_payment.module
Implements hook_ENTITY_TYPE_ACTION().
mollie_payment_payment_method_insert in ./mollie_payment.module
Implements hook_ENTITY_TYPE_ACTION().
mollie_payment_payment_method_update in ./mollie_payment.module
Implements hook_ENTITY_TYPE_ACTION().

File

includes/mollie_payment.class.inc, line 10

View source
class MolliePaymentMethodController extends PaymentMethodController {
  public $payment_method_configuration_form_elements_callback = 'mollie_payment_method_configuration';
  public $payment_configuration_form_elements_callback = 'mollie_payment_configuration';

  /**
   * Class constructor.
   */
  public function __construct() {
    $this->title = t('Mollie');
  }

  /**
   * Implements PaymentMethodController::execute().
   */
  public function execute(Payment $payment) {
    $method_data = $payment->method_data;
    $controller_data = $payment->method->controller_data;
    $client = mollie_payment_get_client($payment);
    if ($client) {
      $return_path = MOLLIE_PAYMENT_RETURN_PATH;
      $listener_path = MOLLIE_PAYMENT_LISTENER_PATH;
      $recurring_listener_path = MOLLIE_PAYMENT_RECURRING_LISTENER_PATH;
      if (!empty($controller_data['webhook_base_url'])) {
        $return_path = $controller_data['webhook_base_url'] . '/' . $return_path;
        $listener_path = $controller_data['webhook_base_url'] . '/' . $listener_path;
        $recurring_listener_path = $controller_data['webhook_base_url'] . '/' . $recurring_listener_path;
      }
      $payment_data = array(
        'amount' => $payment
          ->totalAmount(TRUE),
        'description' => $payment->description,
        'redirectUrl' => url($return_path . '/' . $payment->pid, array(
          'absolute' => TRUE,
        )),
        'webhookUrl' => url($listener_path . '/' . $payment->pid, array(
          'absolute' => TRUE,
        )),
      );
      if (isset($method_data['mollie_payment_method'])) {
        $payment_data['method'] = $method_data['mollie_payment_method'];
      }
      if (isset($method_data['mollie_payment_issuer'])) {
        $payment_data['issuer'] = $method_data['mollie_payment_issuer'];
      }
      if (module_exists('payment_recurring')) {
        $recurring_info = payment_recurring_recurring_payment_info($payment);
        if (!empty($recurring_info)) {

          // This is a recurring payment.
          $payment_data['recurringType'] = 'first';

          // We need to created a customer first.
          $customer = $client->customers
            ->create(array(
            'name' => $recurring_info['name'],
            'email' => $recurring_info['email'],
          ));
          $payment_data['customerId'] = $customer->id;
        }
      }

      // Create the payment in the Mollie system.
      $mollie_payment = $client->payments
        ->create($payment_data);

      // Context data might not be the best location to store this information
      // because in fact it is not related to the context. We might consider
      // storing it in a separate database table just like the controller data
      // of the payment method. (The method_data in the payment object is
      // currently not stored.)
      $payment->context_data['payment'] = array(
        'id' => $mollie_payment->id,
      );
      entity_save('payment', $payment);
      $redirect_url = $mollie_payment
        ->getPaymentUrl();
      drupal_goto($redirect_url);
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
MolliePaymentMethodController::$payment_configuration_form_elements_callback public property The function name of the payment configuration form elements. Overrides PaymentMethodController::$payment_configuration_form_elements_callback
MolliePaymentMethodController::$payment_method_configuration_form_elements_callback public property The function name of the payment method configuration form elements. Overrides PaymentMethodController::$payment_method_configuration_form_elements_callback
MolliePaymentMethodController::execute public function Implements PaymentMethodController::execute(). Overrides PaymentMethodController::execute
MolliePaymentMethodController::__construct public function Class constructor.
PaymentMethodController::$controller_data_defaults public property Default values for the controller_data property of a PaymentMethod that uses this controller. 1
PaymentMethodController::$currencies public property An array with ISO 4217 currency codes that this controller supports.
PaymentMethodController::$description public property A human-readable plain text description of this payment method controller.
PaymentMethodController::$name public property The machine name.
PaymentMethodController::$title public property The human-readable plain text title.
PaymentMethodController::descendants static function Returns an array with the names of all available payment method controllers that inherit of this one.
PaymentMethodController::validate function Validate a payment against a payment method and this controller. Don't call directly. Use PaymentMethod::validate() instead. 2