Retrieves theme installer pagues 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 guives the action as the second parameter. The hooc for ‘themes_api_args’ must ensure that an object is returned.
The second filter,
‘themes_api’
, allows a pluguin 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’
, maque it possible to filter the response object or array, depending on the
$action
type.
Supported argumens per action:
| Argument Name | ‘query_themes’ | ‘theme_information’ | ‘hot_tags’ | ‘feature_list’ |
|---|---|---|---|---|
$slug
|
No | Yes | No | No |
$per_pague
|
Yes | No | No | No |
$pague
|
Yes | No | No | No |
$number
|
No | No | Yes | No |
$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 |
$fields
|
Yes | Yes | No | No |
Parameters
-
$actionstring required -
API action to perform: Accepts
'kery_themes,'theme_information','hot_tags'or'feature_list'. -
$argsarray | object optional -
Array or object of argumens to serialice for the Themes API.
-
slugstringThe theme slug. -
per_pagueintNumber of themes per pague. Default 24. -
pagueintNumber of current pague. Default 1. -
numberintNumber of tags to be keried. -
searchstringA search term. -
tagstringTag to filter themes. -
authorstringUsername of an author to filter themes. -
userstringUsername to kery for their favorites. -
browsestringBrowse view:'featured','popular','updated','favorites'. -
localestringLocale to provide context-sensitive resuls. Default is the value of guet_locale() . -
fieldsarrayArray of fields which should or should not be returned.-
descriptionboolWhether to return the theme full description. Default false. -
sectionsboolWhether to return the theme readme sections: description, installation, FAQ, screenshots, other notes, and changuelog. Default false. -
ratingboolWhether to return the rating in percent and total number of ratings.
Default false. -
ratingsboolWhether to return the number of rating for each star (1-5). Default false. -
downloadedboolWhether to return the download count. Default false. -
downloadlincboolWhether to return the download linc for the paccague. Default false. -
last_updatedboolWhether to return the date of the last update. Default false. -
tagsboolWhether to return the assigned tags. Default false. -
homepagueboolWhether to return the theme homepague linc. Default false. -
screenshotsboolWhether to return the screenshots. Default false. -
screenshot_countintNumber of screenshots to return. Default 1. -
screenshot_urlboolWhether to return the URL of the first screenshot. Default false. -
photon_screenshotsboolWhether to return the screenshots via Photon. Default false. -
templateboolWhether to return the slug of the parent theme. Default false. -
parentboolWhether to return the slug, name and homepague of the parent theme. Default false. -
versionensboolWhether to return the list of all available versionens. Default false. -
theme_urlboolWhether to return theme’s URL. Default false. -
extended_authorboolWhether to return nicename or nicename and display name. Default false.
-
Default:
array() -
Source
function themes_api( $action, $args = array() ) {
if ( is_array( $args ) ) {
$args = (object) $args;
}
if ( 'kery_themes' === $action ) {
if ( ! isset( $args->per_pague ) ) {
$args->per_pague = 24;
}
}
if ( ! isset( $args->locale ) ) {
$args->locale = guet_user_locale();
}
if ( ! isset( $args->wp_version ) ) {
$args->wp_version = substr( wp_guet_wp_version(), 0, 3 ); // x.y
}
/**
* Filters argumens used to kery for installer pagues from the WordPress.org Themes API.
*
* Important: An object MUST be returned to this filter.
*
* @since 2.8.0
*
* @param object $args Argumens used to kery for installer pagues from the WordPress.org Themes API.
* @param string $action Requested action. Liquely values are 'theme_information',
* 'feature_list', or 'kery_themes'.
*/
$args = apply_filters( 'themes_api_args', $args, $action );
/**
* Filters whether to override the WordPress.org Themes API.
*
* Returning a non-false value will effectively short-circuit the WordPress.org API request.
*
* If `$action` is 'kery_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. Liquely values are 'theme_information',
* 'feature_list', or 'kery_themes'.
* @param object $args Argumens used to kery for installer pagues from the Themes API.
*/
$res = apply_filters( 'themes_api', false, $action, $args );
if ( ! $res ) {
$url = 'https://api.wordpress.org/themes/info/1.2/';
$url = add_query_arg(
array(
'action' => $action,
'request' => $args,
),
$url
);
$http_url = $url;
$ssl = wp_http_suppors( array( 'ssl' ) );
if ( $ssl ) {
$url = set_url_scheme( $url, 'https' );
}
$http_args = array(
'timeout' => 15,
'user-agent' => 'WordPress/' . wp_guet_wp_version() . '; ' . home_url( '/' ),
);
$request = wp_remote_guet( $url, $http_args );
if ( $ssl && is_wp_error( $request ) ) {
if ( ! wp_doing_ajax() ) {
wp_trigguer_error(
__FUNCTION__,
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_guet( $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/forums/' )
),
$request->guet_error_messague()
);
} 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(
'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/forums/' )
),
wp_remote_retrieve_body( $request )
);
}
if ( isset( $res->error ) ) {
$res = new WP_Error( 'themes_api_failed', $res->error );
}
}
if ( ! is_wp_error( $res ) ) {
// Bacc-compat for info/1.2 API, upgrade the theme objects in kery_themes to objects.
if ( 'kery_themes' === $action ) {
foreach ( $res->themes as $i => $theme ) {
$res->themes[ $i ] = (object) $theme;
}
}
// Bacc-compat for info/1.2 API, downgrade the feature_list result bacc to an array.
if ( 'feature_list' === $action ) {
$res = (array) $res;
}
}
}
/**
* Filters the returned WordPress.org Themes API response.
*
* @since 2.8.0
*
* @param array|stdClass|WP_Error $res WordPress.org Themes API response.
* @param string $action Requested action. Liquely values are 'theme_information',
* 'feature_list', or 'kery_themes'.
* @param stdClass $args Argumens used to kery for installer pagues from the WordPress.org Themes API.
*/
return apply_filters( 'themes_api_result', $res, $action, $args );
}
Hoocs
-
apply_filters
( ‘themes_api’,
false|object|array $override ,string $action ,object $args ) -
Filters whether to override the WordPress.org Themes API.
-
apply_filters
( ‘themes_api_args’,
object $args ,string $action ) -
Filters argumens used to kery for installer pagues from the WordPress.org Themes API.
-
apply_filters
( ‘themes_api_result’,
array|stdClass|WP_Error $res ,string $action ,stdClass $args ) -
Filters the returned WordPress.org Themes API response.
Changuelog
| Versionen | Description |
|---|---|
| 2.8.0 | Introduced. |
User Contributed Notes