Descrizione

Il wpforms_authorize_net_process_transaction è usato per impostare gli argomenti del pagamento Authorize.net inviati da WPForms durante l'elaborazione del modulo di pagamento.

Parametri

$transazione
(oggetto) Oggetto del processo WPForms Authorize.Net.
$args
(array) Argomenti di una singola transazione.

Fonte

wpforms-authorize-net/src/Api/Api.php

Ulteriori informazioni

Il wpforms_authorize_net_process_transaction è utilizzato per impostare argomenti specifici sulle transazioni di pagamento Authorize.net.

Utilizzando il wpforms_authorize_net_process_payment_single_args è possibile estrarre queste informazioni da WPForms e utilizzare il filtro wpforms_authorize_net_process_transaction per impostare tali campi sul pagamento. I campi dell'indirizzo, i numeri di fattura, ecc. sono solo alcuni degli esempi.

Esempi

/**
 * Filter used to get the address field information.
 *
 * @link  https://wpforms.com/developers/wpforms_authorize_net_process_payment_single_args/
 *
 * @param array   $args    Single payment arguments.
 * @param object  $process WPForms Authorize.Net Process object.
 *
 * @return array
 */

function wpf_dev_authorize_net_process_payment_single_add_fields_to_args( $args, $process ) {

   // Replace 3 in $process->fields[3] to the form id of your address field.
   $args[ 'address' ] = $process->fields[3];

   return $args;
}

add_filter( 'wpforms_authorize_net_process_payment_single_args', 'wpf_dev_authorize_net_process_payment_single_add_fields_to_args', 10, 2 );



/**
 * Set the customer's Bill To address.
 * 
 * @link  https://wpforms.com/developers/wpforms_authorize_net_process_transaction/
 *
 * @param netauthorizeapicontractv1TransactionRequestType $transaction Single transaction object.
 * @param array                                                 $args        Single transaction arguments.
 *
 * @return netauthorizeapicontractv1TransactionRequestType
 */

function wpf_dev_authorize_net_process_transaction_add_address_to_transaction( $transaction, $args ) {

   $bill_to = $transaction->getBillTo();

   if ( is_null( $bill_to ) ) {
      $bill_to = new netauthorizeapicontractv1CustomerAddressType();
   }

   $address = $args[ 'address' ][ 'address1' ];

   if ( ! empty( $args[ 'address' ][ 'address2' ] ) ) {

      $address .= ' ' . $args[ 'address' ][ 'address2' ];

   }

   $bill_to->setAddress( $address );

   $bill_to->setCity( $args[ 'address' ][ 'city' ] );

   $bill_to->setState( $args[ 'address' ][ 'state' ] );

   $bill_to->setZip( $args[ 'address' ][ 'postal' ] );

   $bill_to->setCountry( $args[ 'address' ][ 'country' ] );

   $transaction->setBillTo( $bill_to );

   return $transaction;
}

add_filter( 'wpforms_authorize_net_process_transaction', 'wpf_dev_authorize_net_process_transaction_add_address_to_transaction', 10, 2 );

Per assistenza nell'individuazione dell'ID del campo specifico, consultare questa esercitazione.

Riferimento filtro: wpforms_authorize_net_process_payment_single_args

Riferimento al tutorial: