plugins_api

函数
plugins_api ( $action, $args = array() )
参数
  • (string) $action API action to perform: 'query_plugins', 'plugin_information', 'hot_tags' or 'hot_categories'.
    Required:
  • (array|object) $args { Optional. Array or object of arguments to serialize for the Plugin Info API. @type string $slug The plugin slug. Default empty. @type int $per_page Number of plugins per page. Default 24. @type int $page Number of current page. Default 1. @type int $number Number of tags or categories to be queried. @type string $search A search term. Default empty. @type string $tag Tag to filter plugins. Default empty. @type string $author Username of an plugin author to filter plugins. Default empty. @type string $user Username to query for their favorites. Default empty. @type string $browse Browse view: 'popular', 'new', 'beta', 'recommended'. @type string $locale Locale to provide context-sensitive results. Default is the value of get_locale(). @type string $installed_plugins Installed plugins to provide context-sensitive results. @type bool $is_ssl Whether links should be returned with https or not. Default false. @type array $fields { Array of fields which should or should not be returned. @type bool $short_description Whether to return the plugin short description. Default true. @type bool $description Whether to return the plugin full description. Default false. @type bool $sections Whether to return the plugin readme sections: description, installation, FAQ, screenshots, other notes, and changelog. Default false. @type bool $tested Whether to return the 'Compatible up to' value. Default true. @type bool $requires Whether to return the required WordPress version. Default true. @type bool $requires_php Whether to return the required PHP version. Default true. @type bool $rating Whether to return the rating in percent and total number of ratings. Default true. @type bool $ratings Whether to return the number of rating for each star (1-5). Default true. @type bool $downloaded Whether to return the download count. Default true. @type bool $downloadlink Whether to return the download link for the package. Default true. @type bool $last_updated Whether to return the date of the last update. Default true. @type bool $added Whether to return the date when the plugin was added to the wordpress.org repository. Default true. @type bool $tags Whether to return the assigned tags. Default true. @type bool $compatibility Whether to return the WordPress compatibility list. Default true. @type bool $homepage Whether to return the plugin homepage link. Default true. @type bool $versions Whether to return the list of all available versions. Default false. @type bool $donate_link Whether to return the donation link. Default true. @type bool $reviews Whether to return the plugin reviews. Default false. @type bool $banners Whether to return the banner images links. Default false. @type bool $icons Whether to return the icon links. Default false. @type bool $active_installs Whether to return the number of active installations. Default false. @type bool $group Whether to return the assigned group. Default false. @type bool $contributors Whether to return the list of contributors. Default false. } }
    Required:
    Default: array()
返回值
  • (object|array|WP_Error) Response object or array on success, WP_Error on failure. See the {@link function reference article} for more information on the make-up of possible return values depending on the value of `$action`.
定义位置
相关方法
plugins_urlis_plugin_activeadd_plugins_pageis_plugin_pageplugin_dir_url
引入
2.7.0
弃用
-

plugins_api: 这是一个WordPress的函数,从WordPress.org的插件API中检索插件信息。它接受一个插件的lug和一个可选的版本号,并返回一个包含插件详细信息的对象,如名称、描述、版本、作者、评级和下载链接。

从WordPress.org Plugins API中检索插件安装页面。

一个插件有可能用三个过滤器来覆盖Plugin API的结果。假设这是给插件的,它可以在插件信息上进行扩展,以提供更多的选择。
提供更多的选择。这非常强大,在覆盖过滤器时必须谨慎使用。

第一个过滤器,{@see ‘plugins_api_args’},是针对args的,并给出动作作为第二个参数。{@see ‘plugins_api_args’}的钩子必须确保返回的是一个对象。

第二个过滤器,{@see ‘plugins_api’},允许一个插件完全覆盖WordPress.org的插件安装API。如果`$action`是’query_plugins’或’plugin_information’,必须传递一个对象。如果`$action`是’hot_tags’或’hot_categories’,必须传递一个数组。

最后,第三个过滤器,{@see ‘plugins_api_result’},使得过滤响应对象或数组成为可能,这取决于`$action`类型。

每个动作支持的参数:
| Argument Name | query_plugins | plugin_information | hot_tags | hot_categories |
| ——————– | :———–: | :—————-: | :——: | :————: |
| `$slug` | No | Yes | No | No |
| `$per_page` | Yes | No | No | No |
| `$page` | Yes | No | No | No |
| `$number` | No | No | Yes | Yes |
| `$search` | Yes | No | No | No |
| `$tag` | Yes | No | No | No |
| `$author` | Yes | No | No | No |
| `$user` | Yes | No | No | No |
| `$browse` | Yes | No | No | No |
| `$locale` | Yes | Yes | No | No |
| `$installed_plugins` | Yes | No | No | No |
| `$is_ssl` | Yes | Yes | No | No |
| `$fields` | Yes | Yes | No | No |

