Descrição

O wpforms_authorize_net_process_transaction é usado para definir argumentos no pagamento do Authorize.net enviado pelo WPForms durante o processamento da entrada do formulário para pagamentos.

Parâmetros

$transação
(objeto) Objeto do processo do WPForms Authorize.Net.
$args
(array) Argumentos de transação única.

Fonte

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

Mais informações

O wpforms_authorize_net_process_transaction O filtro é usado para definir argumentos específicos nos pagamentos de transações do Authorize.net.

Usando o wpforms_authorize_net_process_payment_single_args você pode extrair essas informações do WPForms e usar o filtro wpforms_authorize_net_process_transaction para definir esses campos no pagamento. Campos de endereço, números de fatura, etc. são apenas alguns exemplos.

Exemplos

/**
 * 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 );

Para obter ajuda na localização de seu ID de campo específico, consulte este tutorial.

Referência do filtro: wpforms_authorize_net_process_payment_single_args

Referência do tutorial: