返回介绍

themes_api()

发布于 2017-09-11 10:31:00 字数 13566 浏览 902 评论 0 收藏 0

themes_api( string $action,  array|object $args = array() )

Retrieves theme installer pages from the WordPress.org Themes API.


description

It is possible for a theme to override the Themes API result with three filters. Assume this is for themes, which can extend on the Theme Info to offer more choices. This is very powerful and must be used with care, when overriding the filters.

The first filter, ‘themes_api_args’, is for the args and gives the action as the second parameter. The hook for ‘themes_api_args’ must ensure that an object is returned.

The second filter, ‘themes_api’, allows a plugin to override the WordPress.org Theme API entirely. If $action is ‘query_themes’, ‘theme_information’, or ‘feature_list’, an object MUST be passed. If $action is ‘hot_tags’, an array should be passed.

Finally, the third filter, ‘themes_api_result’, makes it possible to filter the response object or array, depending on the $action type.

Supported arguments per action:

Argument Name‘query_themes’‘theme_information’‘hot_tags’‘feature_list’
$slugNoYesNoNo
$per_pageYesNoNoNo
$pageYesNoNoNo
$numberNoNoYesNo
$searchYesNoNoNo
$tagYesNoNoNo
$authorYesNoNoNo
$userYesNoNoNo
$browseYesNoNoNo
$localeYesYesNoNo
$fieldsYesYesNoNo

参数

$action

(string) (Required) API action to perform: 'query_themes', 'theme_information', 'hot_tags' or 'feature_list'.

$args

(array|object) (Optional) Array or object of arguments to serialize for the Themes API.

  • 'slug'
    (string) The theme slug.
  • 'per_page'
    (int) Number of themes per page. Default 24.
  • 'page'
    (int) Number of current page. Default 1.
  • 'number'
    (int) Number of tags to be queried.
  • 'search'
    (string) A search term.
  • 'tag'
    (string) Tag to filter themes.
  • 'author'
    (string) Username of an author to filter themes.
  • 'user'
    (string) Username to query for their favorites.
  • 'browse'
    (string) Browse view: 'featured', 'popular', 'updated', 'favorites'.
  • 'locale'
    (string) Locale to provide context-sensitive results. Default is the value of get_locale().
  • 'fields'
    (array) Array of fields which should or should not be returned.
    • 'description'
      (bool) Whether to return the theme full description. Default false.
    • 'sections'
      (bool) Whether to return the theme readme sections: description, installation, FAQ, screenshots, other notes, and 更新日志. Default false.
    • 'rating'
      (bool) Whether to return the rating in percent and total number of ratings. Default false.
    • 'ratings'
      (bool) Whether to return the number of rating for each star (1-5). Default false.
    • 'downloaded'
      (bool) Whether to return the download count. Default false.
    • 'downloadlink'
      (bool) Whether to return the download link for the package. Default false.
    • 'last_updated'
      (bool) Whether to return the date of the last update. Default false.
    • 'tags'
      (bool) Whether to return the assigned tags. Default false.
    • 'homepage'
      (bool) Whether to return the theme homepage link. Default false.
    • 'screenshots'
      (bool) Whether to return the screenshots. Default false.
    • 'screenshot_count'
      (int) Number of screenshots to return. Default 1.
    • 'screenshot_url'
      (bool) Whether to return the URL of the first screenshot. Default false.
    • 'photon_screenshots'
      (bool) Whether to return the screenshots via Photon. Default false.
    • 'template'
      (bool) Whether to return the slug of the parent theme. Default false.
    • 'parent'
      (bool) Whether to return the slug, name and homepage of the parent theme. Default false.
    • 'versions'
      (bool) Whether to return the list of all available versions. Default false.
    • 'theme_url'
      (bool) Whether to return theme's URL. Default false.
    • 'extended_author'
      (bool) Whether to return nicename or nicename and display name. Default false.

Default value: array()


返回值

(object|array|WP_Error) Response object or array on success, WP_Error on failure. See the function reference article for more information on the make-up of possible return objects depending on the value of $action.


源代码

File: wp-admin/includes/theme.php