function plugins_api( $action, $args = array() ) {
	// Include an unmodified $wp_version.
	require ABSPATH . WPINC . '/version.php';

	if ( is_array( $args ) ) {
		$args = (object) $args;
	}

	if ( 'query_plugins' === $action ) {
		if ( ! isset( $args->per_page ) ) {
			$args->per_page = 24;
		}
	}

	if ( ! isset( $args->locale ) ) {
		$args->locale = get_user_locale();
	}

	if ( ! isset( $args->wp_version ) ) {
		$args->wp_version = substr( $wp_version, 0, 3 ); // x.y
	}

	/**
	 * Filters the WordPress.org Plugin Installation API arguments.
	 *
	 * Important: An object MUST be returned to this filter.
	 *
	 * @since 2.7.0
	 *
	 * @param object $args   Plugin API arguments.
	 * @param string $action The type of information being requested from the Plugin Installation API.
	 */
	$args = apply_filters( 'plugins_api_args', $args, $action );

	/**
	 * Filters the response for the current WordPress.org Plugin Installation API request.
	 *
	 * Returning a non-false value will effectively short-circuit the WordPress.org API request.
	 *
	 * If `$action` is 'query_plugins' or 'plugin_information', an object MUST be passed.
	 * If `$action` is 'hot_tags' or 'hot_categories', an array should be passed.
	 *
	 * @since 2.7.0
	 *
	 * @param false|object|array $result The result object or array. Default false.
	 * @param string             $action The type of information being requested from the Plugin Installation API.
	 * @param object             $args   Plugin API arguments.
	 */
	$res = apply_filters( 'plugins_api', false, $action, $args );

	if ( false === $res ) {

		$url = 'http://api.wordpress.org/plugins/info/1.2/';
		$url = add_query_arg(
			array(
				'action'  => $action,
				'request' => $args,
			),
			$url
		);

		$http_url = $url;
		$ssl      = wp_http_supports( array( 'ssl' ) );
		if ( $ssl ) {
			$url = set_url_scheme( $url, 'https' );
		}

		$http_args = array(
			'timeout'    => 15,
			'user-agent' => 'WordPress/' . $wp_version . '; ' . home_url( '/' ),
		);
		$request   = wp_remote_get( $url, $http_args );

		if ( $ssl && is_wp_error( $request ) ) {
			if ( ! wp_is_json_request() ) {
				trigger_error(
					sprintf(
						/* translators: %s: Support forums URL. */
						__( 'An unexpected error occurred. Something may be wrong with WordPress.org or this server’s configuration. If you continue to have problems, please try the <a href="%s">support forums</a>.' ),
						__( 'https://wordpress.org/support/forums/' )
					) . ' ' . __( '(WordPress could not establish a secure connection to WordPress.org. Please contact your server administrator.)' ),
					headers_sent() || WP_DEBUG ? E_USER_WARNING : E_USER_NOTICE
				);
			}

			$request = wp_remote_get( $http_url, $http_args );
		}

		if ( is_wp_error( $request ) ) {
			$res = new WP_Error(
				'plugins_api_failed',
				sprintf(
					/* translators: %s: Support forums URL. */
					__( 'An unexpected error occurred. Something may be wrong with WordPress.org or this server’s configuration. If you continue to have problems, please try the <a href="%s">support forums</a>.' ),
					__( 'https://wordpress.org/support/forums/' )
				),
				$request->get_error_message()
			);
		} else {
			$res = json_decode( wp_remote_retrieve_body( $request ), true );
			if ( is_array( $res ) ) {
				// Object casting is required in order to match the info/1.0 format.
				$res = (object) $res;
			} elseif ( null === $res ) {
				$res = new WP_Error(
					'plugins_api_failed',
					sprintf(
						/* translators: %s: Support forums URL. */
						__( 'An unexpected error occurred. Something may be wrong with WordPress.org or this server’s configuration. If you continue to have problems, please try the <a href="%s">support forums</a>.' ),
						__( 'https://wordpress.org/support/forums/' )
					),
					wp_remote_retrieve_body( $request )
				);
			}

			if ( isset( $res->error ) ) {
				$res = new WP_Error( 'plugins_api_failed', $res->error );
			}
		}
	} elseif ( ! is_wp_error( $res ) ) {
		$res->external = true;
	}

	/**
	 * Filters the Plugin Installation API response results.
	 *
	 * @since 2.7.0
	 *
	 * @param object|WP_Error $res    Response object or WP_Error.
	 * @param string          $action The type of information being requested from the Plugin Installation API.
	 * @param object          $args   Plugin API arguments.
	 */
	return apply_filters( 'plugins_api_result', $res, $action, $args );
}

常见问题

FAQs
查看更多 >