WordPress : Comment mettre en liste blanche plus d’options pour l’API XML-RPC ?
Jusqu’à ce que les points de terminaison de l’API REST soient ajoutés au cur de WordPress, j’ai besoin d’un moyen de mettre à jour par programme les options que l’API XML-RPC n’inclut pas par défaut. Il semble que les options soient ajoutées dans le fichier « wp-includes/class-wp-xmlrpc-server.php » via la méthode suivante :
public function initialise_blog_option_info() {
global $wp_version;
$this->blog_options = array(
// Read only options
'software_name' => array(
'desc' => __( 'Software Name' ),
'readonly' => true,
'value' => 'WordPress'
),
'software_version' => array(
'desc' => __( 'Software Version' ),
'readonly' => true,
'value' => $wp_version
),
'blog_url' => array(
'desc' => __( 'WordPress Address (URL)' ),
'readonly' => true,
'option' => 'siteurl'
),
'home_url' => array(
'desc' => __( 'Site Address (URL)' ),
'readonly' => true,
'option' => 'home'
),
'login_url' => array(
'desc' => __( 'Login Address (URL)' ),
'readonly' => true,
'value' => wp_login_url( )
),
'admin_url' => array(
'desc' => __( 'The URL to the admin area' ),
'readonly' => true,
'value' => get_admin_url( )
),
'image_default_link_type' => array(
'desc' => __( 'Image default link type' ),
'readonly' => true,
'option' => 'image_default_link_type'
),
'image_default_size' => array(
'desc' => __( 'Image default size' ),
'readonly' => true,
'option' => 'image_default_size'
),
'image_default_align' => array(
'desc' => __( 'Image default align' ),
'readonly' => true,
'option' => 'image_default_align'
),
'template' => array(
'desc' => __( 'Template' ),
'readonly' => true,
'option' => 'template'
),
'stylesheet' => array(
'desc' => __( 'Stylesheet' ),
'readonly' => true,
'option' => 'stylesheet'
),
'post_thumbnail' => array(
'desc' => __('Post Thumbnail'),
'readonly' => true,
'value' => current_theme_supports( 'post-thumbnails' )
),
// Updatable options
'time_zone' => array(
'desc' => __( 'Time Zone' ),
'readonly' => false,
'option' => 'gmt_offset'
),
'blog_title' => array(
'desc' => __( 'Site Title' ),
'readonly' => false,
'option' => 'blogname'
),
'blog_tagline' => array(
'desc' => __( 'Site Tagline' ),
'readonly' => false,
'option' => 'blogdescription'
),
'date_format' => array(
'desc' => __( 'Date Format' ),
'readonly' => false,
'option' => 'date_format'
),
'time_format' => array(
'desc' => __( 'Time Format' ),
'readonly' => false,
'option' => 'time_format'
),
'users_can_register' => array(
'desc' => __( 'Allow new users to sign up' ),
'readonly' => false,
'option' => 'users_can_register'
),
'thumbnail_size_w' => array(
'desc' => __( 'Thumbnail Width' ),
'readonly' => false,
'option' => 'thumbnail_size_w'
),
'thumbnail_size_h' => array(
'desc' => __( 'Thumbnail Height' ),
'readonly' => false,
'option' => 'thumbnail_size_h'
),
'thumbnail_crop' => array(
'desc' => __( 'Crop thumbnail to exact dimensions' ),
'readonly' => false,
'option' => 'thumbnail_crop'
),
'medium_size_w' => array(
'desc' => __( 'Medium size image width' ),
'readonly' => false,
'option' => 'medium_size_w'
),
'medium_size_h' => array(
'desc' => __( 'Medium size image height' ),
'readonly' => false,
'option' => 'medium_size_h'
),
'medium_large_size_w' => array(
'desc' => __( 'Medium-Large size image width' ),
'readonly' => false,
'option' => 'medium_large_size_w'
),
'medium_large_size_h' => array(
'desc' => __( 'Medium-Large size image height' ),
'readonly' => false,
'option' => 'medium_large_size_h'
),
'large_size_w' => array(
'desc' => __( 'Large size image width' ),
'readonly' => false,
'option' => 'large_size_w'
),
'large_size_h' => array(
'desc' => __( 'Large size image height' ),
'readonly' => false,
'option' => 'large_size_h'
),
'default_comment_status' => array(
'desc' => __( 'Allow people to post comments on new articles' ),
'readonly' => false,
'option' => 'default_comment_status'
),
'default_ping_status' => array(
'desc' => __( 'Allow link notifications from other blogs (pingbacks and trackbacks) on new articles' ),
'readonly' => false,
'option' => 'default_ping_status'
)
);
/**
* Filter the XML-RPC blog options property.
*
* @since 2.6.0
*
* @param array $blog_options An array of XML-RPC blog options.
*/
$this->blog_options = apply_filters( 'xmlrpc_blog_options', $this->blog_options );
}
Voici ma tentative infructueuse de modification des options pour permettre la mise à jour des options blog_url, home_url et WPCF7 dans mon fichier functions.php (site_url et home_url étaient en lecture seule dans la fonction d’origine):
public function blog_option_info() {
global $wp_version;
$this->blog_options = array(
// Updatable options
'blog_url' => array(
'desc' => __( 'WordPress Address (URL)' ),
'readonly' => false,
'option' => 'siteurl'
),
'home_url' => array(
'desc' => __( 'Site Address (URL)' ),
'readonly' => false,
'option' => 'home'
),
'wpcf7' => array(
'desc' => __( 'Contact Form 7 Options' ),
'readonly' => false,
'option' => 'wpcf7'
),
);
$this->blog_options = apply_filters( 'xmlrpc_blog_options', $this->blog_options );
}
Quelle est la bonne façon d’ajouter plus d’options à la liste blanche afin que je puisse les obtenir et les mettre à jour via l’API ?
Solution n°1 trouvée
Je viens de rencontrer ce problème moi-même et je ne mentionne absolument nulle part comment le faire en ligne. Votre message soulignant que les options de la liste blanche sont définies dans $this->blog_options a aidé, alors merci ! Voici le code (c’est dans un plugin personnalisé):
<?php
include_once(ABSPATH . WPINC . '/class-IXR.php');
include_once(ABSPATH . WPINC . '/class-wp-xmlrpc-server.php');
class LSEOP_XmlRpc extends wp_xmlrpc_server {
private $version = 1.0;
public function __construct() {
parent::__construct();
$this->blog_options['permalink_structure'] = [
'desc' => __( 'Permalink Structure' ),
'readonly' => false,
'option' => 'permalink_structure'
];
}
public static function lseop_getName() {
return __CLASS__;
}
}
add_filter('wp_xmlrpc_server_class', array('LSEOP_XmlRpc', 'lseop_getName'));
?>
Il y a beaucoup d’autres codes dans le plugin car j’ajoute également des méthodes XMLRPC mais cela devrait être tout ce dont vous avez besoin.
Solution n°2 trouvée
Si vous souhaitez ajouter la prise en charge de l’option de lecture/écriture via XML-RPC pour l’option nommée NAME_OF_SOME_OPTION, ajoutez le code suivant à votre functions.php :
add_filter('xmlrpc_blog_options', function($blog_options)
{
$blog_options['NAME_OF_SOME_OPTION'] = array(
'desc' => 'DESCRITPTION OF THE OPTION',
'readonly' => false,
'option' => 'NAME_OF_SOME_OPTION'
);
return $blog_options;
});
Si vous souhaitez pouvoir mettre à jour l’option blog_url via XML-RPC, écrivez ce qui suit :
add_filter('xmlrpc_blog_options', function($blog_options)
{
$blog_options['blog_url']['readonly'] = false;
return $blog_options;
});
0 commentaire