function themes_api( $action, $args = array() ) {

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

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

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

	/**
	 * Filters arguments used to query for installer pages from the WordPress.org Themes API.
	 *
	 * Important: An object MUST be returned to this filter.
	 *
	 * @since 2.8.0
	 *
	 * @param object $args   Arguments used to query for installer pages from the WordPress.org Themes API.
	 * @param string $action Requested action. Likely values are 'theme_information',
	 *                       'feature_list', or 'query_themes'.
	 */
	$args = apply_filters( 'themes_api_args', $args, $action );

	/**
	 * Filters whether to override the WordPress.org Themes API.
	 *
	 * Passing a non-false value will effectively short-circuit the WordPress.org API request.
	 *
	 * If `$action` is 'query_themes', 'theme_information', or 'feature_list', an object MUST
	 * be passed. If `$action` is 'hot_tags', an array should be passed.
	 *
	 * @since 2.8.0
	 *
	 * @param false|object|array $override Whether to override the WordPress.org Themes API. Default false.
	 * @param string             $action   Requested action. Likely values are 'theme_information',
	 *                                    'feature_list', or 'query_themes'.
	 * @param object             $args     Arguments used to query for installer pages from the Themes API.
	 */
	$res = apply_filters( 'themes_api', false, $action, $args );

	if ( ! $res ) {
		$url = $http_url = 'http://api.wordpress.org/themes/info/1.0/';
		if ( $ssl = wp_http_supports( array( 'ssl' ) ) )
			$url = set_url_scheme( $url, 'https' );

		$http_args = array(
			'body' => array(
				'action' => $action,
				'request' => serialize( $args )
			)
		);
		$request = wp_remote_post( $url, $http_args );

		if ( $ssl && is_wp_error( $request ) ) {
			if ( ! wp_doing_ajax() ) {
				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/' )
					) . ' ' . __( '(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_post( $http_url, $http_args );
		}

		if ( is_wp_error($request) ) {
			$res = new WP_Error( 'themes_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/' )
				),
				$request->get_error_message()
			);
		} else {
			$res = maybe_unserialize( wp_remote_retrieve_body( $request ) );
			if ( ! is_object( $res ) && ! is_array( $res ) ) {
				$res = new WP_Error( 'themes_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/' )
					),
					wp_remote_retrieve_body( $request )
				);
			}
		}
	}

	/**
	 * Filters the returned WordPress.org Themes API response.
	 *
	 * @since 2.8.0
	 *
	 * @param array|object|WP_Error $res    WordPress.org Themes API response.
	 * @param string                $action Requested action. Likely values are 'theme_information',
	 *                                      'feature_list', or 'query_themes'.
	 * @param object                $args   Arguments used to query for installer pages from the WordPress.org Themes API.
	 */
	return apply_filters( 'themes_api_result', $res, $action, $args );
}

更新日志

Versiondescription
2.8.0Introduced.

相关函数

Uses

  • wp-includes/load.php: wp_doing_ajax()
  • wp-includes/l10n.php: get_user_locale()
  • wp-admin/includes/theme.php: themes_api_args
  • wp-admin/includes/theme.php: themes_api
  • wp-admin/includes/theme.php: themes_api_result
  • wp-includes/l10n.php: __()
  • wp-includes/functions.php: maybe_unserialize()
  • wp-includes/link-template.php: set_url_scheme()
  • wp-includes/http.php: wp_http_supports()
  • wp-includes/http.php: wp_remote_post()
  • wp-includes/http.php: wp_remote_retrieve_body()
  • wp-includes/plugin.php: apply_filters()
  • wp-includes/load.php: is_wp_error()
  • wp-includes/class-wp-error.php: WP_Error::__construct()
  • Show 9 more uses Hide more uses

Used By

  • wp-admin/includes/ajax-actions.php: wp_ajax_install_theme()
  • wp-admin/includes/class-theme-upgrader.php: Theme_Upgrader::check_parent_theme_filter()
  • wp-admin/includes/theme.php: get_theme_feature_list()
  • wp-admin/includes/theme-install.php: install_themes_feature_list()
  • wp-admin/includes/theme-install.php: install_theme_information()
  • wp-admin/includes/class-wp-theme-install-list-table.php: WP_Theme_Install_List_Table::prepare_items()
  • wp-admin/includes/ajax-actions.php: wp_ajax_query_themes()
  • Show 2 more used by Hide more used by

User Contributed Notes

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文