GC_HTTP_Requests_Hooks

最后更新于:2021-12-01 10:03:15

GC_

Bridge to connect Requests internal hooks to GeChiUI actions.

源文件

文件: gc-includes/class-gc-http-requests-hooks.php

class GC_HTTP_Requests_Hooks extends Requests_Hooks {
	/**
	 * Requested URL.
	 *
	 * @var string Requested URL.
	 */
	protected $url;

	/**
	 * GeChiUI GC_HTTP request data.
	 *
	 * @var array Request data in GC_Http format.
	 */
	protected $request = array();

	/**
	 * Constructor.
	 *
	 * @param string $url     URL to request.
	 * @param array  $request Request data in GC_Http format.
	 */
	public function __construct( $url, $request ) {
		$this->url     = $url;
		$this->request = $request;
	}

	/**
	 * Dispatch a Requests hook to a native GeChiUI action.
	 *
	 * @param string $hook       Hook name.
	 * @param array  $parameters 参数 to pass to callbacks.
	 * @return bool True if hooks were run, false if nothing was hooked.
	 */
	public function dispatch( $hook, $parameters = array() ) {
		$result = parent::dispatch( $hook, $parameters );

		// Handle back-compat actions.
		switch ( $hook ) {
			case 'curl.before_send':
				/** This action is documented in gc-includes/class-gc-http-curl.php */
				do_action_ref_array( 'http_api_curl', array( &$parameters[0], $this->request, $this->url ) );
				break;
		}

		/**
		 * Transforms a native Request hook to a GeChiUI action.
		 *
		 * This action maps Requests internal hook to a native GeChiUI action.
		 *
		 * @see https://github.com/rmccue/Requests/blob/master/docs/hooks.md
		 *
		 * @since 4.7.0
		 *
		 * @param array $parameters 参数 from Requests internal hook.
		 * @param array $request Request data in GC_Http format.
		 * @param string $url URL to request.
		 */
		do_action_ref_array( "requests-{$hook}", $parameters, $this->request, $this->url ); // phpcs:ignore GeChiUI.NamingConventions.ValidHookName.UseUnderscores

		return $result;
	}
}