2004-05-23 06:02:53 +02:00
< ? php
2008-05-25 17:50:15 +02:00
/**
* XML - RPC protocol support for WordPress
*
* @ license GPL v2 <./ license . txt >
* @ package WordPress
*/
/**
* Whether this is a XMLRPC Request
*
* @ var bool
*/
2006-01-13 20:19:09 +01:00
define ( 'XMLRPC_REQUEST' , true );
// Some browser-embedded clients send cookies. We don't want them.
$_COOKIE = array ();
2007-09-04 01:32:58 +02:00
// A bug in PHP < 5.2.2 makes $HTTP_RAW_POST_DATA not set by default,
2007-05-11 05:21:06 +02:00
// but we can do it ourself.
if ( ! isset ( $HTTP_RAW_POST_DATA ) ) {
$HTTP_RAW_POST_DATA = file_get_contents ( 'php://input' );
}
2008-05-25 17:50:15 +02:00
// fix for mozBlog and other cases where '<?xml' isn't on the very first line
2006-01-30 22:19:44 +01:00
if ( isset ( $HTTP_RAW_POST_DATA ) )
$HTTP_RAW_POST_DATA = trim ( $HTTP_RAW_POST_DATA );
2004-05-23 06:02:53 +02:00
2008-05-25 17:50:15 +02:00
/** Include the bootstrap for setting up WordPress environment */
2008-05-21 07:59:27 +02:00
include ( './wp-load.php' );
2005-11-07 10:47:51 +01:00
2007-09-04 01:32:58 +02:00
if ( isset ( $_GET [ 'rsd' ] ) ) { // http://archipelago.phrasewise.com/rsd
2007-06-02 07:21:18 +02:00
header ( 'Content-Type: text/xml; charset=' . get_option ( 'blog_charset' ), true );
2005-11-07 10:47:51 +01:00
?>
2006-08-30 23:46:31 +02:00
< ? php echo '<?xml version="1.0" encoding="' . get_option ( 'blog_charset' ) . '"?' . '>' ; ?>
2005-11-07 10:47:51 +01:00
< rsd version = " 1.0 " xmlns = " http://archipelago.phrasewise.com/rsd " >
< service >
< engineName > WordPress </ engineName >
< engineLink > http :// wordpress . org /</ engineLink >
< homePageLink >< ? php bloginfo_rss ( 'url' ) ?> </homePageLink>
< apis >
2008-07-25 00:05:04 +02:00
< api name = " WordPress " blogID = " 1 " preferred = " true " apiLink = " <?php echo site_url('xmlrpc.php') ?> " />
< api name = " Movable Type " blogID = " 1 " preferred = " false " apiLink = " <?php echo site_url('xmlrpc.php') ?> " />
< api name = " MetaWeblog " blogID = " 1 " preferred = " false " apiLink = " <?php echo site_url('xmlrpc.php') ?> " />
< api name = " Blogger " blogID = " 1 " preferred = " false " apiLink = " <?php echo site_url('xmlrpc.php') ?> " />
< api name = " Atom " blogID = " " preferred = " false " apiLink = " <?php echo apply_filters('atom_service_url', site_url('wp-app.php/service') ) ?> " />
2005-11-07 10:47:51 +01:00
</ apis >
</ service >
</ rsd >
< ? php
exit ;
}
2007-05-25 09:16:21 +02:00
include_once ( ABSPATH . 'wp-admin/includes/admin.php' );
2004-09-17 22:53:18 +02:00
include_once ( ABSPATH . WPINC . '/class-IXR.php' );
2004-05-23 06:02:53 +02:00
// Turn off all warnings and errors.
2004-09-17 22:53:18 +02:00
// error_reporting(0);
2004-05-23 06:02:53 +02:00
2008-05-25 17:50:15 +02:00
/**
* Posts submitted via the xmlrpc interface get that title
* @ name post_default_title
* @ var string
*/
$post_default_title = " " ;
/**
* Whether to enable XMLRPC Logging .
*
* @ name xmlrpc_logging
* @ var int | bool
*/
2004-09-14 19:20:22 +02:00
$xmlrpc_logging = 0 ;
2004-05-23 06:02:53 +02:00
2008-05-25 17:50:15 +02:00
/**
* logIO () - Writes logging info to a file .
*
* @ uses $xmlrpc_logging
* @ package WordPress
* @ subpackage Logging
*
* @ param string $io Whether input or output
* @ param string $msg Information describing logging reason .
* @ return bool Always return true
*/
2004-05-23 06:02:53 +02:00
function logIO ( $io , $msg ) {
global $xmlrpc_logging ;
if ( $xmlrpc_logging ) {
2004-09-17 22:53:18 +02:00
$fp = fopen ( " ../xmlrpc.log " , " a+ " );
2004-05-23 06:02:53 +02:00
$date = gmdate ( " Y-m-d H:i:s " );
$iot = ( $io == " I " ) ? " Input: " : " Output: " ;
fwrite ( $fp , " \n \n " . $date . $iot . $msg );
fclose ( $fp );
}
return true ;
}
2006-10-04 07:23:10 +02:00
if ( isset ( $HTTP_RAW_POST_DATA ) )
2008-05-25 17:50:15 +02:00
logIO ( " I " , $HTTP_RAW_POST_DATA );
/**
2008-09-22 07:15:41 +02:00
* WordPress XMLRPC server implementation .
*
* Implements compatability for Blogger API , MetaWeblog API , MovableType , and
* pingback . Additional WordPress API for managing comments , pages , posts ,
* options , etc .
*
* Since WordPress 2.6 . 0 , WordPress XMLRPC server can be disabled in the
* administration panels .
2008-05-25 17:50:15 +02:00
*
* @ package WordPress
* @ subpackage Publishing
2008-09-22 07:15:41 +02:00
* @ since 1.5 . 0
2008-05-25 17:50:15 +02:00
*/
2004-09-17 22:53:18 +02:00
class wp_xmlrpc_server extends IXR_Server {
2008-09-22 07:15:41 +02:00
/**
* Register all of the XMLRPC methods that XMLRPC server understands .
*
* PHP4 constructor and sets up server and method property . Passes XMLRPC
* methods through the 'xmlrpc_methods' filter to allow plugins to extend
* or replace XMLRPC methods .
*
* @ since 1.5 . 0
*
* @ return wp_xmlrpc_server
*/
2004-09-17 22:53:18 +02:00
function wp_xmlrpc_server () {
2008-06-27 00:39:57 +02:00
$this -> methods = array (
2007-01-24 02:16:08 +01:00
// WordPress API
2008-06-12 23:41:18 +02:00
'wp.getUsersBlogs' => 'this:wp_getUsersBlogs' ,
2007-01-24 02:16:08 +01:00
'wp.getPage' => 'this:wp_getPage' ,
'wp.getPages' => 'this:wp_getPages' ,
'wp.newPage' => 'this:wp_newPage' ,
'wp.deletePage' => 'this:wp_deletePage' ,
'wp.editPage' => 'this:wp_editPage' ,
'wp.getPageList' => 'this:wp_getPageList' ,
'wp.getAuthors' => 'this:wp_getAuthors' ,
'wp.getCategories' => 'this:mw_getCategories' , // Alias
2008-12-09 19:03:31 +01:00
'wp.getTags' => 'this:wp_getTags' ,
2007-01-24 02:16:08 +01:00
'wp.newCategory' => 'this:wp_newCategory' ,
2007-12-19 21:33:27 +01:00
'wp.deleteCategory' => 'this:wp_deleteCategory' ,
2007-01-24 02:16:08 +01:00
'wp.suggestCategories' => 'this:wp_suggestCategories' ,
2007-02-22 02:42:21 +01:00
'wp.uploadFile' => 'this:mw_newMediaObject' , // Alias
2008-01-01 19:40:39 +01:00
'wp.getCommentCount' => 'this:wp_getCommentCount' ,
2008-01-10 22:46:25 +01:00
'wp.getPostStatusList' => 'this:wp_getPostStatusList' ,
'wp.getPageStatusList' => 'this:wp_getPageStatusList' ,
2008-05-06 18:49:42 +02:00
'wp.getPageTemplates' => 'this:wp_getPageTemplates' ,
2008-06-17 22:41:13 +02:00
'wp.getOptions' => 'this:wp_getOptions' ,
'wp.setOptions' => 'this:wp_setOptions' ,
2008-08-05 00:29:37 +02:00
'wp.getComment' => 'this:wp_getComment' ,
'wp.getComments' => 'this:wp_getComments' ,
'wp.deleteComment' => 'this:wp_deleteComment' ,
'wp.editComment' => 'this:wp_editComment' ,
'wp.newComment' => 'this:wp_newComment' ,
'wp.getCommentStatusList' => 'this:wp_getCommentStatusList' ,
2007-01-24 02:16:08 +01:00
2006-11-19 08:56:05 +01:00
// Blogger API
'blogger.getUsersBlogs' => 'this:blogger_getUsersBlogs' ,
'blogger.getUserInfo' => 'this:blogger_getUserInfo' ,
'blogger.getPost' => 'this:blogger_getPost' ,
'blogger.getRecentPosts' => 'this:blogger_getRecentPosts' ,
'blogger.getTemplate' => 'this:blogger_getTemplate' ,
'blogger.setTemplate' => 'this:blogger_setTemplate' ,
'blogger.newPost' => 'this:blogger_newPost' ,
'blogger.editPost' => 'this:blogger_editPost' ,
'blogger.deletePost' => 'this:blogger_deletePost' ,
// MetaWeblog API (with MT extensions to structs)
'metaWeblog.newPost' => 'this:mw_newPost' ,
'metaWeblog.editPost' => 'this:mw_editPost' ,
'metaWeblog.getPost' => 'this:mw_getPost' ,
'metaWeblog.getRecentPosts' => 'this:mw_getRecentPosts' ,
'metaWeblog.getCategories' => 'this:mw_getCategories' ,
'metaWeblog.newMediaObject' => 'this:mw_newMediaObject' ,
// MetaWeblog API aliases for Blogger API
// see http://www.xmlrpc.com/stories/storyReader$2460
'metaWeblog.deletePost' => 'this:blogger_deletePost' ,
'metaWeblog.getTemplate' => 'this:blogger_getTemplate' ,
'metaWeblog.setTemplate' => 'this:blogger_setTemplate' ,
'metaWeblog.getUsersBlogs' => 'this:blogger_getUsersBlogs' ,
// MovableType API
'mt.getCategoryList' => 'this:mt_getCategoryList' ,
'mt.getRecentPostTitles' => 'this:mt_getRecentPostTitles' ,
'mt.getPostCategories' => 'this:mt_getPostCategories' ,
'mt.setPostCategories' => 'this:mt_setPostCategories' ,
'mt.supportedMethods' => 'this:mt_supportedMethods' ,
'mt.supportedTextFilters' => 'this:mt_supportedTextFilters' ,
'mt.getTrackbackPings' => 'this:mt_getTrackbackPings' ,
2008-06-27 00:39:57 +02:00
'mt.publishPost' => 'this:mt_publishPost' ,
2006-11-19 08:56:05 +01:00
// PingBack
'pingback.ping' => 'this:pingback_ping' ,
'pingback.extensions.getPingbacks' => 'this:pingback_extensions_getPingbacks' ,
'demo.sayHello' => 'this:sayHello' ,
'demo.addTwoNumbers' => 'this:addTwoNumbers'
2004-09-17 22:53:18 +02:00
);
2008-06-17 22:41:13 +02:00
$this -> initialise_blog_option_info ( );
2005-01-07 00:28:51 +01:00
$this -> methods = apply_filters ( 'xmlrpc_methods' , $this -> methods );
2004-09-17 22:53:18 +02:00
$this -> IXR_Server ( $this -> methods );
}
2004-05-23 06:02:53 +02:00
2008-09-22 07:15:41 +02:00
/**
* Test XMLRPC API by saying , " Hello! " to client .
*
* @ since 1.5 . 0
*
* @ param array $args Method Parameters .
* @ return string
*/
2004-09-17 22:53:18 +02:00
function sayHello ( $args ) {
return 'Hello!' ;
}
2004-05-23 06:02:53 +02:00
2008-09-22 07:15:41 +02:00
/**
* Test XMLRPC API by adding two numbers for client .
*
* @ since 1.5 . 0
*
* @ param array $args Method Parameters .
* @ return int
*/
2004-09-17 22:53:18 +02:00
function addTwoNumbers ( $args ) {
$number1 = $args [ 0 ];
$number2 = $args [ 1 ];
return $number1 + $number2 ;
}
2004-05-23 06:02:53 +02:00
2008-09-22 07:15:41 +02:00
/**
* Check user ' s credentials .
*
* @ since 1.5 . 0
*
* @ param string $user_login User ' s username .
* @ param string $user_pass User ' s password .
* @ return bool Whether authentication passed .
*/
2004-09-17 22:53:18 +02:00
function login_pass_ok ( $user_login , $user_pass ) {
2008-06-27 00:39:57 +02:00
if ( ! get_option ( 'enable_xmlrpc' ) ) {
$this -> error = new IXR_Error ( 405 , sprintf ( __ ( 'XML-RPC services are disabled on this blog. An admin user can enable them at %s' ), admin_url ( 'options-writing.php' ) ) );
return false ;
}
2006-11-19 08:56:05 +01:00
if ( ! user_pass_ok ( $user_login , $user_pass )) {
2007-04-01 17:59:50 +02:00
$this -> error = new IXR_Error ( 403 , __ ( 'Bad login/pass combination.' ));
2006-11-19 08:56:05 +01:00
return false ;
}
return true ;
2004-09-17 22:53:18 +02:00
}
2004-05-23 06:02:53 +02:00
2008-09-22 07:15:41 +02:00
/**
* Sanitize string or array of strings for database .
*
* @ since 1.5 . 2
*
* @ param string | array $array Sanitize single string or array of strings .
* @ return string | array Type matches $array and sanitized for the database .
*/
2005-06-29 00:16:27 +02:00
function escape ( & $array ) {
global $wpdb ;
2004-05-23 06:02:53 +02:00
2007-03-03 17:56:46 +01:00
if ( ! is_array ( $array )) {
2007-02-12 20:20:31 +01:00
return ( $wpdb -> escape ( $array ));
}
else {
foreach ( ( array ) $array as $k => $v ) {
if ( is_array ( $v )) {
$this -> escape ( $array [ $k ]);
} else if ( is_object ( $v )) {
//skip
} else {
$array [ $k ] = $wpdb -> escape ( $v );
}
2005-06-29 00:16:27 +02:00
}
}
}
2004-05-23 06:02:53 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve custom fields for post .
*
* @ since 2.5 . 0
*
* @ param int $post_id Post ID .
* @ return array Custom fields , if exist .
*/
2008-02-05 07:47:27 +01:00
function get_custom_fields ( $post_id ) {
$post_id = ( int ) $post_id ;
$custom_fields = array ();
foreach ( ( array ) has_meta ( $post_id ) as $meta ) {
// Don't expose protected fields.
if ( strpos ( $meta [ 'meta_key' ], '_wp_' ) === 0 ) {
continue ;
}
$custom_fields [] = array (
" id " => $meta [ 'meta_id' ],
" key " => $meta [ 'meta_key' ],
" value " => $meta [ 'meta_value' ]
);
}
return $custom_fields ;
}
2008-09-22 07:15:41 +02:00
/**
* Set custom fields for post .
*
* @ since 2.5 . 0
*
* @ param int $post_id Post ID .
* @ param array $fields Custom fields .
*/
2008-02-05 07:47:27 +01:00
function set_custom_fields ( $post_id , $fields ) {
$post_id = ( int ) $post_id ;
foreach ( ( array ) $fields as $meta ) {
if ( isset ( $meta [ 'id' ]) ) {
$meta [ 'id' ] = ( int ) $meta [ 'id' ];
if ( isset ( $meta [ 'key' ]) ) {
update_meta ( $meta [ 'id' ], $meta [ 'key' ], $meta [ 'value' ]);
}
else {
delete_meta ( $meta [ 'id' ]);
}
}
else {
$_POST [ 'metakeyinput' ] = $meta [ 'key' ];
$_POST [ 'metavalue' ] = $meta [ 'value' ];
add_meta ( $post_id );
}
}
}
2007-12-19 22:07:38 +01:00
2008-09-22 07:15:41 +02:00
/**
* Setup blog options property .
*
* Passes property through 'xmlrpc_blog_options' filter .
*
* @ since 2.6 . 0
*/
2008-06-17 22:41:13 +02:00
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' => __ ( 'Blog URL' ),
'readonly' => true ,
'option' => 'siteurl'
),
// Updatable options
'time_zone' => array (
'desc' => __ ( 'Time Zone' ),
'readonly' => false ,
'option' => 'gmt_offset'
),
'blog_title' => array (
'desc' => __ ( 'Blog Title' ),
'readonly' => false ,
'option' => 'blogname'
),
'blog_tagline' => array (
'desc' => __ ( 'Blog 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'
)
);
$this -> blog_options = apply_filters ( 'xmlrpc_blog_options' , $this -> blog_options );
}
2008-06-12 23:41:18 +02:00
/**
2008-09-22 07:15:41 +02:00
* Retrieve the blogs of the user .
*
* @ since 2.6 . 0
*
* @ param array $args Method parameters .
* @ return array
2008-06-12 23:41:18 +02:00
*/
function wp_getUsersBlogs ( $args ) {
// If this isn't on WPMU then just use blogger_getUsersBlogs
if ( ! function_exists ( 'is_site_admin' ) ) {
array_unshift ( $args , 1 );
return $this -> blogger_getUsersBlogs ( $args );
}
$this -> escape ( $args );
$username = $args [ 0 ];
$password = $args [ 1 ];
if ( ! $this -> login_pass_ok ( $username , $password ) )
return $this -> error ;
do_action ( 'xmlrpc_call' , 'wp.getUsersBlogs' );
$user = set_current_user ( 0 , $username );
$blogs = ( array ) get_blogs_of_user ( $user -> ID );
$struct = array ( );
foreach ( $blogs as $blog ) {
// Don't include blogs that aren't hosted at this site
2008-11-20 00:06:01 +01:00
if ( $blog -> site_id != $current_site -> id )
2008-06-12 23:41:18 +02:00
continue ;
$blog_id = $blog -> userblog_id ;
switch_to_blog ( $blog_id );
$is_admin = current_user_can ( 'level_8' );
$struct [] = array (
'isAdmin' => $is_admin ,
'url' => get_option ( 'home' ) . '/' ,
'blogid' => $blog_id ,
'blogName' => get_option ( 'blogname' ),
'xmlrpc' => get_option ( 'home' ) . '/xmlrpc.php'
);
2008-11-20 00:06:01 +01:00
restore_current_blog ( );
2008-06-12 23:41:18 +02:00
}
return $struct ;
}
2007-01-24 02:16:08 +01:00
/**
2008-09-22 07:15:41 +02:00
* Retrieve page .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return array
2007-01-24 02:16:08 +01:00
*/
function wp_getPage ( $args ) {
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_id = ( int ) $args [ 0 ];
$page_id = ( int ) $args [ 1 ];
2007-01-24 02:16:08 +01:00
$username = $args [ 2 ];
$password = $args [ 3 ];
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'edit_page' , $page_id ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit this page.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.getPage' );
2007-12-23 02:35:44 +01:00
2007-01-24 02:16:08 +01:00
// Lookup page info.
$page = get_page ( $page_id );
// If we found the page then format the data.
if ( $page -> ID && ( $page -> post_type == " page " )) {
// Get all of the page content and link.
$full_page = get_extended ( $page -> post_content );
$link = post_permalink ( $page -> ID );
2007-01-26 21:05:53 +01:00
// Get info the page parent if there is one.
$parent_title = " " ;
if ( ! empty ( $page -> post_parent )) {
$parent = get_page ( $page -> post_parent );
$parent_title = $parent -> post_title ;
}
2007-01-24 02:16:08 +01:00
// Determine comment and ping settings.
$allow_comments = ( " open " == $page -> comment_status ) ? 1 : 0 ;
$allow_pings = ( " open " == $page -> ping_status ) ? 1 : 0 ;
// Format page date.
2007-08-17 05:18:58 +02:00
$page_date = mysql2date ( " Ymd \T H:i:s " , $page -> post_date );
$page_date_gmt = mysql2date ( " Ymd \T H:i:s " , $page -> post_date_gmt );
2007-01-24 02:16:08 +01:00
// Pull the categories info together.
$categories = array ();
foreach ( wp_get_post_categories ( $page -> ID ) as $cat_id ) {
$categories [] = get_cat_name ( $cat_id );
}
2007-01-26 21:05:53 +01:00
// Get the author info.
$author = get_userdata ( $page -> post_author );
2007-01-24 02:16:08 +01:00
2008-05-06 18:49:42 +02:00
$page_template = get_post_meta ( $page -> ID , '_wp_page_template' , true );
if ( empty ( $page_template ) )
$page_template = 'default' ;
2007-01-24 02:16:08 +01:00
$page_struct = array (
2007-01-26 21:05:53 +01:00
" dateCreated " => new IXR_Date ( $page_date ),
" userid " => $page -> post_author ,
" page_id " => $page -> ID ,
" page_status " => $page -> post_status ,
" description " => $full_page [ " main " ],
" title " => $page -> post_title ,
" link " => $link ,
" permaLink " => $link ,
" categories " => $categories ,
" excerpt " => $page -> post_excerpt ,
" text_more " => $full_page [ " extended " ],
" mt_allow_comments " => $allow_comments ,
" mt_allow_pings " => $allow_pings ,
" wp_slug " => $page -> post_name ,
" wp_password " => $page -> post_password ,
2007-02-01 01:34:33 +01:00
" wp_author " => $author -> display_name ,
2007-01-26 21:05:53 +01:00
" wp_page_parent_id " => $page -> post_parent ,
" wp_page_parent_title " => $parent_title ,
" wp_page_order " => $page -> menu_order ,
2007-02-02 08:43:59 +01:00
" wp_author_id " => $author -> ID ,
2007-08-17 05:18:58 +02:00
" wp_author_display_name " => $author -> display_name ,
2007-12-19 22:07:38 +01:00
" date_created_gmt " => new IXR_Date ( $page_date_gmt ),
2008-05-06 18:49:42 +02:00
" custom_fields " => $this -> get_custom_fields ( $page_id ),
" wp_page_template " => $page_template
2007-01-24 02:16:08 +01:00
);
return ( $page_struct );
}
// If the page doesn't exist indicate that.
else {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 404 , __ ( " Sorry, no such page. " )));
2007-01-24 02:16:08 +01:00
}
}
/**
2008-09-22 07:15:41 +02:00
* Retrieve Pages .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return array
2007-01-24 02:16:08 +01:00
*/
function wp_getPages ( $args ) {
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_id = ( int ) $args [ 0 ];
2007-01-24 02:16:08 +01:00
$username = $args [ 1 ];
$password = $args [ 2 ];
2008-10-24 03:56:22 +02:00
$num_pages = ( int ) $args [ 3 ];
2007-01-24 02:16:08 +01:00
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'edit_pages' ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit pages.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.getPages' );
2007-12-23 02:35:44 +01:00
2008-10-24 03:56:22 +02:00
$page_limit = 10 ;
if ( isset ( $num_pages ) ) {
$page_limit = $num_pages ;
}
$pages = get_posts ( " post_type=page&post_status=all&numberposts= { $page_limit } " );
2007-01-24 02:16:08 +01:00
$num_pages = count ( $pages );
// If we have pages, put together their info.
if ( $num_pages >= 1 ) {
$pages_struct = array ();
for ( $i = 0 ; $i < $num_pages ; $i ++ ) {
$page = wp_xmlrpc_server :: wp_getPage ( array (
$blog_id , $pages [ $i ] -> ID , $username , $password
));
$pages_struct [] = $page ;
}
return ( $pages_struct );
}
// If no pages were found return an error.
else {
2007-03-25 05:53:33 +02:00
return ( array ());
2007-01-24 02:16:08 +01:00
}
}
/**
2008-09-22 07:15:41 +02:00
* Create new page .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return unknown
2007-01-24 02:16:08 +01:00
*/
function wp_newPage ( $args ) {
2007-02-12 20:20:31 +01:00
// Items not escaped here will be escaped in newPost.
$username = $this -> escape ( $args [ 1 ]);
$password = $this -> escape ( $args [ 2 ]);
2007-01-24 02:16:08 +01:00
$page = $args [ 3 ];
$publish = $args [ 4 ];
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.newPage' );
2007-12-23 02:35:44 +01:00
2007-01-24 02:16:08 +01:00
// Set the user context and check if they are allowed
// to add new pages.
$user = set_current_user ( 0 , $username );
if ( ! current_user_can ( " publish_pages " )) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 401 , __ ( " Sorry, you can not add new pages. " )));
2007-01-24 02:16:08 +01:00
}
// Mark this as content for a page.
$args [ 3 ][ " post_type " ] = " page " ;
// Let mw_newPost do all of the heavy lifting.
return ( $this -> mw_newPost ( $args ));
}
/**
2008-09-22 07:15:41 +02:00
* Delete page .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return bool True , if success .
2007-01-24 02:16:08 +01:00
*/
function wp_deletePage ( $args ) {
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_id = ( int ) $args [ 0 ];
2007-01-24 02:16:08 +01:00
$username = $args [ 1 ];
$password = $args [ 2 ];
2007-03-23 01:59:21 +01:00
$page_id = ( int ) $args [ 3 ];
2007-01-24 02:16:08 +01:00
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.deletePage' );
2007-12-23 02:35:44 +01:00
2007-01-24 02:16:08 +01:00
// Get the current page based on the page_id and
// make sure it is a page and not a post.
$actual_page = wp_get_single_post ( $page_id , ARRAY_A );
if (
! $actual_page
|| ( $actual_page [ " post_type " ] != " page " )
) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 404 , __ ( " Sorry, no such page. " )));
2007-01-24 02:16:08 +01:00
}
// Set the user context and make sure they can delete pages.
set_current_user ( 0 , $username );
if ( ! current_user_can ( " delete_page " , $page_id )) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 401 , __ ( " Sorry, you do not have the right to delete this page. " )));
2007-01-24 02:16:08 +01:00
}
// Attempt to delete the page.
$result = wp_delete_post ( $page_id );
if ( ! $result ) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 500 , __ ( " Failed to delete the page. " )));
2007-01-24 02:16:08 +01:00
}
return ( true );
}
/**
2008-09-22 07:15:41 +02:00
* Edit page .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return unknown
2007-01-24 02:16:08 +01:00
*/
function wp_editPage ( $args ) {
2007-02-12 20:20:31 +01:00
// Items not escaped here will be escaped in editPost.
2007-03-23 01:59:21 +01:00
$blog_id = ( int ) $args [ 0 ];
2007-04-03 09:11:13 +02:00
$page_id = ( int ) $this -> escape ( $args [ 1 ]);
2007-02-12 20:20:31 +01:00
$username = $this -> escape ( $args [ 2 ]);
$password = $this -> escape ( $args [ 3 ]);
2007-01-24 02:16:08 +01:00
$content = $args [ 4 ];
$publish = $args [ 5 ];
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.editPage' );
2007-12-23 02:35:44 +01:00
2007-01-24 02:16:08 +01:00
// Get the page data and make sure it is a page.
$actual_page = wp_get_single_post ( $page_id , ARRAY_A );
if (
! $actual_page
|| ( $actual_page [ " post_type " ] != " page " )
) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 404 , __ ( " Sorry, no such page. " )));
2007-01-24 02:16:08 +01:00
}
// Set the user context and make sure they are allowed to edit pages.
set_current_user ( 0 , $username );
if ( ! current_user_can ( " edit_page " , $page_id )) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 401 , __ ( " Sorry, you do not have the right to edit this page. " )));
2007-01-24 02:16:08 +01:00
}
// Mark this as content for a page.
$content [ " post_type " ] = " page " ;
// Arrange args in the way mw_editPost understands.
$args = array (
$page_id ,
$username ,
$password ,
$content ,
$publish
);
// Let mw_editPost do all of the heavy lifting.
return ( $this -> mw_editPost ( $args ));
}
/**
2008-09-22 07:15:41 +02:00
* Retrieve page list .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return unknown
2007-01-24 02:16:08 +01:00
*/
function wp_getPageList ( $args ) {
global $wpdb ;
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_id = ( int ) $args [ 0 ];
2007-01-24 02:16:08 +01:00
$username = $args [ 1 ];
$password = $args [ 2 ];
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'edit_pages' ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit pages.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.getPageList' );
2007-12-23 02:35:44 +01:00
2007-01-24 02:16:08 +01:00
// Get list of pages ids and titles
$page_list = $wpdb -> get_results ( "
SELECT ID page_id ,
2007-01-26 21:05:53 +01:00
post_title page_title ,
2007-02-22 02:42:21 +01:00
post_parent page_parent_id ,
2007-08-17 05:18:58 +02:00
post_date_gmt ,
post_date
2007-01-24 02:16:08 +01:00
FROM { $wpdb -> posts }
WHERE post_type = 'page'
ORDER BY ID
" );
2007-02-22 02:42:21 +01:00
// The date needs to be formated properly.
$num_pages = count ( $page_list );
for ( $i = 0 ; $i < $num_pages ; $i ++ ) {
2007-08-17 05:18:58 +02:00
$post_date = mysql2date ( " Ymd \T H:i:s " , $page_list [ $i ] -> post_date );
$post_date_gmt = mysql2date ( " Ymd \T H:i:s " , $page_list [ $i ] -> post_date_gmt );
2007-02-22 02:42:21 +01:00
$page_list [ $i ] -> dateCreated = new IXR_Date ( $post_date );
2007-08-17 05:18:58 +02:00
$page_list [ $i ] -> date_created_gmt = new IXR_Date ( $post_date_gmt );
2007-02-22 02:42:21 +01:00
2007-04-22 05:07:34 +02:00
unset ( $page_list [ $i ] -> post_date_gmt );
2007-08-17 05:18:58 +02:00
unset ( $page_list [ $i ] -> post_date );
2007-02-22 02:42:21 +01:00
}
2007-01-24 02:16:08 +01:00
return ( $page_list );
}
/**
2008-09-22 07:15:41 +02:00
* Retrieve authors list .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return array
2007-01-24 02:16:08 +01:00
*/
function wp_getAuthors ( $args ) {
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_id = ( int ) $args [ 0 ];
2007-01-24 02:16:08 +01:00
$username = $args [ 1 ];
$password = $args [ 2 ];
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-26 20:54:35 +01:00
set_current_user ( 0 , $username );
if ( ! current_user_can ( " edit_posts " )) {
return ( new IXR_Error ( 401 , __ ( " Sorry, you can not edit posts on this blog. " )));
2008-09-22 07:15:41 +02:00
}
2007-12-26 20:54:35 +01:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.getAuthors' );
2007-12-23 02:35:44 +01:00
2007-12-26 20:54:35 +01:00
$authors = array ();
foreach ( ( array ) get_users_of_blog () as $row ) {
$authors [] = array (
" user_id " => $row -> user_id ,
" user_login " => $row -> user_login ,
" display_name " => $row -> display_name
);
}
return ( $authors );
2007-01-24 02:16:08 +01:00
}
2008-10-14 01:54:21 +02:00
/**
* Get list of all tags
*
* @ since 2.7
*
* @ param array $args Method parameters .
* @ return array
*/
function wp_getTags ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
if ( ! $this -> login_pass_ok ( $username , $password ) ) {
return $this -> error ;
}
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'edit_posts' ) ) {
return new IXR_Error ( 401 , __ ( 'Sorry, you must be able to edit posts on this blog in order to view tags.' ) );
}
do_action ( 'xmlrpc_call' , 'wp.getKeywords' );
$tags = array ( );
if ( $all_tags = get_tags ( ) ) {
foreach ( ( array ) $all_tags as $tag ) {
$struct [ 'tag_id' ] = $tag -> term_id ;
$struct [ 'name' ] = $tag -> name ;
$struct [ 'count' ] = $tag -> count ;
$struct [ 'slug' ] = $tag -> slug ;
$struct [ 'html_url' ] = wp_specialchars ( get_tag_link ( $tag -> term_id ) );
$struct [ 'rss_url' ] = wp_specialchars ( get_tag_feed_link ( $tag -> term_id ) );
$tags [] = $struct ;
}
}
return $tags ;
}
2007-01-24 02:16:08 +01:00
/**
2008-09-22 07:15:41 +02:00
* Create new category .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return int Category ID .
2007-01-24 02:16:08 +01:00
*/
function wp_newCategory ( $args ) {
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_id = ( int ) $args [ 0 ];
2007-01-24 02:16:08 +01:00
$username = $args [ 1 ];
$password = $args [ 2 ];
$category = $args [ 3 ];
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.newCategory' );
2007-12-23 02:35:44 +01:00
2007-01-24 02:16:08 +01:00
// Set the user context and make sure they are
// allowed to add a category.
set_current_user ( 0 , $username );
2007-12-19 21:33:27 +01:00
if ( ! current_user_can ( " manage_categories " )) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 401 , __ ( " Sorry, you do not have the right to add a category. " )));
2007-01-24 02:16:08 +01:00
}
// If no slug was provided make it empty so that
// WordPress will generate one.
if ( empty ( $category [ " slug " ])) {
$category [ " slug " ] = " " ;
}
// If no parent_id was provided make it empty
// so that it will be a top level page (no parent).
2007-02-22 16:30:47 +01:00
if ( ! isset ( $category [ " parent_id " ]) )
2007-01-24 02:16:08 +01:00
$category [ " parent_id " ] = " " ;
// If no description was provided make it empty.
if ( empty ( $category [ " description " ])) {
$category [ " description " ] = " " ;
}
2007-06-14 04:25:30 +02:00
2007-01-24 02:16:08 +01:00
$new_category = array (
" cat_name " => $category [ " name " ],
" category_nicename " => $category [ " slug " ],
" category_parent " => $category [ " parent_id " ],
" category_description " => $category [ " description " ]
);
2007-03-23 03:05:29 +01:00
$cat_id = wp_insert_category ( $new_category );
2007-01-24 02:16:08 +01:00
if ( ! $cat_id ) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 500 , __ ( " Sorry, the new category failed. " )));
2007-01-24 02:16:08 +01:00
}
return ( $cat_id );
}
2007-12-19 21:33:27 +01:00
/**
2008-09-22 07:15:41 +02:00
* Remove category .
*
* @ since 2.5 . 0
*
* @ param array $args Method parameters .
* @ return mixed See { @ link wp_delete_category ()} for return info .
2007-12-19 21:33:27 +01:00
*/
function wp_deleteCategory ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$category_id = ( int ) $args [ 3 ];
if ( ! $this -> login_pass_ok ( $username , $password ) ) {
return $this -> error ;
}
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.deleteCategory' );
2007-12-23 02:35:44 +01:00
2007-12-19 21:33:27 +01:00
set_current_user ( 0 , $username );
if ( ! current_user_can ( " manage_categories " ) ) {
2008-02-25 20:13:21 +01:00
return new IXR_Error ( 401 , __ ( " Sorry, you do not have the right to delete a category. " ) );
2007-12-19 21:33:27 +01:00
}
return wp_delete_category ( $category_id );
}
2007-01-24 02:16:08 +01:00
/**
2008-09-22 07:15:41 +02:00
* Retrieve category list .
*
* @ since 2.2 . 0
*
* @ param array $args Method parameters .
* @ return array
2007-01-24 02:16:08 +01:00
*/
function wp_suggestCategories ( $args ) {
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_id = ( int ) $args [ 0 ];
2007-01-24 02:16:08 +01:00
$username = $args [ 1 ];
$password = $args [ 2 ];
$category = $args [ 3 ];
2007-05-28 07:12:56 +02:00
$max_results = ( int ) $args [ 4 ];
2007-01-24 02:16:08 +01:00
if ( ! $this -> login_pass_ok ( $username , $password )) {
return ( $this -> error );
}
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $username );
2008-02-05 07:47:27 +01:00
if ( ! current_user_can ( 'edit_posts' ) )
2008-01-18 08:52:15 +01:00
return new IXR_Error ( 401 , __ ( 'Sorry, you must be able to edit posts to this blog in order to view categories.' ) );
2007-12-27 23:14:27 +01:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'wp.suggestCategories' );
2007-12-23 02:35:44 +01:00
2007-12-19 21:30:44 +01:00
$category_suggestions = array ();
2007-07-17 04:02:52 +02:00
$args = array ( 'get' => 'all' , 'number' => $max_results , 'name__like' => $category );
2007-12-19 21:30:44 +01:00
foreach ( ( array ) get_categories ( $args ) as $cat ) {
$category_suggestions [] = array (
" category_id " => $cat -> cat_ID ,
" category_name " => $cat -> cat_name
);
}
2007-01-24 02:16:08 +01:00
return ( $category_suggestions );
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve comment .
*
* @ since 2.7 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2008-08-05 00:29:37 +02:00
function wp_getComment ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$comment_id = ( int ) $args [ 3 ];
if ( ! $this -> login_pass_ok ( $username , $password ) )
return $this -> error ;
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'moderate_comments' ) )
return new IXR_Error ( 403 , __ ( 'You are not allowed to moderate comments on this blog.' ) );
do_action ( 'xmlrpc_call' , 'wp.getComment' );
if ( ! $comment = get_comment ( $comment_id ) )
return new IXR_Error ( 404 , __ ( 'Invalid comment ID.' ) );
// Format page date.
$comment_date = mysql2date ( " Ymd \T H:i:s " , $comment -> comment_date );
$comment_date_gmt = mysql2date ( " Ymd \T H:i:s " , $comment -> comment_date_gmt );
if ( 0 == $comment -> comment_approved )
$comment_status = 'hold' ;
else if ( 'spam' == $comment -> comment_approved )
$comment_status = 'spam' ;
2008-09-25 21:56:36 +02:00
else if ( 1 == $comment -> comment_approved )
2008-08-05 00:29:37 +02:00
$comment_status = 'approve' ;
2008-09-25 21:56:36 +02:00
else
$comment_status = $comment -> comment_approved ;
2008-08-05 00:29:37 +02:00
$link = get_comment_link ( $comment );
$comment_struct = array (
" date_created_gmt " => new IXR_Date ( $comment_date_gmt ),
" user_id " => $comment -> user_id ,
" comment_id " => $comment -> comment_ID ,
" parent " => $comment -> comment_parent ,
" status " => $comment_status ,
" content " => $comment -> comment_content ,
" link " => $link ,
" post_id " => $comment -> comment_post_ID ,
" post_title " => get_the_title ( $comment -> comment_post_ID ),
2008-08-21 07:19:16 +02:00
" author " => $comment -> comment_author ,
2008-08-05 00:29:37 +02:00
" author_url " => $comment -> comment_author_url ,
" author_email " => $comment -> comment_author_email ,
" author_ip " => $comment -> comment_author_IP ,
2008-12-04 21:31:40 +01:00
" type " => $comment -> comment_type ,
2008-08-05 00:29:37 +02:00
);
return $comment_struct ;
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve comments .
*
* @ since 2.7 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2008-08-05 00:29:37 +02:00
function wp_getComments ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$struct = $args [ 3 ];
if ( ! $this -> login_pass_ok ( $username , $password ) )
return ( $this -> error );
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'moderate_comments' ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit comments.' ) );
do_action ( 'xmlrpc_call' , 'wp.getComments' );
if ( isset ( $struct [ 'status' ]) )
$status = $struct [ 'status' ];
else
$status = '' ;
$post_id = '' ;
if ( isset ( $struct [ 'post_id' ]) )
$post_id = absint ( $struct [ 'post_id' ]);
$offset = 0 ;
if ( isset ( $struct [ 'offset' ]) )
$offset = absint ( $struct [ 'offset' ]);
$number = 10 ;
if ( isset ( $struct [ 'number' ]) )
$number = absint ( $struct [ 'number' ]);
$comments = get_comments ( array ( 'status' => $status , 'post_id' => $post_id , 'offset' => $offset , 'number' => $number ) );
$num_comments = count ( $comments );
if ( ! $num_comments )
return array ();
$comments_struct = array ();
for ( $i = 0 ; $i < $num_comments ; $i ++ ) {
$comment = wp_xmlrpc_server :: wp_getComment ( array (
$blog_id , $username , $password , $comments [ $i ] -> comment_ID ,
));
$comments_struct [] = $comment ;
}
return $comments_struct ;
}
2008-09-22 07:15:41 +02:00
/**
* Remove comment .
*
* @ since 2.7 . 0
*
* @ param array $args Method parameters .
* @ return mixed { @ link wp_delete_comment ()}
*/
2008-08-05 00:29:37 +02:00
function wp_deleteComment ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$comment_ID = ( int ) $args [ 3 ];
if ( ! $this -> login_pass_ok ( $username , $password ) )
return $this -> error ;
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'moderate_comments' ) )
return new IXR_Error ( 403 , __ ( 'You are not allowed to moderate comments on this blog.' ) );
do_action ( 'xmlrpc_call' , 'wp.deleteComment' );
if ( ! get_comment ( $comment_ID ) )
return new IXR_Error ( 404 , __ ( 'Invalid comment ID.' ) );
return wp_delete_comment ( $comment_ID );
}
2008-09-22 07:15:41 +02:00
/**
* Edit comment .
*
* @ since 2.7 . 0
*
* @ param array $args Method parameters .
* @ return bool True , on success .
*/
2008-08-05 00:29:37 +02:00
function wp_editComment ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$comment_ID = ( int ) $args [ 3 ];
$content_struct = $args [ 4 ];
if ( ! $this -> login_pass_ok ( $username , $password ) )
return $this -> error ;
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'moderate_comments' ) )
return new IXR_Error ( 403 , __ ( 'You are not allowed to moderate comments on this blog.' ) );
do_action ( 'xmlrpc_call' , 'wp.editComment' );
if ( ! get_comment ( $comment_ID ) )
return new IXR_Error ( 404 , __ ( 'Invalid comment ID.' ) );
if ( isset ( $content_struct [ 'status' ]) ) {
$statuses = get_comment_statuses ();
$statuses = array_keys ( $statuses );
if ( ! in_array ( $content_struct [ 'status' ], $statuses ) )
return new IXR_Error ( 401 , __ ( 'Invalid comment status.' ) );
$comment_approved = $content_struct [ 'status' ];
}
// Do some timestamp voodoo
if ( ! empty ( $content_struct [ 'date_created_gmt' ] ) ) {
$dateCreated = str_replace ( 'Z' , '' , $content_struct [ 'date_created_gmt' ] -> getIso () ) . 'Z' ; // We know this is supposed to be GMT, so we're going to slap that Z on there by force
$comment_date = get_date_from_gmt ( iso8601_to_datetime ( $dateCreated ));
$comment_date_gmt = iso8601_to_datetime ( $dateCreated , GMT );
}
if ( isset ( $content_struct [ 'content' ]) )
$comment_content = $content_struct [ 'content' ];
if ( isset ( $content_struct [ 'author' ]) )
$comment_author = $content_struct [ 'author' ];
if ( isset ( $content_struct [ 'author_url' ]) )
$comment_author_url = $content_struct [ 'author_url' ];
if ( isset ( $content_struct [ 'author_email' ]) )
$comment_author_email = $content_struct [ 'author_email' ];
// We've got all the data -- post it:
$comment = compact ( 'comment_ID' , 'comment_content' , 'comment_approved' , 'comment_date' , 'comment_date_gmt' , 'comment_author' , 'comment_author_email' , 'comment_author_url' );
2008-08-09 07:36:14 +02:00
2008-08-05 00:29:37 +02:00
$result = wp_update_comment ( $comment );
if ( is_wp_error ( $result ) )
return new IXR_Error ( 500 , $result -> get_error_message ());
if ( ! $result )
return new IXR_Error ( 500 , __ ( 'Sorry, the comment could not be edited. Something wrong happened.' ));
return true ;
}
2008-09-22 07:15:41 +02:00
/**
* Create new comment .
*
* @ since 2.7 . 0
*
* @ param array $args Method parameters .
* @ return mixed { @ link wp_new_comment ()}
*/
2008-08-05 00:29:37 +02:00
function wp_newComment ( $args ) {
global $wpdb ;
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$post = $args [ 3 ];
$content_struct = $args [ 4 ];
$allow_anon = apply_filters ( 'xmlrpc_allow_anonymous_comments' , false );
if ( ! $this -> login_pass_ok ( $username , $password ) ) {
$logged_in = false ;
if ( $allow_anon && get_option ( 'comment_registration' ) )
return new IXR_Error ( 403 , __ ( 'You must be registered to comment' ) );
else if ( ! $allow_anon )
return $this -> error ;
} else {
$logged_in = true ;
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'moderate_comments' ) )
return new IXR_Error ( 403 , __ ( 'You are not allowed to moderate comments on this blog.' ) );
}
if ( is_numeric ( $post ) )
$post_id = absint ( $post );
else
$post_id = url_to_postid ( $post );
if ( ! $post_id )
return new IXR_Error ( 404 , __ ( 'Invalid post ID.' ) );
if ( ! get_post ( $post_id ) )
return new IXR_Error ( 404 , __ ( 'Invalid post ID.' ) );
$comment [ 'comment_post_ID' ] = $post_id ;
if ( $logged_in ) {
$user = wp_get_current_user ();
$comment [ 'comment_author' ] = $wpdb -> escape ( $user -> display_name );
$comment [ 'comment_author_email' ] = $wpdb -> escape ( $user -> user_email );
$comment [ 'comment_author_url' ] = $wpdb -> escape ( $user -> user_url );
$comment [ 'user_ID' ] = $user -> ID ;
} else {
$comment [ 'comment_author' ] = '' ;
if ( isset ( $content_struct [ 'author' ]) )
$comment [ 'comment_author' ] = $content_struct [ 'author' ];
$comment [ 'comment_author_email' ] = '' ;
if ( isset ( $content_struct [ 'author' ]) )
$comment [ 'comment_author_email' ] = $content_struct [ 'author_email' ];
$comment [ 'comment_author_url' ] = '' ;
if ( isset ( $content_struct [ 'author' ]) )
$comment [ 'comment_author_url' ] = $content_struct [ 'author_url' ];
$comment [ 'user_ID' ] = 0 ;
if ( get_option ( 'require_name_email' ) ) {
if ( 6 > strlen ( $comment [ 'comment_author_email' ]) || '' == $comment [ 'comment_author' ] )
return new IXR_Error ( 403 , __ ( 'Comment author name and email are required' ) );
elseif ( ! is_email ( $comment [ 'comment_author_email' ]) )
return new IXR_Error ( 403 , __ ( 'A valid email address is required' ) );
}
}
2008-08-24 08:56:22 +02:00
$comment [ 'comment_parent' ] = isset ( $content_struct [ 'comment_parent' ]) ? absint ( $content_struct [ 'comment_parent' ]) : 0 ;
2008-08-05 00:29:37 +02:00
$comment [ 'comment_content' ] = $content_struct [ 'content' ];
do_action ( 'xmlrpc_call' , 'wp.newComment' );
2008-08-09 07:36:14 +02:00
2008-08-05 00:29:37 +02:00
return wp_new_comment ( $comment );
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve all of the comment status .
*
* @ since 2.7 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2008-08-05 00:29:37 +02:00
function wp_getCommentStatusList ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
if ( ! $this -> login_pass_ok ( $username , $password ) )
return $this -> error ;
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'moderate_comments' ) )
return new IXR_Error ( 403 , __ ( 'You are not allowed access to details about this blog.' ) );
do_action ( 'xmlrpc_call' , 'wp.getCommentStatusList' );
return get_comment_statuses ( );
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve comment count .
*
* @ since 2.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2008-01-01 19:40:39 +01:00
function wp_getCommentCount ( $args ) {
2008-02-05 07:47:27 +01:00
$this -> escape ( $args );
2008-01-01 19:40:39 +01:00
2008-02-05 07:47:27 +01:00
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$post_id = ( int ) $args [ 3 ];
2008-01-01 19:40:39 +01:00
2008-02-05 07:47:27 +01:00
if ( ! $this -> login_pass_ok ( $username , $password ) ) {
2008-06-27 00:39:57 +02:00
return $this -> error ;
2008-02-05 07:47:27 +01:00
}
2008-01-01 19:40:39 +01:00
2008-02-05 07:47:27 +01:00
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'edit_posts' ) ) {
2008-02-25 19:34:45 +01:00
return new IXR_Error ( 403 , __ ( 'You are not allowed access to details about comments.' ) );
2008-02-05 07:47:27 +01:00
}
2008-01-01 19:40:39 +01:00
2008-01-18 08:52:15 +01:00
do_action ( 'xmlrpc_call' , 'wp.getCommentCount' );
2008-05-09 18:02:44 +02:00
$count = wp_count_comments ( $post_id );
return array (
" approved " => $count -> approved ,
" awaiting_moderation " => $count -> moderated ,
" spam " => $count -> spam ,
" total_comments " => $count -> total_comments
);
2008-01-01 19:40:39 +01:00
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve post statuses .
*
* @ since 2.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2008-01-10 22:46:25 +01:00
function wp_getPostStatusList ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
if ( ! $this -> login_pass_ok ( $username , $password ) ) {
2008-06-27 00:39:57 +02:00
return $this -> error ;
2008-01-10 22:46:25 +01:00
}
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'edit_posts' ) ) {
return new IXR_Error ( 403 , __ ( 'You are not allowed access to details about this blog.' ) );
}
2008-01-18 08:52:15 +01:00
do_action ( 'xmlrpc_call' , 'wp.getPostStatusList' );
2008-01-10 22:46:25 +01:00
return get_post_statuses ( );
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve page statuses .
*
* @ since 2.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2008-01-10 22:46:25 +01:00
function wp_getPageStatusList ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
if ( ! $this -> login_pass_ok ( $username , $password ) ) {
2008-06-27 00:39:57 +02:00
return $this -> error ;
2008-01-10 22:46:25 +01:00
}
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'edit_posts' ) ) {
2008-01-22 18:13:43 +01:00
return new IXR_Error ( 403 , __ ( 'You are not allowed access to details about this blog.' ) );
2008-01-10 22:46:25 +01:00
}
2008-01-18 08:52:15 +01:00
do_action ( 'xmlrpc_call' , 'wp.getPageStatusList' );
2008-01-10 22:46:25 +01:00
return get_page_statuses ( );
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve page templates .
*
* @ since 2.6 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2008-05-06 18:49:42 +02:00
function wp_getPageTemplates ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
if ( ! $this -> login_pass_ok ( $username , $password ) ) {
2008-06-27 00:39:57 +02:00
return $this -> error ;
2008-05-06 18:49:42 +02:00
}
set_current_user ( 0 , $username );
if ( ! current_user_can ( 'edit_pages' ) ) {
return new IXR_Error ( 403 , __ ( 'You are not allowed access to details about this blog.' ) );
}
$templates = get_page_templates ( );
$templates [ 'Default' ] = 'default' ;
return $templates ;
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve blog options .
*
* @ since 2.6 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2008-06-17 22:41:13 +02:00
function wp_getOptions ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$options = ( array ) $args [ 3 ];
if ( ! $this -> login_pass_ok ( $username , $password ) )
2008-06-27 00:39:57 +02:00
return $this -> error ;
2008-06-17 22:41:13 +02:00
$user = set_current_user ( 0 , $username );
// If no specific options where asked for, return all of them
if ( count ( $options ) == 0 ) {
$options = array_keys ( $this -> blog_options );
}
return $this -> _getOptions ( $options );
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve blog options value from list .
*
* @ since 2.6 . 0
*
* @ param array $options Options to retrieve .
* @ return array
*/
2008-06-17 22:41:13 +02:00
function _getOptions ( $options )
{
$data = array ( );
foreach ( $options as $option ) {
if ( array_key_exists ( $option , $this -> blog_options ) )
{
$data [ $option ] = $this -> blog_options [ $option ];
//Is the value static or dynamic?
if ( isset ( $data [ $option ][ 'option' ] ) ) {
$data [ $option ][ 'value' ] = get_option ( $data [ $option ][ 'option' ] );
unset ( $data [ $option ][ 'option' ]);
}
}
}
return $data ;
}
2008-09-22 07:15:41 +02:00
/**
* Update blog options .
*
* @ since 2.6 . 0
*
* @ param array $args Method parameters .
* @ return unknown
*/
2008-06-17 22:41:13 +02:00
function wp_setOptions ( $args ) {
$this -> escape ( $args );
$blog_id = ( int ) $args [ 0 ];
$username = $args [ 1 ];
$password = $args [ 2 ];
$options = ( array ) $args [ 3 ];
if ( ! $this -> login_pass_ok ( $username , $password ) )
2008-06-27 00:39:57 +02:00
return $this -> error ;
2008-06-17 22:41:13 +02:00
$user = set_current_user ( 0 , $username );
if ( ! current_user_can ( 'manage_options' ) )
return new IXR_Error ( 403 , __ ( 'You are not allowed to update options.' ) );
foreach ( $options as $o_name => $o_value ) {
$option_names [] = $o_name ;
if ( empty ( $o_value ) )
continue ;
if ( ! array_key_exists ( $o_name , $this -> blog_options ) )
continue ;
if ( $this -> blog_options [ $o_name ][ 'readonly' ] == true )
continue ;
update_option ( $this -> blog_options [ $o_name ][ 'option' ], $o_value );
}
//Now return the updated values
return $this -> _getOptions ( $option_names );
}
2008-01-10 22:46:25 +01:00
2008-09-22 07:15:41 +02:00
/* Blogger API functions .
2004-09-17 22:53:18 +02:00
* specs on http :// plant . blogger . com / api and http :// groups . yahoo . com / group / bloggerDev /
*/
2004-05-23 06:02:53 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve blogs that user owns .
*
* Will make more sense once we support multiple blogs .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function blogger_getUsersBlogs ( $args ) {
2004-05-23 06:02:53 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-27 01:39:28 +02:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2004-05-23 06:02:53 +02:00
2007-03-27 01:39:28 +02:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-05-23 06:02:53 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'blogger.getUsersBlogs' );
2007-12-23 02:35:44 +01:00
2007-03-27 01:39:28 +02:00
set_current_user ( 0 , $user_login );
2008-05-09 02:45:17 +02:00
$is_admin = current_user_can ( 'manage_options' );
2004-05-23 06:02:53 +02:00
2007-03-27 01:39:28 +02:00
$struct = array (
'isAdmin' => $is_admin ,
'url' => get_option ( 'home' ) . '/' ,
'blogid' => '1' ,
2008-06-12 23:41:18 +02:00
'blogName' => get_option ( 'blogname' ),
'xmlrpc' => get_option ( 'home' ) . '/xmlrpc.php' ,
2007-03-27 01:39:28 +02:00
);
2006-01-13 23:08:00 +01:00
2007-03-27 01:39:28 +02:00
return array ( $struct );
2004-05-23 06:02:53 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve user ' s data .
*
* Gives your client some info about you , so you don ' t have to .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function blogger_getUserInfo ( $args ) {
2004-05-23 06:02:53 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2006-11-19 08:56:05 +01:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2004-08-25 17:24:09 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-08-25 17:24:09 +02:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
2008-02-05 07:47:27 +01:00
if ( ! current_user_can ( 'edit_posts' ) )
2007-12-27 23:14:27 +01:00
return new IXR_Error ( 401 , __ ( 'Sorry, you do not have access to user data on this blog.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'blogger.getUserInfo' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$user_data = get_userdatabylogin ( $user_login );
2004-09-17 22:48:43 +02:00
2006-11-19 08:56:05 +01:00
$struct = array (
'nickname' => $user_data -> nickname ,
'userid' => $user_data -> ID ,
'url' => $user_data -> user_url ,
'lastname' => $user_data -> last_name ,
'firstname' => $user_data -> first_name
);
2004-09-17 22:48:43 +02:00
2006-11-19 08:56:05 +01:00
return $struct ;
2004-09-17 22:48:43 +02:00
}
2004-05-23 06:02:53 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function blogger_getPost ( $args ) {
2004-05-23 06:02:53 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$post_ID = ( int ) $args [ 1 ];
2006-11-19 08:56:05 +01:00
$user_login = $args [ 2 ];
$user_pass = $args [ 3 ];
2004-05-23 06:02:53 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-05-23 06:02:53 +02:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
2008-02-05 07:47:27 +01:00
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
2007-12-27 23:14:27 +01:00
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit this post.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'blogger.getPost' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$post_data = wp_get_single_post ( $post_ID , ARRAY_A );
2004-05-23 06:02:53 +02:00
2006-11-19 08:56:05 +01:00
$categories = implode ( ',' , wp_get_post_categories ( $post_ID ));
2004-05-23 06:02:53 +02:00
2006-11-19 08:56:05 +01:00
$content = '<title>' . stripslashes ( $post_data [ 'post_title' ]) . '</title>' ;
$content .= '<category>' . $categories . '</category>' ;
$content .= stripslashes ( $post_data [ 'post_content' ]);
2004-05-23 06:02:53 +02:00
2006-11-19 08:56:05 +01:00
$struct = array (
'userid' => $post_data [ 'post_author' ],
'dateCreated' => new IXR_Date ( mysql2date ( 'Ymd\TH:i:s' , $post_data [ 'post_date' ])),
'content' => $content ,
'postid' => $post_data [ 'ID' ]
);
2004-05-23 06:02:53 +02:00
2006-11-19 08:56:05 +01:00
return $struct ;
2004-05-23 06:02:53 +02:00
}
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve list of recent posts .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function blogger_getRecentPosts ( $args ) {
2004-05-23 17:46:43 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_ID = ( int ) $args [ 1 ]; /* though we don't use it yet */
2006-11-19 08:56:05 +01:00
$user_login = $args [ 2 ];
$user_pass = $args [ 3 ];
$num_posts = $args [ 4 ];
2004-05-23 17:46:43 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-05-23 17:46:43 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'blogger.getRecentPosts' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$posts_list = wp_get_recent_posts ( $num_posts );
2004-05-23 17:46:43 +02:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
2006-11-19 08:56:05 +01:00
if ( ! $posts_list ) {
2007-04-01 17:59:50 +02:00
$this -> error = new IXR_Error ( 500 , __ ( 'Either there are no posts, or something went wrong.' ));
2006-11-19 08:56:05 +01:00
return $this -> error ;
}
2004-05-23 17:46:43 +02:00
2006-11-19 08:56:05 +01:00
foreach ( $posts_list as $entry ) {
2007-12-27 23:14:27 +01:00
if ( ! current_user_can ( 'edit_post' , $entry [ 'ID' ] ) )
continue ;
2004-05-23 17:46:43 +02:00
2006-11-19 08:56:05 +01:00
$post_date = mysql2date ( 'Ymd\TH:i:s' , $entry [ 'post_date' ]);
$categories = implode ( ',' , wp_get_post_categories ( $entry [ 'ID' ]));
2004-08-25 17:24:09 +02:00
2006-11-19 08:56:05 +01:00
$content = '<title>' . stripslashes ( $entry [ 'post_title' ]) . '</title>' ;
$content .= '<category>' . $categories . '</category>' ;
$content .= stripslashes ( $entry [ 'post_content' ]);
2004-05-23 17:46:43 +02:00
2006-11-19 08:56:05 +01:00
$struct [] = array (
'userid' => $entry [ 'post_author' ],
'dateCreated' => new IXR_Date ( $post_date ),
'content' => $content ,
'postid' => $entry [ 'ID' ],
);
2004-05-23 17:46:43 +02:00
2006-11-19 08:56:05 +01:00
}
$recent_posts = array ();
for ( $j = 0 ; $j < count ( $struct ); $j ++ ) {
array_push ( $recent_posts , $struct [ $j ]);
}
2004-09-17 22:48:43 +02:00
2006-11-19 08:56:05 +01:00
return $recent_posts ;
2004-05-23 17:46:43 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve blog_filename content .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return string
*/
2004-09-17 22:53:18 +02:00
function blogger_getTemplate ( $args ) {
2004-05-23 17:46:43 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2008-09-22 07:15:41 +02:00
$blog_ID = ( int ) $args [ 1 ];
$user_login = $args [ 2 ];
$user_pass = $args [ 3 ];
$template = $args [ 4 ]; /* could be 'main' or 'archiveIndex', but we don't use it */
2004-05-23 17:46:43 +02:00
2008-09-22 07:15:41 +02:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-05-23 17:46:43 +02:00
2008-09-22 07:15:41 +02:00
do_action ( 'xmlrpc_call' , 'blogger.getTemplate' );
2007-12-23 02:35:44 +01:00
2008-09-22 07:15:41 +02:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_themes' ) ) {
return new IXR_Error ( 401 , __ ( 'Sorry, this user can not edit the template.' ));
}
2004-05-23 17:46:43 +02:00
2008-09-22 07:15:41 +02:00
/* warning: here we make the assumption that the blog's URL is on the same server */
$filename = get_option ( 'home' ) . '/' ;
$filename = preg_replace ( '#https?://.+?/#' , $_SERVER [ 'DOCUMENT_ROOT' ] . '/' , $filename );
2004-08-25 17:24:09 +02:00
2008-09-22 07:15:41 +02:00
$f = fopen ( $filename , 'r' );
$content = fread ( $f , filesize ( $filename ));
fclose ( $f );
2004-05-23 17:46:43 +02:00
2008-09-22 07:15:41 +02:00
/* so it is actually editable with a windows/mac client */
// FIXME: (or delete me) do we really want to cater to bad clients at the expense of good ones by BEEPing up their line breaks? commented. $content = str_replace("\n", "\r\n", $content);
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
return $content ;
2004-09-17 22:53:18 +02:00
}
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
/**
* Updates the content of blog_filename .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return bool True when done .
*/
2004-09-17 22:53:18 +02:00
function blogger_setTemplate ( $args ) {
2004-09-17 22:48:43 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-12-23 02:35:44 +01:00
$blog_ID = ( int ) $args [ 1 ];
$user_login = $args [ 2 ];
$user_pass = $args [ 3 ];
$content = $args [ 4 ];
$template = $args [ 5 ]; /* could be 'main' or 'archiveIndex', but we don't use it */
2004-05-23 17:46:43 +02:00
2007-12-23 02:35:44 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-05-23 18:42:23 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'blogger.setTemplate' );
2004-05-23 18:42:23 +02:00
2007-12-23 02:35:44 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_themes' ) ) {
return new IXR_Error ( 401 , __ ( 'Sorry, this user can not edit the template.' ));
}
2004-05-23 18:42:23 +02:00
2007-12-23 02:35:44 +01:00
/* warning: here we make the assumption that the blog's URL is on the same server */
$filename = get_option ( 'home' ) . '/' ;
$filename = preg_replace ( '#https?://.+?/#' , $_SERVER [ 'DOCUMENT_ROOT' ] . '/' , $filename );
if ( $f = fopen ( $filename , 'w+' )) {
fwrite ( $f , $content );
fclose ( $f );
} else {
return new IXR_Error ( 500 , __ ( 'Either the file is not writable, or something wrong happened. The file has not been updated.' ));
}
2004-05-23 18:42:23 +02:00
2007-12-23 02:35:44 +01:00
return true ;
2004-09-17 22:53:18 +02:00
}
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
/**
* Create new post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return int
*/
2004-09-17 22:53:18 +02:00
function blogger_newPost ( $args ) {
2004-09-17 22:48:43 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-12-06 20:49:33 +01:00
$blog_ID = ( int ) $args [ 1 ]; /* though we don't use it yet */
$user_login = $args [ 2 ];
$user_pass = $args [ 3 ];
$content = $args [ 4 ];
$publish = $args [ 5 ];
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2007-12-23 02:35:44 +01:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'blogger.newPost' );
2007-12-23 02:35:44 +01:00
2007-12-06 20:49:33 +01:00
$cap = ( $publish ) ? 'publish_posts' : 'edit_posts' ;
$user = set_current_user ( 0 , $user_login );
if ( ! current_user_can ( $cap ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you are not allowed to post on this blog.' ));
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_status = ( $publish ) ? 'publish' : 'draft' ;
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_author = $user -> ID ;
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_title = xmlrpc_getposttitle ( $content );
$post_category = xmlrpc_getpostcategory ( $content );
$post_content = xmlrpc_removepostdata ( $content );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_date = current_time ( 'mysql' );
$post_date_gmt = current_time ( 'mysql' , 1 );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_data = compact ( 'blog_ID' , 'post_author' , 'post_date' , 'post_date_gmt' , 'post_content' , 'post_title' , 'post_category' , 'post_status' );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_ID = wp_insert_post ( $post_data );
if ( is_wp_error ( $post_ID ) )
return new IXR_Error ( 500 , $post_ID -> get_error_message ());
if ( ! $post_ID )
return new IXR_Error ( 500 , __ ( 'Sorry, your entry could not be posted. Something wrong happened.' ));
$this -> attach_uploads ( $post_ID , $post_content );
logIO ( 'O' , " Posted ! ID: $post_ID " );
return $post_ID ;
2004-05-23 18:42:23 +02:00
}
2004-08-25 17:24:09 +02:00
2008-09-22 07:15:41 +02:00
/**
* Edit a post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return bool true when done .
*/
2004-09-17 22:53:18 +02:00
function blogger_editPost ( $args ) {
2004-08-25 17:24:09 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_ID = ( int ) $args [ 1 ];
$user_login = $args [ 2 ];
$user_pass = $args [ 3 ];
$content = $args [ 4 ];
$publish = $args [ 5 ];
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2007-12-23 02:35:44 +01:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'blogger.editPost' );
2007-12-23 02:35:44 +01:00
2007-12-06 20:49:33 +01:00
$actual_post = wp_get_single_post ( $post_ID , ARRAY_A );
2008-02-05 07:47:27 +01:00
2008-11-18 01:53:30 +01:00
if ( ! $actual_post || $actual_post [ 'post_type' ] != 'post' ) {
2007-12-06 20:49:33 +01:00
return new IXR_Error ( 404 , __ ( 'Sorry, no such post.' ));
}
2008-02-05 07:47:27 +01:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $actual_post );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you do not have the right to edit this post.' ));
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
extract ( $actual_post , EXTR_SKIP );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ( 'publish' == $post_status ) && ! current_user_can ( 'publish_posts' ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you do not have the right to publish this post.' ));
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_title = xmlrpc_getposttitle ( $content );
$post_category = xmlrpc_getpostcategory ( $content );
$post_content = xmlrpc_removepostdata ( $content );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$postdata = compact ( 'ID' , 'post_content' , 'post_title' , 'post_category' , 'post_status' , 'post_excerpt' );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$result = wp_update_post ( $postdata );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $result ) {
return new IXR_Error ( 500 , __ ( 'For some strange yet very annoying reason, this post could not be edited.' ));
}
$this -> attach_uploads ( $ID , $post_content );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
return true ;
2004-08-25 17:24:09 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Remove a post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return bool True when post is deleted .
*/
2004-09-17 22:53:18 +02:00
function blogger_deletePost ( $args ) {
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_ID = ( int ) $args [ 1 ];
$user_login = $args [ 2 ];
$user_pass = $args [ 3 ];
$publish = $args [ 4 ];
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2007-12-23 02:35:44 +01:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'blogger.deletePost' );
2007-12-23 02:35:44 +01:00
2007-12-06 20:49:33 +01:00
$actual_post = wp_get_single_post ( $post_ID , ARRAY_A );
2008-02-05 07:47:27 +01:00
2008-11-18 01:53:30 +01:00
if ( ! $actual_post || $actual_post [ 'post_type' ] != 'post' ) {
2007-12-06 20:49:33 +01:00
return new IXR_Error ( 404 , __ ( 'Sorry, no such post.' ));
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you do not have the right to delete this post.' ));
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$result = wp_delete_post ( $post_ID );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $result ) {
return new IXR_Error ( 500 , __ ( 'For some strange yet very annoying reason, this post could not be deleted.' ));
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
return true ;
2004-09-17 22:48:43 +02:00
}
2004-08-25 18:28:20 +02:00
2004-09-17 22:53:18 +02:00
/* MetaWeblog API functions
* specs on wherever Dave Winer wants them to be
*/
2004-09-14 19:20:22 +02:00
2008-09-22 07:15:41 +02:00
/**
* Create a new post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return int
*/
2004-09-17 22:53:18 +02:00
function mw_newPost ( $args ) {
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-12-06 20:49:33 +01:00
$blog_ID = ( int ) $args [ 0 ]; // we will support this in the near future
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
$content_struct = $args [ 3 ];
$publish = $args [ 4 ];
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2008-02-04 19:35:05 +01:00
$user = set_current_user ( 0 , $user_login );
2007-12-23 02:35:44 +01:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'metaWeblog.newPost' );
2007-12-23 02:35:44 +01:00
2008-02-04 19:35:05 +01:00
$cap = ( $publish ) ? 'publish_posts' : 'edit_posts' ;
$error_message = __ ( 'Sorry, you are not allowed to publish posts on this blog.' );
$post_type = 'post' ;
2008-05-06 18:49:42 +02:00
$page_template = '' ;
2008-02-04 19:35:05 +01:00
if ( ! empty ( $content_struct [ 'post_type' ] ) ) {
if ( $content_struct [ 'post_type' ] == 'page' ) {
$cap = ( $publish ) ? 'publish_pages' : 'edit_pages' ;
$error_message = __ ( 'Sorry, you are not allowed to publish pages on this blog.' );
$post_type = 'page' ;
2008-05-06 18:49:42 +02:00
if ( ! empty ( $content_struct [ 'wp_page_template' ] ) )
$page_template = $content_struct [ 'wp_page_template' ];
2008-02-04 19:35:05 +01:00
}
2008-02-13 18:54:08 +01:00
elseif ( $content_struct [ 'post_type' ] == 'post' ) {
2008-02-04 19:35:05 +01:00
// This is the default, no changes needed
}
else {
// No other post_type values are allowed here
return new IXR_Error ( 401 , __ ( 'Invalid post type.' ) );
}
}
2004-08-25 18:28:20 +02:00
2008-02-04 19:35:05 +01:00
if ( ! current_user_can ( $cap ) ) {
return new IXR_Error ( 401 , $error_message );
2007-01-24 02:16:08 +01:00
}
// Let WordPress generate the post_name (slug) unless
// one has been provided.
$post_name = " " ;
2007-04-18 00:00:00 +02:00
if ( isset ( $content_struct [ " wp_slug " ])) {
2007-01-24 02:16:08 +01:00
$post_name = $content_struct [ " wp_slug " ];
}
// Only use a password if one was given.
2007-04-18 00:00:00 +02:00
if ( isset ( $content_struct [ " wp_password " ])) {
2007-01-24 02:16:08 +01:00
$post_password = $content_struct [ " wp_password " ];
}
// Only set a post parent if one was provided.
2007-02-22 02:42:21 +01:00
if ( isset ( $content_struct [ " wp_page_parent_id " ])) {
2007-01-24 02:16:08 +01:00
$post_parent = $content_struct [ " wp_page_parent_id " ];
}
// Only set the menu_order if it was provided.
2007-04-18 00:00:00 +02:00
if ( isset ( $content_struct [ " wp_page_order " ])) {
2007-01-24 02:16:08 +01:00
$menu_order = $content_struct [ " wp_page_order " ];
}
2007-12-06 20:49:33 +01:00
$post_author = $user -> ID ;
2004-08-25 18:28:20 +02:00
2007-02-01 01:34:33 +01:00
// If an author id was provided then use it instead.
2007-04-18 00:00:00 +02:00
if (
isset ( $content_struct [ " wp_author_id " ])
&& ( $user -> ID != $content_struct [ " wp_author_id " ])
) {
2007-02-02 08:43:59 +01:00
switch ( $post_type ) {
case " post " :
if ( ! current_user_can ( " edit_others_posts " )) {
2007-05-25 17:33:47 +02:00
return ( new IXR_Error ( 401 , __ ( " You are not allowed to post as this user " )));
2007-02-02 08:43:59 +01:00
}
break ;
case " page " :
if ( ! current_user_can ( " edit_others_pages " )) {
2007-05-25 17:33:47 +02:00
return ( new IXR_Error ( 401 , __ ( " You are not allowed to create pages as this user " )));
2007-02-02 08:43:59 +01:00
}
break ;
default :
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 401 , __ ( " Invalid post type. " )));
2007-02-02 08:43:59 +01:00
break ;
}
2007-02-01 01:34:33 +01:00
$post_author = $content_struct [ " wp_author_id " ];
}
2007-12-06 20:49:33 +01:00
$post_title = $content_struct [ 'title' ];
$post_content = apply_filters ( 'content_save_pre' , $content_struct [ 'description' ] );
2008-01-10 22:46:25 +01:00
2007-12-06 20:49:33 +01:00
$post_status = $publish ? 'publish' : 'draft' ;
2008-01-10 23:37:15 +01:00
if ( isset ( $content_struct [ " { $post_type } _status " ] ) ) {
switch ( $content_struct [ " { $post_type } _status " ] ) {
2008-01-10 22:46:25 +01:00
case 'draft' :
case 'private' :
case 'publish' :
2008-01-10 23:37:15 +01:00
$post_status = $content_struct [ " { $post_type } _status " ];
2008-01-10 22:46:25 +01:00
break ;
case 'pending' :
// Pending is only valid for posts, not pages.
if ( $post_type === 'post' ) {
2008-01-10 23:37:15 +01:00
$post_status = $content_struct [ " { $post_type } _status " ];
2008-01-10 22:46:25 +01:00
}
break ;
default :
$post_status = $publish ? 'publish' : 'draft' ;
break ;
}
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_excerpt = $content_struct [ 'mt_excerpt' ];
$post_more = $content_struct [ 'mt_text_more' ];
2004-08-25 18:28:20 +02:00
2007-08-30 01:01:48 +02:00
$tags_input = $content_struct [ 'mt_keywords' ];
2007-04-18 00:00:00 +02:00
if ( isset ( $content_struct [ " mt_allow_comments " ])) {
2007-06-19 21:12:24 +02:00
if ( ! is_numeric ( $content_struct [ " mt_allow_comments " ])) {
switch ( $content_struct [ " mt_allow_comments " ]) {
case " closed " :
$comment_status = " closed " ;
break ;
case " open " :
$comment_status = " open " ;
break ;
default :
$comment_status = get_option ( " default_comment_status " );
break ;
}
2007-04-18 00:00:00 +02:00
}
2007-06-19 21:12:24 +02:00
else {
switch (( int ) $content_struct [ " mt_allow_comments " ]) {
case 0 :
2007-11-28 21:52:55 +01:00
case 2 :
2007-06-19 21:12:24 +02:00
$comment_status = " closed " ;
break ;
case 1 :
$comment_status = " open " ;
break ;
default :
$comment_status = get_option ( " default_comment_status " );
break ;
}
}
}
else {
$comment_status = get_option ( " default_comment_status " );
2007-04-18 00:00:00 +02:00
}
2004-08-25 18:28:20 +02:00
2007-04-18 00:00:00 +02:00
if ( isset ( $content_struct [ " mt_allow_pings " ])) {
2007-06-19 21:12:24 +02:00
if ( ! is_numeric ( $content_struct [ " mt_allow_pings " ])) {
2007-08-18 01:32:49 +02:00
switch ( $content_struct [ 'mt_allow_pings' ]) {
2007-06-19 21:12:24 +02:00
case " closed " :
$ping_status = " closed " ;
2007-09-04 01:32:58 +02:00
break ;
2007-06-19 21:12:24 +02:00
case " open " :
$ping_status = " open " ;
break ;
default :
$ping_status = get_option ( " default_ping_status " );
break ;
}
}
else {
switch (( int ) $content_struct [ " mt_allow_pings " ]) {
case 0 :
$ping_status = " closed " ;
break ;
case 1 :
$ping_status = " open " ;
break ;
default :
$ping_status = get_option ( " default_ping_status " );
break ;
}
2007-04-18 00:00:00 +02:00
}
}
2007-06-19 21:12:24 +02:00
else {
$ping_status = get_option ( " default_ping_status " );
}
2004-08-25 18:28:20 +02:00
2007-12-06 20:49:33 +01:00
if ( $post_more ) {
2008-04-03 22:56:48 +02:00
$post_content = $post_content . " <!--more--> " . $post_more ;
2007-12-06 20:49:33 +01:00
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$to_ping = $content_struct [ 'mt_tb_ping_urls' ];
if ( is_array ( $to_ping ) )
$to_ping = implode ( ' ' , $to_ping );
2005-06-19 05:30:46 +02:00
2007-08-17 05:18:58 +02:00
// Do some timestamp voodoo
2008-01-30 21:33:14 +01:00
if ( ! empty ( $content_struct [ 'date_created_gmt' ] ) )
$dateCreated = str_replace ( 'Z' , '' , $content_struct [ 'date_created_gmt' ] -> getIso () ) . 'Z' ; // We know this is supposed to be GMT, so we're going to slap that Z on there by force
elseif ( ! empty ( $content_struct [ 'dateCreated' ]) )
$dateCreated = $content_struct [ 'dateCreated' ] -> getIso ();
if ( ! empty ( $dateCreated ) ) {
2007-08-17 05:18:58 +02:00
$post_date = get_date_from_gmt ( iso8601_to_datetime ( $dateCreated ));
$post_date_gmt = iso8601_to_datetime ( $dateCreated , GMT );
} else {
$post_date = current_time ( 'mysql' );
$post_date_gmt = current_time ( 'mysql' , 1 );
}
2004-09-17 22:53:18 +02:00
2007-12-06 20:49:33 +01:00
$catnames = $content_struct [ 'categories' ];
2008-01-29 23:54:18 +01:00
logIO ( 'O' , 'Post cats: ' . var_export ( $catnames , true ));
2007-12-06 20:49:33 +01:00
$post_category = array ();
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( is_array ( $catnames )) {
foreach ( $catnames as $cat ) {
$post_category [] = get_cat_ID ( $cat );
}
}
2004-09-17 22:48:43 +02:00
2007-12-06 20:49:33 +01:00
// We've got all the data -- post it:
2008-05-06 18:49:42 +02:00
$postdata = compact ( 'post_author' , 'post_date' , 'post_date_gmt' , 'post_content' , 'post_title' , 'post_category' , 'post_status' , 'post_excerpt' , 'comment_status' , 'ping_status' , 'to_ping' , 'post_type' , 'post_name' , 'post_password' , 'post_parent' , 'menu_order' , 'tags_input' , 'page_template' );
2008-02-05 07:47:27 +01:00
2008-05-06 18:49:42 +02:00
$post_ID = wp_insert_post ( $postdata , true );
2007-12-06 20:49:33 +01:00
if ( is_wp_error ( $post_ID ) )
return new IXR_Error ( 500 , $post_ID -> get_error_message ());
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $post_ID ) {
return new IXR_Error ( 500 , __ ( 'Sorry, your entry could not be posted. Something wrong happened.' ));
}
2007-12-19 22:07:38 +01:00
2008-02-05 07:47:27 +01:00
if ( isset ( $content_struct [ 'custom_fields' ]) ) {
$this -> set_custom_fields ( $post_ID , $content_struct [ 'custom_fields' ]);
}
2008-08-09 07:36:14 +02:00
// Handle enclosures
$enclosure = $content_struct [ 'enclosure' ];
if ( is_array ( $enclosure ) && isset ( $enclosure [ 'url' ] ) && isset ( $enclosure [ 'length' ] ) && isset ( $enclosure [ 'type' ] ) ) {
2008-04-28 18:15:23 +02:00
add_post_meta ( $post_ID , 'enclosure' , $enclosure [ 'url' ] . " \n " . $enclosure [ 'length' ] . " \n " . $enclosure [ 'type' ] );
2008-08-09 07:36:14 +02:00
}
2008-04-28 18:15:23 +02:00
2007-12-06 20:49:33 +01:00
$this -> attach_uploads ( $post_ID , $post_content );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
logIO ( 'O' , " Posted ! ID: $post_ID " );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
return strval ( $post_ID );
2004-08-25 18:28:20 +02:00
}
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
/**
* Attach upload to a post .
*
* @ since 2.1 . 0
*
* @ param int $post_ID Post ID .
* @ param string $post_content Post Content for attachment .
*/
2006-12-01 05:34:59 +01:00
function attach_uploads ( $post_ID , $post_content ) {
global $wpdb ;
// find any unattached files
$attachments = $wpdb -> get_results ( " SELECT ID, guid FROM { $wpdb -> posts } WHERE post_parent = '-1' AND post_type = 'attachment' " );
if ( is_array ( $attachments ) ) {
foreach ( $attachments as $file ) {
if ( strpos ( $post_content , $file -> guid ) !== false ) {
2008-04-14 18:13:25 +02:00
$wpdb -> query ( $wpdb -> prepare ( " UPDATE { $wpdb -> posts } SET post_parent = %d WHERE ID = %d " , $post_ID , $file -> ID ) );
2006-12-01 05:34:59 +01:00
}
}
}
}
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
/**
* Edit a post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return bool True on success .
*/
2004-09-17 22:53:18 +02:00
function mw_editPost ( $args ) {
2004-08-25 18:28:20 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-12-06 20:49:33 +01:00
$post_ID = ( int ) $args [ 0 ];
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
$content_struct = $args [ 3 ];
$publish = $args [ 4 ];
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
2007-12-23 02:35:44 +01:00
return $this -> error ;
2007-12-06 20:49:33 +01:00
}
2008-02-04 19:35:05 +01:00
$user = set_current_user ( 0 , $user_login );
2004-08-25 18:28:20 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'metaWeblog.editPost' );
2007-12-23 02:35:44 +01:00
2008-02-04 19:35:05 +01:00
$cap = ( $publish ) ? 'publish_posts' : 'edit_posts' ;
$error_message = __ ( 'Sorry, you are not allowed to publish posts on this blog.' );
$post_type = 'post' ;
2008-05-06 18:49:42 +02:00
$page_template = '' ;
2008-02-04 19:35:05 +01:00
if ( ! empty ( $content_struct [ 'post_type' ] ) ) {
if ( $content_struct [ 'post_type' ] == 'page' ) {
$cap = ( $publish ) ? 'publish_pages' : 'edit_pages' ;
$error_message = __ ( 'Sorry, you are not allowed to publish pages on this blog.' );
$post_type = 'page' ;
2008-05-06 18:49:42 +02:00
if ( ! empty ( $content_struct [ 'wp_page_template' ] ) )
$page_template = $content_struct [ 'wp_page_template' ];
2008-02-04 19:35:05 +01:00
}
2008-02-13 18:54:08 +01:00
elseif ( $content_struct [ 'post_type' ] == 'post' ) {
2008-02-04 19:35:05 +01:00
// This is the default, no changes needed
}
else {
// No other post_type values are allowed here
return new IXR_Error ( 401 , __ ( 'Invalid post type.' ) );
2008-02-02 18:55:40 +01:00
}
2007-01-24 02:16:08 +01:00
}
2008-02-04 19:35:05 +01:00
if ( ! current_user_can ( $cap ) ) {
return new IXR_Error ( 401 , $error_message );
}
2007-03-21 23:15:20 +01:00
2007-12-06 20:49:33 +01:00
$postdata = wp_get_single_post ( $post_ID , ARRAY_A );
2007-03-25 05:53:33 +02:00
// If there is no post data for the give post id, stop
// now and return an error. Other wise a new post will be
// created (which was the old behavior).
if ( empty ( $postdata [ " ID " ])) {
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 404 , __ ( " Invalid post id. " )));
2007-03-25 05:53:33 +02:00
}
2007-03-21 23:15:20 +01:00
$this -> escape ( $postdata );
2007-06-18 02:18:18 +02:00
extract ( $postdata , EXTR_SKIP );
2007-03-21 23:15:20 +01:00
2007-01-24 02:16:08 +01:00
// Let WordPress manage slug if none was provided.
$post_name = " " ;
2007-04-18 00:00:00 +02:00
if ( isset ( $content_struct [ " wp_slug " ])) {
2007-01-24 02:16:08 +01:00
$post_name = $content_struct [ " wp_slug " ];
}
// Only use a password if one was given.
2007-04-18 00:00:00 +02:00
if ( isset ( $content_struct [ " wp_password " ])) {
2007-01-24 02:16:08 +01:00
$post_password = $content_struct [ " wp_password " ];
}
// Only set a post parent if one was given.
2007-03-03 17:56:46 +01:00
if ( isset ( $content_struct [ " wp_page_parent_id " ])) {
2007-01-24 02:16:08 +01:00
$post_parent = $content_struct [ " wp_page_parent_id " ];
}
2007-01-30 04:09:58 +01:00
// Only set the menu_order if it was given.
2007-04-18 00:00:00 +02:00
if ( isset ( $content_struct [ " wp_page_order " ])) {
2007-01-24 02:16:08 +01:00
$menu_order = $content_struct [ " wp_page_order " ];
}
2007-05-22 21:53:16 +02:00
$post_author = $postdata [ " post_author " ];
2007-04-18 00:00:00 +02:00
2007-01-30 04:09:58 +01:00
// Only set the post_author if one is set.
2007-04-18 00:00:00 +02:00
if (
isset ( $content_struct [ " wp_author_id " ])
&& ( $user -> ID != $content_struct [ " wp_author_id " ])
) {
2007-02-02 08:43:59 +01:00
switch ( $post_type ) {
case " post " :
if ( ! current_user_can ( " edit_others_posts " )) {
2007-05-25 17:33:47 +02:00
return ( new IXR_Error ( 401 , __ ( " You are not allowed to change the post author as this user. " )));
2007-02-02 08:43:59 +01:00
}
break ;
case " page " :
if ( ! current_user_can ( " edit_others_pages " )) {
2007-05-25 17:33:47 +02:00
return ( new IXR_Error ( 401 , __ ( " You are not allowed to change the page author as this user. " )));
2007-02-02 08:43:59 +01:00
}
break ;
default :
2007-04-01 17:59:50 +02:00
return ( new IXR_Error ( 401 , __ ( " Invalid post type. " )));
2007-02-02 08:43:59 +01:00
break ;
}
2007-02-01 01:34:33 +01:00
$post_author = $content_struct [ " wp_author_id " ];
}
2007-06-19 21:12:24 +02:00
if ( isset ( $content_struct [ " mt_allow_comments " ])) {
if ( ! is_numeric ( $content_struct [ " mt_allow_comments " ])) {
switch ( $content_struct [ " mt_allow_comments " ]) {
case " closed " :
$comment_status = " closed " ;
break ;
case " open " :
$comment_status = " open " ;
break ;
default :
$comment_status = get_option ( " default_comment_status " );
break ;
}
}
else {
switch (( int ) $content_struct [ " mt_allow_comments " ]) {
case 0 :
2007-11-28 21:52:55 +01:00
case 2 :
2007-06-19 21:12:24 +02:00
$comment_status = " closed " ;
break ;
case 1 :
$comment_status = " open " ;
break ;
default :
$comment_status = get_option ( " default_comment_status " );
break ;
}
}
}
if ( isset ( $content_struct [ " mt_allow_pings " ])) {
if ( ! is_numeric ( $content_struct [ " mt_allow_pings " ])) {
2007-08-18 01:32:49 +02:00
switch ( $content_struct [ " mt_allow_pings " ]) {
2007-06-19 21:12:24 +02:00
case " closed " :
$ping_status = " closed " ;
2007-09-04 01:32:58 +02:00
break ;
2007-06-19 21:12:24 +02:00
case " open " :
$ping_status = " open " ;
break ;
default :
$ping_status = get_option ( " default_ping_status " );
break ;
}
}
else {
switch (( int ) $content_struct [ " mt_allow_pings " ]) {
case 0 :
$ping_status = " closed " ;
break ;
case 1 :
$ping_status = " open " ;
break ;
default :
$ping_status = get_option ( " default_ping_status " );
break ;
}
}
}
2007-12-06 20:49:33 +01:00
$post_title = $content_struct [ 'title' ];
$post_content = apply_filters ( 'content_save_pre' , $content_struct [ 'description' ] );
$catnames = $content_struct [ 'categories' ];
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_category = array ();
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( is_array ( $catnames )) {
foreach ( $catnames as $cat ) {
$post_category [] = get_cat_ID ( $cat );
}
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_excerpt = $content_struct [ 'mt_excerpt' ];
$post_more = $content_struct [ 'mt_text_more' ];
2008-01-10 22:46:25 +01:00
2007-12-06 20:49:33 +01:00
$post_status = $publish ? 'publish' : 'draft' ;
2008-01-10 23:37:15 +01:00
if ( isset ( $content_struct [ " { $post_type } _status " ] ) ) {
switch ( $content_struct [ " { $post_type } _status " ] ) {
2008-01-10 22:46:25 +01:00
case 'draft' :
case 'private' :
case 'publish' :
2008-01-10 23:37:15 +01:00
$post_status = $content_struct [ " { $post_type } _status " ];
2008-01-10 22:46:25 +01:00
break ;
case 'pending' :
// Pending is only valid for posts, not pages.
if ( $post_type === 'post' ) {
2008-01-10 23:37:15 +01:00
$post_status = $content_struct [ " { $post_type } _status " ];
2008-01-10 22:46:25 +01:00
}
break ;
default :
$post_status = $publish ? 'publish' : 'draft' ;
break ;
}
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$tags_input = $content_struct [ 'mt_keywords' ];
2004-09-17 22:53:18 +02:00
2007-12-06 20:49:33 +01:00
if ( ( 'publish' == $post_status ) ) {
if ( ( 'page' == $post_type ) && ! current_user_can ( 'publish_pages' ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you do not have the right to publish this page.' ));
else if ( ! current_user_can ( 'publish_posts' ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you do not have the right to publish this post.' ));
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( $post_more ) {
2008-04-03 22:56:48 +02:00
$post_content = $post_content . " <!--more--> " . $post_more ;
2007-12-06 20:49:33 +01:00
}
2004-09-17 22:53:18 +02:00
2007-12-06 20:49:33 +01:00
$to_ping = $content_struct [ 'mt_tb_ping_urls' ];
if ( is_array ( $to_ping ) )
$to_ping = implode ( ' ' , $to_ping );
2008-01-30 21:33:14 +01:00
2007-12-06 20:49:33 +01:00
// Do some timestamp voodoo
2008-01-30 21:33:14 +01:00
if ( ! empty ( $content_struct [ 'date_created_gmt' ] ) )
$dateCreated = str_replace ( 'Z' , '' , $content_struct [ 'date_created_gmt' ] -> getIso () ) . 'Z' ; // We know this is supposed to be GMT, so we're going to slap that Z on there by force
elseif ( ! empty ( $content_struct [ 'dateCreated' ]) )
$dateCreated = $content_struct [ 'dateCreated' ] -> getIso ();
if ( ! empty ( $dateCreated ) ) {
$post_date = get_date_from_gmt ( iso8601_to_datetime ( $dateCreated ));
$post_date_gmt = iso8601_to_datetime ( $dateCreated , GMT );
2007-12-06 20:49:33 +01:00
} else {
$post_date = $postdata [ 'post_date' ];
$post_date_gmt = $postdata [ 'post_date_gmt' ];
}
2004-09-17 22:53:18 +02:00
2007-12-06 20:49:33 +01:00
// We've got all the data -- post it:
2008-05-06 18:49:42 +02:00
$newpost = compact ( 'ID' , 'post_content' , 'post_title' , 'post_category' , 'post_status' , 'post_excerpt' , 'comment_status' , 'ping_status' , 'post_date' , 'post_date_gmt' , 'to_ping' , 'post_name' , 'post_password' , 'post_parent' , 'menu_order' , 'post_author' , 'tags_input' , 'page_template' );
$result = wp_update_post ( $newpost , true );
if ( is_wp_error ( $result ) )
return new IXR_Error ( 500 , $result -> get_error_message ());
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $result ) {
return new IXR_Error ( 500 , __ ( 'Sorry, your entry could not be edited. Something wrong happened.' ));
}
2007-12-19 22:07:38 +01:00
2008-02-05 07:47:27 +01:00
if ( isset ( $content_struct [ 'custom_fields' ]) ) {
$this -> set_custom_fields ( $post_ID , $content_struct [ 'custom_fields' ]);
}
2007-12-19 22:07:38 +01:00
2008-08-09 07:36:14 +02:00
// Handle enclosures
$enclosure = $content_struct [ 'enclosure' ];
if ( is_array ( $enclosure ) && isset ( $enclosure [ 'url' ] ) && isset ( $enclosure [ 'length' ] ) && isset ( $enclosure [ 'type' ] ) ) {
2008-04-28 18:15:23 +02:00
add_post_meta ( $post_ID , 'enclosure' , $enclosure [ 'url' ] . " \n " . $enclosure [ 'length' ] . " \n " . $enclosure [ 'type' ] );
2008-08-09 07:36:14 +02:00
}
2008-04-28 18:15:23 +02:00
2007-12-06 20:49:33 +01:00
$this -> attach_uploads ( $ID , $post_content );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
logIO ( 'O' , " (MW) Edited ! ID: $post_ID " );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
return true ;
2004-08-26 17:42:43 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function mw_getPost ( $args ) {
2004-09-17 22:48:43 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post_ID = ( int ) $args [ 0 ];
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2007-12-23 02:35:44 +01:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit this post.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'metaWeblog.getPost' );
2007-12-23 02:35:44 +01:00
2007-12-06 20:49:33 +01:00
$postdata = wp_get_single_post ( $post_ID , ARRAY_A );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
if ( $postdata [ 'post_date' ] != '' ) {
$post_date = mysql2date ( 'Ymd\TH:i:s' , $postdata [ 'post_date' ]);
$post_date_gmt = mysql2date ( 'Ymd\TH:i:s' , $postdata [ 'post_date_gmt' ]);
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$categories = array ();
$catids = wp_get_post_categories ( $post_ID );
foreach ( $catids as $catid )
$categories [] = get_cat_name ( $catid );
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$tagnames = array ();
$tags = wp_get_post_tags ( $post_ID );
if ( ! empty ( $tags ) ) {
foreach ( $tags as $tag )
$tagnames [] = $tag -> name ;
$tagnames = implode ( ', ' , $tagnames );
} else {
$tagnames = '' ;
2007-08-30 01:01:48 +02:00
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$post = get_extended ( $postdata [ 'post_content' ]);
$link = post_permalink ( $postdata [ 'ID' ]);
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
// Get the author info.
$author = get_userdata ( $postdata [ 'post_author' ]);
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$allow_comments = ( 'open' == $postdata [ 'comment_status' ]) ? 1 : 0 ;
$allow_pings = ( 'open' == $postdata [ 'ping_status' ]) ? 1 : 0 ;
2008-01-10 22:46:25 +01:00
// Consider future posts as published
if ( $postdata [ 'post_status' ] === 'future' ) {
$postdata [ 'post_status' ] = 'publish' ;
}
2008-12-09 19:03:31 +01:00
2008-10-06 21:20:50 +02:00
$enclosure = array ();
foreach ( ( array ) get_post_custom ( $post_ID ) as $key => $val ) {
if ( $key == 'enclosure' ) {
foreach ( ( array ) $val as $enc ) {
$encdata = split ( " \n " , $enc );
$enclosure [ 'url' ] = trim ( htmlspecialchars ( $encdata [ 0 ]));
$enclosure [ 'length' ] = trim ( $encdata [ 1 ]);
$enclosure [ 'type' ] = trim ( $encdata [ 2 ]);
break 2 ;
}
}
}
2008-02-05 07:47:27 +01:00
2007-12-06 20:49:33 +01:00
$resp = array (
'dateCreated' => new IXR_Date ( $post_date ),
'userid' => $postdata [ 'post_author' ],
'postid' => $postdata [ 'ID' ],
'description' => $post [ 'main' ],
'title' => $postdata [ 'post_title' ],
'link' => $link ,
'permaLink' => $link ,
// commented out because no other tool seems to use this
// 'content' => $entry['post_content'],
'categories' => $categories ,
'mt_excerpt' => $postdata [ 'post_excerpt' ],
'mt_text_more' => $post [ 'extended' ],
'mt_allow_comments' => $allow_comments ,
'mt_allow_pings' => $allow_pings ,
'mt_keywords' => $tagnames ,
'wp_slug' => $postdata [ 'post_name' ],
'wp_password' => $postdata [ 'post_password' ],
'wp_author_id' => $author -> ID ,
'wp_author_display_name' => $author -> display_name ,
'date_created_gmt' => new IXR_Date ( $post_date_gmt ),
2007-12-19 22:07:38 +01:00
'post_status' => $postdata [ 'post_status' ],
'custom_fields' => $this -> get_custom_fields ( $post_ID )
2007-12-06 20:49:33 +01:00
);
2008-12-09 19:03:31 +01:00
2008-10-06 21:20:50 +02:00
if ( ! empty ( $enclosure )) $resp [ 'enclosure' ] = $enclosure ;
2008-12-09 19:03:31 +01:00
2007-12-06 20:49:33 +01:00
return $resp ;
2007-08-30 01:01:48 +02:00
} else {
2007-12-06 20:49:33 +01:00
return new IXR_Error ( 404 , __ ( 'Sorry, no such post.' ));
2007-08-30 01:01:48 +02:00
}
2004-09-17 22:53:18 +02:00
}
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve list of recent posts .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function mw_getRecentPosts ( $args ) {
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_ID = ( int ) $args [ 0 ];
2006-11-19 08:56:05 +01:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2007-03-23 01:59:21 +01:00
$num_posts = ( int ) $args [ 3 ];
2004-09-17 22:53:18 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-09-17 22:53:18 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'metaWeblog.getRecentPosts' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$posts_list = wp_get_recent_posts ( $num_posts );
2004-09-17 22:53:18 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $posts_list ) {
2008-10-13 23:28:28 +02:00
return array ( );
2006-11-19 08:56:05 +01:00
}
2004-09-17 22:53:18 +02:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
2007-12-26 20:50:26 +01:00
2006-11-19 08:56:05 +01:00
foreach ( $posts_list as $entry ) {
2007-12-27 23:14:27 +01:00
if ( ! current_user_can ( 'edit_post' , $entry [ 'ID' ] ) )
continue ;
2004-09-17 22:53:18 +02:00
2007-08-17 05:18:58 +02:00
$post_date = mysql2date ( 'Ymd\TH:i:s' , $entry [ 'post_date' ]);
$post_date_gmt = mysql2date ( 'Ymd\TH:i:s' , $entry [ 'post_date_gmt' ]);
2006-11-19 08:56:05 +01:00
$categories = array ();
$catids = wp_get_post_categories ( $entry [ 'ID' ]);
foreach ( $catids as $catid ) {
$categories [] = get_cat_name ( $catid );
}
2004-09-17 22:53:18 +02:00
2007-08-30 01:01:48 +02:00
$tagnames = array ();
$tags = wp_get_post_tags ( $entry [ 'ID' ] );
if ( ! empty ( $tags ) ) {
foreach ( $tags as $tag ) {
$tagnames [] = $tag -> name ;
}
$tagnames = implode ( ', ' , $tagnames );
} else {
$tagnames = '' ;
}
2006-11-19 08:56:05 +01:00
$post = get_extended ( $entry [ 'post_content' ]);
$link = post_permalink ( $entry [ 'ID' ]);
2004-09-17 22:53:18 +02:00
2007-01-30 04:09:58 +01:00
// Get the post author info.
2007-02-01 01:34:33 +01:00
$author = get_userdata ( $entry [ 'post_author' ]);
2007-01-30 04:09:58 +01:00
2006-11-19 08:56:05 +01:00
$allow_comments = ( 'open' == $entry [ 'comment_status' ]) ? 1 : 0 ;
$allow_pings = ( 'open' == $entry [ 'ping_status' ]) ? 1 : 0 ;
2008-01-10 22:46:25 +01:00
// Consider future posts as published
if ( $entry [ 'post_status' ] === 'future' ) {
$entry [ 'post_status' ] = 'publish' ;
}
2006-11-19 08:56:05 +01:00
$struct [] = array (
'dateCreated' => new IXR_Date ( $post_date ),
'userid' => $entry [ 'post_author' ],
'postid' => $entry [ 'ID' ],
'description' => $post [ 'main' ],
'title' => $entry [ 'post_title' ],
'link' => $link ,
'permaLink' => $link ,
2008-09-22 07:15:41 +02:00
// commented out because no other tool seems to use this
// 'content' => $entry['post_content'],
2006-11-19 08:56:05 +01:00
'categories' => $categories ,
'mt_excerpt' => $entry [ 'post_excerpt' ],
'mt_text_more' => $post [ 'extended' ],
'mt_allow_comments' => $allow_comments ,
2007-01-30 04:09:58 +01:00
'mt_allow_pings' => $allow_pings ,
2007-08-30 01:01:48 +02:00
'mt_keywords' => $tagnames ,
2007-01-30 04:09:58 +01:00
'wp_slug' => $entry [ 'post_name' ],
'wp_password' => $entry [ 'post_password' ],
2007-02-02 08:43:59 +01:00
'wp_author_id' => $author -> ID ,
2007-08-17 05:18:58 +02:00
'wp_author_display_name' => $author -> display_name ,
2007-12-05 08:42:42 +01:00
'date_created_gmt' => new IXR_Date ( $post_date_gmt ),
2007-12-19 22:07:38 +01:00
'post_status' => $entry [ 'post_status' ],
'custom_fields' => $this -> get_custom_fields ( $entry [ 'ID' ])
2006-11-19 08:56:05 +01:00
);
2004-09-17 22:53:18 +02:00
2006-11-19 08:56:05 +01:00
}
2004-09-17 22:53:18 +02:00
2006-11-19 08:56:05 +01:00
$recent_posts = array ();
for ( $j = 0 ; $j < count ( $struct ); $j ++ ) {
array_push ( $recent_posts , $struct [ $j ]);
}
return $recent_posts ;
2004-09-17 22:53:18 +02:00
}
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve the list of categories on a given blog .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function mw_getCategories ( $args ) {
2004-09-17 22:48:43 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_ID = ( int ) $args [ 0 ];
2006-11-19 08:56:05 +01:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2004-09-17 22:48:43 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-09-17 22:48:43 +02:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_posts' ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you must be able to edit posts on this blog in order to view categories.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'metaWeblog.getCategories' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$categories_struct = array ();
2004-09-17 22:48:43 +02:00
2007-06-25 23:34:06 +02:00
if ( $cats = get_categories ( 'get=all' ) ) {
foreach ( $cats as $cat ) {
$struct [ 'categoryId' ] = $cat -> term_id ;
$struct [ 'parentId' ] = $cat -> parent ;
2008-12-05 06:13:27 +01:00
$struct [ 'description' ] = $cat -> description ;
2007-06-25 23:34:06 +02:00
$struct [ 'categoryName' ] = $cat -> name ;
$struct [ 'htmlUrl' ] = wp_specialchars ( get_category_link ( $cat -> term_id ));
2008-11-08 10:10:19 +01:00
$struct [ 'rssUrl' ] = wp_specialchars ( get_category_feed_link ( $cat -> term_id , 'rss2' ));
2004-09-17 22:48:43 +02:00
2006-11-19 08:56:05 +01:00
$categories_struct [] = $struct ;
}
}
2004-09-17 22:48:43 +02:00
2006-11-19 08:56:05 +01:00
return $categories_struct ;
2004-08-26 17:42:43 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Uploads a file , following your settings .
*
* Adapted from a patch by Johann Richard .
*
* @ link http :// mycvs . org / archives / 2004 / 06 / 30 / file - upload - to - wordpress - in - ecto /
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function mw_newMediaObject ( $args ) {
2005-06-30 02:12:18 +02:00
global $wpdb ;
2005-06-30 18:07:42 +02:00
2007-03-23 01:59:21 +01:00
$blog_ID = ( int ) $args [ 0 ];
2005-12-01 23:51:40 +01:00
$user_login = $wpdb -> escape ( $args [ 1 ]);
2005-06-30 02:12:18 +02:00
$user_pass = $wpdb -> escape ( $args [ 2 ]);
2005-12-01 23:51:40 +01:00
$data = $args [ 3 ];
2004-09-17 22:53:18 +02:00
2007-01-09 23:53:14 +01:00
$name = sanitize_file_name ( $data [ 'name' ] );
2005-12-01 23:51:40 +01:00
$type = $data [ 'type' ];
$bits = $data [ 'bits' ];
2004-09-17 22:53:18 +02:00
2007-06-08 19:07:59 +02:00
logIO ( 'O' , '(MW) Received ' . strlen ( $bits ) . ' bytes' );
if ( ! $this -> login_pass_ok ( $user_login , $user_pass ) )
return $this -> error ;
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'metaWeblog.newMediaObject' );
2007-12-23 02:35:44 +01:00
2007-06-08 19:07:59 +02:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'upload_files' ) ) {
logIO ( 'O' , '(MW) User does not have upload_files capability' );
$this -> error = new IXR_Error ( 401 , __ ( 'You are not allowed to upload files to this site.' ));
return $this -> error ;
}
if ( $upload_err = apply_filters ( " pre_upload_error " , false ) )
return new IXR_Error ( 500 , $upload_err );
2007-02-22 02:42:21 +01:00
if ( ! empty ( $data [ " overwrite " ]) && ( $data [ " overwrite " ] == true )) {
2007-03-03 17:56:46 +01:00
// Get postmeta info on the object.
2007-03-09 21:14:52 +01:00
$old_file = $wpdb -> get_row ( "
SELECT ID
FROM { $wpdb -> posts }
WHERE post_title = '{$name}'
AND post_type = 'attachment'
2007-03-03 17:56:46 +01:00
" );
2007-03-09 21:14:52 +01:00
// Delete previous file.
wp_delete_attachment ( $old_file -> ID );
// Make sure the new name is different by pre-pending the
// previous post id.
$filename = preg_replace ( " /^wpid \ d+-/ " , " " , $name );
$name = " wpid { $old_file -> ID } - { $filename } " ;
2007-02-22 02:42:21 +01:00
}
2007-12-06 20:49:33 +01:00
$upload = wp_upload_bits ( $name , $type , $bits );
2005-12-29 03:07:10 +01:00
if ( ! empty ( $upload [ 'error' ]) ) {
2007-05-25 17:33:47 +02:00
$errorString = sprintf ( __ ( 'Could not write file %1$s (%2$s)' ), $name , $upload [ 'error' ]);
2007-03-16 23:12:15 +01:00
logIO ( 'O' , '(MW) ' . $errorString );
return new IXR_Error ( 500 , $errorString );
2005-12-01 23:51:40 +01:00
}
2006-12-01 05:34:59 +01:00
// Construct the attachment array
// attach to post_id -1
$post_id = - 1 ;
$attachment = array (
'post_title' => $name ,
'post_content' => '' ,
'post_type' => 'attachment' ,
'post_parent' => $post_id ,
'post_mime_type' => $type ,
'guid' => $upload [ 'url' ]
);
2007-02-22 02:42:21 +01:00
2007-03-03 17:56:46 +01:00
// Save the data
2007-03-23 03:05:29 +01:00
$id = wp_insert_attachment ( $attachment , $upload [ 'file' ], $post_id );
2007-03-03 17:56:46 +01:00
wp_update_attachment_metadata ( $id , wp_generate_attachment_metadata ( $id , $upload [ 'file' ] ) );
2007-03-09 21:14:52 +01:00
return apply_filters ( 'wp_handle_upload' , array ( 'file' => $name , 'url' => $upload [ 'url' ], 'type' => $type ) );
2004-08-27 10:46:24 +02:00
}
2004-09-17 22:53:18 +02:00
/* MovableType API functions
* specs on http :// www . movabletype . org / docs / mtmanual_programmatic . html
*/
2004-09-14 18:52:13 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve the post titles of recent posts .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function mt_getRecentPostTitles ( $args ) {
2004-09-14 18:52:13 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_ID = ( int ) $args [ 0 ];
2006-11-19 08:56:05 +01:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2007-03-23 01:59:21 +01:00
$num_posts = ( int ) $args [ 3 ];
2004-09-14 18:52:13 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-09-14 18:52:13 +02:00
2008-01-18 08:52:15 +01:00
do_action ( 'xmlrpc_call' , 'mt.getRecentPostTitles' );
2006-11-19 08:56:05 +01:00
$posts_list = wp_get_recent_posts ( $num_posts );
2004-09-14 18:52:13 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $posts_list ) {
2007-04-01 17:59:50 +02:00
$this -> error = new IXR_Error ( 500 , __ ( 'Either there are no posts, or something went wrong.' ));
2006-11-19 08:56:05 +01:00
return $this -> error ;
}
2004-09-14 18:52:13 +02:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
2006-11-19 08:56:05 +01:00
foreach ( $posts_list as $entry ) {
2008-02-05 07:47:27 +01:00
if ( ! current_user_can ( 'edit_post' , $entry [ 'ID' ] ) )
2007-12-27 23:14:27 +01:00
continue ;
2004-09-14 18:52:13 +02:00
2007-08-17 05:18:58 +02:00
$post_date = mysql2date ( 'Ymd\TH:i:s' , $entry [ 'post_date' ]);
$post_date_gmt = mysql2date ( 'Ymd\TH:i:s' , $entry [ 'post_date_gmt' ]);
2004-09-14 18:52:13 +02:00
2006-11-19 08:56:05 +01:00
$struct [] = array (
'dateCreated' => new IXR_Date ( $post_date ),
'userid' => $entry [ 'post_author' ],
'postid' => $entry [ 'ID' ],
'title' => $entry [ 'post_title' ],
2007-08-17 05:18:58 +02:00
'date_created_gmt' => new IXR_Date ( $post_date_gmt )
2006-11-19 08:56:05 +01:00
);
2004-09-14 18:52:13 +02:00
2006-11-19 08:56:05 +01:00
}
$recent_posts = array ();
for ( $j = 0 ; $j < count ( $struct ); $j ++ ) {
array_push ( $recent_posts , $struct [ $j ]);
}
return $recent_posts ;
2004-09-14 18:52:13 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve list of all categories on blog .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function mt_getCategoryList ( $args ) {
2004-09-14 18:52:13 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$blog_ID = ( int ) $args [ 0 ];
2006-11-19 08:56:05 +01:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2004-09-14 18:52:13 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-09-14 18:52:13 +02:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_posts' ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you must be able to edit posts on this blog in order to view categories.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'mt.getCategoryList' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$categories_struct = array ();
2004-09-14 18:52:13 +02:00
2007-05-23 22:59:11 +02:00
if ( $cats = get_categories ( 'hide_empty=0&hierarchical=0' ) ) {
2006-11-19 08:56:05 +01:00
foreach ( $cats as $cat ) {
2007-05-23 22:59:11 +02:00
$struct [ 'categoryId' ] = $cat -> term_id ;
$struct [ 'categoryName' ] = $cat -> name ;
2004-09-14 18:52:13 +02:00
2006-11-19 08:56:05 +01:00
$categories_struct [] = $struct ;
}
}
2004-09-14 18:52:13 +02:00
2006-11-19 08:56:05 +01:00
return $categories_struct ;
2004-09-14 18:52:13 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve post categories .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function mt_getPostCategories ( $args ) {
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$post_ID = ( int ) $args [ 0 ];
2006-11-19 08:56:05 +01:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2004-09-17 22:53:18 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-09-17 22:53:18 +02:00
2007-12-27 23:14:27 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit this post.' ) );
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'mt.getPostCategories' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$categories = array ();
$catids = wp_get_post_categories ( intval ( $post_ID ));
// first listed category will be the primary category
$isPrimary = true ;
foreach ( $catids as $catid ) {
$categories [] = array (
'categoryName' => get_cat_name ( $catid ),
2007-01-25 19:27:47 +01:00
'categoryId' => ( string ) $catid ,
2006-11-19 08:56:05 +01:00
'isPrimary' => $isPrimary
);
$isPrimary = false ;
}
return $categories ;
2004-09-16 16:54:25 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Sets categories for a post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return bool True on success .
*/
2004-09-17 22:53:18 +02:00
function mt_setPostCategories ( $args ) {
2004-09-16 16:54:25 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$post_ID = ( int ) $args [ 0 ];
2006-11-19 08:56:05 +01:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
$categories = $args [ 3 ];
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-09-16 16:54:25 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'mt.setPostCategories' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit this post.' ));
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
foreach ( $categories as $cat ) {
$catids [] = $cat [ 'categoryId' ];
}
2006-02-12 08:53:23 +01:00
2006-11-19 08:56:05 +01:00
wp_set_post_categories ( $post_ID , $catids );
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
return true ;
2004-09-17 22:53:18 +02:00
}
2004-09-16 16:54:25 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve an array of methods supported by this server .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function mt_supportedMethods ( $args ) {
2004-09-16 16:54:25 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'mt.supportedMethods' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$supported_methods = array ();
foreach ( $this -> methods as $key => $value ) {
$supported_methods [] = $key ;
}
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
return $supported_methods ;
2004-09-16 16:54:25 +02:00
}
2004-09-17 22:48:43 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve an empty array because we don ' t support per - post text filters .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
*/
2004-09-17 22:53:18 +02:00
function mt_supportedTextFilters ( $args ) {
2008-01-18 08:52:15 +01:00
do_action ( 'xmlrpc_call' , 'mt.supportedTextFilters' );
2007-03-26 01:50:22 +02:00
return apply_filters ( 'xmlrpc_text_filters' , array ());
2004-09-17 22:53:18 +02:00
}
2004-09-16 16:54:25 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieve trackbacks sent to a given post .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return mixed
*/
2004-09-17 22:53:18 +02:00
function mt_getTrackbackPings ( $args ) {
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
global $wpdb ;
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
$post_ID = intval ( $args );
2004-09-16 16:54:25 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'mt.getTrackbackPings' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
$actual_post = wp_get_single_post ( $post_ID , ARRAY_A );
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $actual_post ) {
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 404 , __ ( 'Sorry, no such post.' ));
2006-11-19 08:56:05 +01:00
}
2004-09-16 16:54:25 +02:00
2008-04-14 18:13:25 +02:00
$comments = $wpdb -> get_results ( $wpdb -> prepare ( " SELECT comment_author_url, comment_content, comment_author_IP, comment_type FROM $wpdb->comments WHERE comment_post_ID = %d " , $post_ID ) );
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $comments ) {
return array ();
}
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
$trackback_pings = array ();
foreach ( $comments as $comment ) {
if ( 'trackback' == $comment -> comment_type ) {
$content = $comment -> comment_content ;
$title = substr ( $content , 8 , ( strpos ( $content , '</strong>' ) - 8 ));
$trackback_pings [] = array (
'pingTitle' => $title ,
'pingURL' => $comment -> comment_author_url ,
'pingIP' => $comment -> comment_author_IP
);
}
2004-09-16 16:54:25 +02:00
}
2006-11-19 08:56:05 +01:00
return $trackback_pings ;
2004-09-16 16:54:25 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Sets a post 's publish status to ' publish ' .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return int
*/
2004-09-17 22:53:18 +02:00
function mt_publishPost ( $args ) {
2004-09-16 16:54:25 +02:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2007-03-23 01:59:21 +01:00
$post_ID = ( int ) $args [ 0 ];
2006-11-19 08:56:05 +01:00
$user_login = $args [ 1 ];
$user_pass = $args [ 2 ];
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
if ( ! $this -> login_pass_ok ( $user_login , $user_pass )) {
return $this -> error ;
}
2004-09-16 16:54:25 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'mt.publishPost' );
2007-12-23 02:35:44 +01:00
2006-11-19 08:56:05 +01:00
set_current_user ( 0 , $user_login );
if ( ! current_user_can ( 'edit_post' , $post_ID ) )
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 401 , __ ( 'Sorry, you can not edit this post.' ));
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
$postdata = wp_get_single_post ( $post_ID , ARRAY_A );
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
$postdata [ 'post_status' ] = 'publish' ;
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
// retain old cats
$cats = wp_get_post_categories ( $post_ID );
$postdata [ 'post_category' ] = $cats ;
2005-06-29 00:16:27 +02:00
$this -> escape ( $postdata );
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
$result = wp_update_post ( $postdata );
2004-09-16 16:54:25 +02:00
2006-11-19 08:56:05 +01:00
return $result ;
2004-09-17 22:53:18 +02:00
}
2004-09-16 16:54:25 +02:00
2004-09-17 22:53:18 +02:00
/* PingBack functions
* specs on www . hixie . ch / specs / pingback / pingback
*/
2004-09-16 15:26:06 +02:00
2008-09-22 07:15:41 +02:00
/**
* Retrieves a pingback and registers it .
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function pingback_ping ( $args ) {
2007-12-06 20:49:33 +01:00
global $wpdb ;
2004-09-16 15:26:06 +02:00
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'pingback.ping' );
2007-12-23 02:35:44 +01:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2004-09-17 22:53:18 +02:00
$pagelinkedfrom = $args [ 0 ];
$pagelinkedto = $args [ 1 ];
2004-09-17 22:48:43 +02:00
2004-09-17 22:53:18 +02:00
$title = '' ;
2004-09-17 22:48:43 +02:00
2004-09-17 22:53:18 +02:00
$pagelinkedfrom = str_replace ( '&' , '&' , $pagelinkedfrom );
2007-09-18 18:42:25 +02:00
$pagelinkedto = str_replace ( '&' , '&' , $pagelinkedto );
$pagelinkedto = str_replace ( '&' , '&' , $pagelinkedto );
2004-09-17 22:48:43 +02:00
2004-09-17 22:53:18 +02:00
// Check if the page linked to is in our site
2006-08-30 23:46:31 +02:00
$pos1 = strpos ( $pagelinkedto , str_replace ( array ( 'http://www.' , 'http://' , 'https://www.' , 'https://' ), '' , get_option ( 'home' )));
2005-06-04 12:15:36 +02:00
if ( ! $pos1 )
2007-12-06 20:49:33 +01:00
return new IXR_Error ( 0 , __ ( 'Is there no link to us?' ));
2004-09-16 15:26:06 +02:00
// let's find which post is linked to
2004-09-17 22:53:18 +02:00
// FIXME: does url_to_postid() cover all these cases already?
// if so, then let's use it and drop the old code.
2004-09-16 15:26:06 +02:00
$urltest = parse_url ( $pagelinkedto );
if ( $post_ID = url_to_postid ( $pagelinkedto )) {
$way = 'url_to_postid()' ;
2004-09-17 22:53:18 +02:00
} elseif ( preg_match ( '#p/[0-9]{1,}#' , $urltest [ 'path' ], $match )) {
2004-09-16 15:26:06 +02:00
// the path defines the post_ID (archives/p/XXXX)
$blah = explode ( '/' , $match [ 0 ]);
2007-03-23 01:59:21 +01:00
$post_ID = ( int ) $blah [ 1 ];
2004-09-16 15:26:06 +02:00
$way = 'from the path' ;
} elseif ( preg_match ( '#p=[0-9]{1,}#' , $urltest [ 'query' ], $match )) {
// the querystring defines the post_ID (?p=XXXX)
$blah = explode ( '=' , $match [ 0 ]);
2007-03-23 01:59:21 +01:00
$post_ID = ( int ) $blah [ 1 ];
2004-09-16 15:26:06 +02:00
$way = 'from the querystring' ;
} elseif ( isset ( $urltest [ 'fragment' ])) {
// an #anchor is there, it's either...
if ( intval ( $urltest [ 'fragment' ])) {
// ...an integer #XXXX (simpliest case)
2007-03-23 01:59:21 +01:00
$post_ID = ( int ) $urltest [ 'fragment' ];
2004-09-16 15:26:06 +02:00
$way = 'from the fragment (numeric)' ;
} elseif ( preg_match ( '/post-[0-9]+/' , $urltest [ 'fragment' ])) {
// ...a post id in the form 'post-###'
$post_ID = preg_replace ( '/[^0-9]+/' , '' , $urltest [ 'fragment' ]);
$way = 'from the fragment (post-###)' ;
} elseif ( is_string ( $urltest [ 'fragment' ])) {
// ...or a string #title, a little more complicated
2005-06-04 12:15:36 +02:00
$title = preg_replace ( '/[^a-z0-9]/i' , '.' , $urltest [ 'fragment' ]);
2008-04-14 18:13:25 +02:00
$sql = $wpdb -> prepare ( " SELECT ID FROM $wpdb->posts WHERE post_title RLIKE %s " , $title );
2004-09-17 22:53:18 +02:00
if ( ! ( $post_ID = $wpdb -> get_var ( $sql )) ) {
// returning unknown error '0' is better than die()ing
return new IXR_Error ( 0 , '' );
}
2004-09-16 15:26:06 +02:00
$way = 'from the fragment (title)' ;
}
} else {
// TODO: Attempt to extract a post ID from the given URL
2007-05-25 17:33:47 +02:00
return new IXR_Error ( 33 , __ ( 'The specified target URL cannot be used as a target. It either doesn\'t exist, or it is not a pingback-enabled resource.' ));
2004-09-16 15:26:06 +02:00
}
2005-06-04 12:15:36 +02:00
$post_ID = ( int ) $post_ID ;
2004-09-16 15:26:06 +02:00
2006-08-30 18:40:17 +02:00
logIO ( " O " , " (PB) URL=' $pagelinkedto ' ID=' $post_ID ' Found=' $way ' " );
2004-09-16 15:26:06 +02:00
2005-06-30 18:07:42 +02:00
$post = get_post ( $post_ID );
2004-09-16 15:26:06 +02:00
2005-06-04 12:15:36 +02:00
if ( ! $post ) // Post_ID not found
2007-05-25 17:33:47 +02:00
return new IXR_Error ( 33 , __ ( 'The specified target URL cannot be used as a target. It either doesn\'t exist, or it is not a pingback-enabled resource.' ));
2004-09-17 22:53:18 +02:00
2005-11-05 17:20:09 +01:00
if ( $post_ID == url_to_postid ( $pagelinkedfrom ) )
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 0 , __ ( 'The source URL and the target URL cannot both point to the same resource.' ));
2005-11-05 17:20:09 +01:00
2005-06-04 12:15:36 +02:00
// Check if pings are on
2008-11-14 23:33:13 +01:00
if ( ! pings_open ( $post ) )
2007-05-25 17:33:47 +02:00
return new IXR_Error ( 33 , __ ( 'The specified target URL cannot be used as a target. It either doesn\'t exist, or it is not a pingback-enabled resource.' ));
2004-09-17 22:53:18 +02:00
// Let's check that the remote site didn't already pingback this entry
2008-04-14 18:13:25 +02:00
$wpdb -> get_results ( $wpdb -> prepare ( " SELECT * FROM $wpdb->comments WHERE comment_post_ID = %d AND comment_author_url = %s " , $post_ID , $pagelinkedfrom ) );
2004-09-17 22:53:18 +02:00
2005-06-04 12:15:36 +02:00
if ( $wpdb -> num_rows ) // We already have a Pingback from this URL
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 48 , __ ( 'The pingback has already been registered.' ));
2004-09-16 15:26:06 +02:00
2004-09-17 22:53:18 +02:00
// very stupid, but gives time to the 'from' server to publish !
sleep ( 1 );
2004-09-16 15:26:06 +02:00
2004-09-17 22:53:18 +02:00
// Let's check the remote site
2005-05-03 09:52:11 +02:00
$linea = wp_remote_fopen ( $pagelinkedfrom );
if ( ! $linea )
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 16 , __ ( 'The source URL does not exist.' ));
2004-09-16 17:20:39 +02:00
2008-03-14 20:08:09 +01:00
$linea = apply_filters ( 'pre_remote_source' , $linea , $pagelinkedto );
2004-09-17 22:53:18 +02:00
// Work around bug in strip_tags():
2005-06-04 12:15:36 +02:00
$linea = str_replace ( '<!DOC' , '<DOC' , $linea );
$linea = preg_replace ( '/[\s\r\n\t]+/' , ' ' , $linea ); // normalize spaces
$linea = preg_replace ( " / <(h1|h2|h3|h4|h5|h6|p|th|td|li|dt|dd|pre|caption|input|textarea|button|body)[^>]*>/ " , " \n \n " , $linea );
2004-09-17 22:53:18 +02:00
2005-06-04 12:15:36 +02:00
preg_match ( '|<title>([^<]*?)</title>|is' , $linea , $matchtitle );
$title = $matchtitle [ 1 ];
if ( empty ( $title ) )
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 32 , __ ( 'We cannot find a title on that page.' ));
2004-09-17 22:53:18 +02:00
2005-06-04 12:15:36 +02:00
$linea = strip_tags ( $linea , '<a>' ); // just keep the tag we need
2004-09-17 22:53:18 +02:00
2005-06-04 12:15:36 +02:00
$p = explode ( " \n \n " , $linea );
2006-02-12 08:53:23 +01:00
2006-12-27 07:10:03 +01:00
$preg_target = preg_quote ( $pagelinkedto );
2006-02-12 08:53:23 +01:00
2005-06-04 12:15:36 +02:00
foreach ( $p as $para ) {
2006-12-27 07:10:03 +01:00
if ( strpos ( $para , $pagelinkedto ) !== false ) { // it exists, but is it a link?
preg_match ( " |<a[^>]+? " . $preg_target . " [^>]*>([^>]+?)</a>| " , $para , $context );
// If the URL isn't in a link context, keep looking
if ( empty ( $context ) )
continue ;
// We're going to use this fake tag to mark the context in a bit
// the marker is needed in case the link text appears more than once in the paragraph
$excerpt = preg_replace ( '|\</?wpcontext\>|' , '' , $para );
// prevent really long link text
if ( strlen ( $context [ 1 ]) > 100 )
$context [ 1 ] = substr ( $context [ 1 ], 0 , 100 ) . '...' ;
$marker = '<wpcontext>' . $context [ 1 ] . '</wpcontext>' ; // set up our marker
$excerpt = str_replace ( $context [ 0 ], $marker , $excerpt ); // swap out the link for our marker
$excerpt = strip_tags ( $excerpt , '<wpcontext>' ); // strip all tags but our context marker
$excerpt = trim ( $excerpt );
$preg_marker = preg_quote ( $marker );
$excerpt = preg_replace ( " |.*? \ s(. { 0,100} $preg_marker . { 0,100}) \ s.*|s " , '$1' , $excerpt );
$excerpt = strip_tags ( $excerpt ); // YES, again, to remove the marker wrapper
break ;
2005-06-04 12:15:36 +02:00
}
2004-09-17 22:53:18 +02:00
}
2006-12-27 07:10:03 +01:00
if ( empty ( $context ) ) // Link to target not found
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 17 , __ ( 'The source URL does not contain a link to the target URL, and so cannot be used as a source.' ));
2005-08-03 02:30:40 +02:00
2007-09-18 18:42:25 +02:00
$pagelinkedfrom = str_replace ( '&' , '&' , $pagelinkedfrom );
2005-06-04 12:15:36 +02:00
$context = '[...] ' . wp_specialchars ( $excerpt ) . ' [...]' ;
2005-07-05 22:47:22 +02:00
$pagelinkedfrom = $wpdb -> escape ( $pagelinkedfrom );
2004-09-17 22:53:18 +02:00
2006-07-27 00:18:36 +02:00
$comment_post_ID = ( int ) $post_ID ;
2004-09-22 21:45:29 +02:00
$comment_author = $title ;
2006-07-27 00:18:36 +02:00
$this -> escape ( $comment_author );
2004-09-22 21:45:29 +02:00
$comment_author_url = $pagelinkedfrom ;
$comment_content = $context ;
2006-07-27 00:18:36 +02:00
$this -> escape ( $comment_content );
2004-09-22 21:45:29 +02:00
$comment_type = 'pingback' ;
2004-09-17 22:53:18 +02:00
2004-09-22 21:45:29 +02:00
$commentdata = compact ( 'comment_post_ID' , 'comment_author' , 'comment_author_url' , 'comment_content' , 'comment_type' );
2007-03-23 03:05:29 +01:00
$comment_ID = wp_new_comment ( $commentdata );
2006-11-24 17:39:51 +01:00
do_action ( 'pingback_post' , $comment_ID );
2006-02-12 08:53:23 +01:00
2007-05-25 17:33:47 +02:00
return sprintf ( __ ( 'Pingback from %1$s to %2$s registered. Keep the web talking! :-)' ), $pagelinkedfrom , $pagelinkedto );
2004-09-17 22:53:18 +02:00
}
2008-09-22 07:15:41 +02:00
/**
* Retrieve array of URLs that pingbacked the given URL .
*
* Specs on http :// www . aquarionics . com / misc / archives / blogite / 0198. html
*
* @ since 1.5 . 0
*
* @ param array $args Method parameters .
* @ return array
*/
2004-09-17 22:53:18 +02:00
function pingback_extensions_getPingbacks ( $args ) {
global $wpdb ;
2007-12-23 10:15:57 +01:00
do_action ( 'xmlrpc_call' , 'pingback.extensions.getPingsbacks' );
2007-12-23 02:35:44 +01:00
2005-06-29 00:16:27 +02:00
$this -> escape ( $args );
2004-09-17 22:53:18 +02:00
$url = $args ;
2007-03-23 03:05:29 +01:00
$post_ID = url_to_postid ( $url );
2004-09-17 22:53:18 +02:00
if ( ! $post_ID ) {
// We aren't sure that the resource is available and/or pingback enabled
2007-05-25 17:33:47 +02:00
return new IXR_Error ( 33 , __ ( 'The specified target URL cannot be used as a target. It either doesn\'t exist, or it is not a pingback-enabled resource.' ));
2004-09-17 22:53:18 +02:00
}
$actual_post = wp_get_single_post ( $post_ID , ARRAY_A );
if ( ! $actual_post ) {
// No such post = resource not found
2007-04-01 17:59:50 +02:00
return new IXR_Error ( 32 , __ ( 'The specified target URL does not exist.' ));
2004-09-17 22:53:18 +02:00
}
2008-04-14 18:13:25 +02:00
$comments = $wpdb -> get_results ( $wpdb -> prepare ( " SELECT comment_author_url, comment_content, comment_author_IP, comment_type FROM $wpdb->comments WHERE comment_post_ID = %d " , $post_ID ) );
2004-09-17 22:53:18 +02:00
if ( ! $comments ) {
return array ();
}
$pingbacks = array ();
foreach ( $comments as $comment ) {
2005-01-07 00:10:28 +01:00
if ( 'pingback' == $comment -> comment_type )
2004-09-17 22:53:18 +02:00
$pingbacks [] = $comment -> comment_author_url ;
2004-09-16 17:20:39 +02:00
}
2004-09-17 22:53:18 +02:00
return $pingbacks ;
2004-09-16 17:20:39 +02:00
}
2004-05-23 18:42:23 +02:00
}
2004-05-23 06:02:53 +02:00
2004-09-17 22:53:18 +02:00
$wp_xmlrpc_server = new wp_xmlrpc_server ();
2008-06-12 23:41:18 +02:00
?>