<?php /** * AuthorizeIPN controller class. * * Replacement for CiviCRM's 'extern/authorizeIPN.php'. * * @see https://docs.civicrm.org/sysadmin/en/latest/setup/payment-processors/authorize-net/#shell-script-testing-method * * @since 0.1 */ namespace CiviCRM_WP_REST\Controller; class AuthorizeIPN extends Base { /** * The base route. * * @since 0.1 * @var string */ protected $rest_base = 'authorizeIPN'; /** * Registers routes. * * @since 0.1 */ public function register_routes() { register_rest_route( $this->get_namespace(), $this->get_rest_base(), [ [ 'methods' => \WP_REST_Server::ALLMETHODS, 'callback' => [ $this, 'get_item' ] ] ] ); } /** * Get items. * * @since 0.1 * @param WP_REST_Request $request */ public function get_item( $request ) { /** * Filter request params. * * @since 0.1 * @param array $params * @param WP_REST_Request $request */ $params = apply_filters( 'civi_wp_rest/controller/authorizeIPN/params', $request->get_params(), $request ); $authorize_IPN = new \CRM_Core_Payment_AuthorizeNetIPN( $params ); // log notification \Civi::log()->alert( 'payment_notification processor_name=AuthNet', $params ); /** * Filter AuthorizeIPN object. * * @param CRM_Core_Payment_AuthorizeNetIPN $authorize_IPN * @param array $params * @param WP_REST_Request $request */ $authorize_IPN = apply_filters( 'civi_wp_rest/controller/authorizeIPN/instance', $authorize_IPN, $params, $request ); try { if ( ! method_exists( $authorize_IPN, 'main' ) || ! $this->instance_of_crm_base_ipn( $authorize_IPN ) ) return $this->civi_rest_error( get_class( $authorize_IPN ) . ' must implement a "main" method.' ); $result = $authorize_IPN->main(); } catch ( \CRM_Core_Exception $e ) { \Civi::log()->error( $e->getMessage() ); \Civi::log()->error( 'error data ', [ 'data' => $e->getErrorData() ] ); \Civi::log()->error( 'REQUEST ', [ 'params' => $params ] ); return $this->civi_rest_error( $e->getMessage() ); } return rest_ensure_response( $result ); } /** * Checks whether object is an instance of CRM_Core_Payment_AuthorizeNetIPN or CRM_Core_Payment_BaseIPN. * * Needed because the instance is being filtered through 'civi_wp_rest/controller/authorizeIPN/instance'. * * @since 0.1 * @param CRM_Core_Payment_AuthorizeNetIPN|CRM_Core_Payment_BaseIPN $object * @return bool */ public function instance_of_crm_base_ipn( $object ) { return $object instanceof \CRM_Core_Payment_BaseIPN || $object instanceof \CRM_Core_Payment_AuthorizeNetIPN; } /** * Item schema. * * @since 0.1 * @return array $schema */ public function get_item_schema() {} /** * Item arguments. * * @since 0.1 * @return array $arguments */ public function get_item_args() {} }