WordPress.org

Make WordPress Core

Changeset 20271


Ignore:
Timestamp:
03/23/12 17:53:14 (3 years ago)
Author:
westi
Message:

XMLRPC: Add new wp.getPostType and wp.getPostTypes apis. See #18436 props maxcutler, markoheijnen and nprasath002.

Location:
trunk/wp-includes
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/wp-includes/class-wp-xmlrpc-server.php

    r20270 r20271  
    7777            'wp.getMediaLibrary'    => 'this:wp_getMediaLibrary', 
    7878            'wp.getPostFormats'     => 'this:wp_getPostFormats', 
     79            'wp.getPostType'        => 'this:wp_getPostType', 
     80            'wp.getPostTypes'       => 'this:wp_getPostTypes', 
    7981 
    8082            // Blogger API 
     
    342344                'readonly'      => true, 
    343345                'option'        => 'stylesheet' 
     346            ), 
     347            'featured_image'    => array( 
     348                'desc'          => __('Featured Image'), 
     349                'readonly'      => true, 
     350                'value'         => current_theme_supports( 'post-thumbnails' ) 
    344351            ), 
    345352            'featured_image'    => array( 
     
    628635 
    629636    /** 
     637     * Prepares post data for return in an XML-RPC object. 
     638     * 
     639     * @access protected 
     640     * 
     641     * @param array|object $post_type The unprepared post type data 
     642     * @param array $fields The subset of post fields to return 
     643     * @return array The prepared post type data 
     644     */ 
     645    protected function _prepare_post_type( $post_type, $fields ) { 
     646        $post_type = (array) $post_type; 
     647 
     648        $_post_type = array( 
     649            'name' => $post_type['name'], 
     650            'label' => $post_type['label'], 
     651            'description' => $post_type['description'], 
     652            'hierarchical' => $post_type['hierarchical'], 
     653            'public' => $post_type['public'], 
     654            '_builtin' => $post_type['_builtin'], 
     655            'supports' => get_all_post_type_supports( $post_type['name'] ) 
     656        ); 
     657 
     658        if ( in_array( 'labels', $fields ) ) { 
     659            $_post_type['labels'] = (array) $post_type['labels']; 
     660        } 
     661 
     662        if ( in_array( 'capabilities', $fields ) ) { 
     663            $_post_type['cap'] = (array) $post_type['cap']; 
     664            $_post_type['capability_type'] = $post_type['capability_type']; 
     665            $_post_type['map_meta_cap'] = $post_type['map_meta_cap']; 
     666        } 
     667 
     668        if ( in_array( 'admin', $fields ) ) { 
     669            $_post_type['publicly_queryable'] = $post_type['publicly_queryable']; 
     670            $_post_type['exclude_from_search'] = $post_type['exclude_from_search']; 
     671            $_post_type['_edit_link'] = $post_type['_edit_link']; 
     672            $_post_type['rewrite'] = $post_type['rewrite']; 
     673            $_post_type['has_archive'] = $post_type['has_archive']; 
     674            $_post_type['query_var'] = $post_type['query_var']; 
     675        } 
     676 
     677        if ( in_array( 'menu', $fields ) ) { 
     678            $_post_type['show_ui'] = $post_type['show_ui']; 
     679            $_post_type['menu_position'] = $post_type['menu_position']; 
     680            $_post_type['menu_icon'] = $post_type['menu_icon']; 
     681            $_post_type['show_in_nav_menus'] = $post_type['show_in_nav_menus']; 
     682            $_post_type['show_in_menu'] = $post_type['show_in_menu']; 
     683            $_post_type['show_in_admin_bar'] = $post_type['show_in_admin_bar']; 
     684        } 
     685 
     686        if ( in_array( 'taxonomies', $fields ) ) { 
     687            $_post_type['taxonomies'] = get_object_taxonomies( $_post_type['name'] ); 
     688        } 
     689 
     690        return apply_filters( 'xmlrpc__prepare_post_type', $_post_type, $post_type ); 
     691    } 
     692 
     693    /** 
    630694     * Create a new post for any registered post type. 
    631695     * 
     
    28812945 
    28822946        return $formats; 
     2947    } 
     2948 
     2949    /** 
     2950     * Retrieves a post type 
     2951     * 
     2952     * @uses get_post_type_object() 
     2953     * @param array $args Method parameters. Contains: 
     2954     *  - int     $blog_id 
     2955     *  - string  $username 
     2956     *  - string  $password 
     2957     *  - string  $post_type_name 
     2958     *  - array   $fields 
     2959     * @return array contains: 
     2960     *  - 'labels' 
     2961     *  - 'description' 
     2962     *  - 'capability_type' 
     2963     *  - 'cap' 
     2964     *  - 'map_meta_cap' 
     2965     *  - 'hierarchical' 
     2966     *  - 'menu_position' 
     2967     *  - 'taxonomies' 
     2968     *  - 'supports' 
     2969     */ 
     2970    function wp_getPostType( $args ) { 
     2971        $this->escape( $args ); 
     2972 
     2973        $blog_id        = (int) $args[0]; 
     2974        $username       = $args[1]; 
     2975        $password       = $args[2]; 
     2976        $post_type_name = $args[3]; 
     2977 
     2978        if ( isset( $args[4] ) )  
     2979            $fields = $args[4];  
     2980        else  
     2981            $fields = apply_filters( 'xmlrpc_default_posttype_fields', array( 'labels', 'capabilities', 'taxonomies' ), 'wp.getPostType' );  
     2982 
     2983        if ( !$user = $this->login( $username, $password ) ) 
     2984            return $this->error; 
     2985 
     2986        do_action( 'xmlrpc_call', 'wp.getPostType' ); 
     2987 
     2988        if( ! post_type_exists( $post_type_name ) ) 
     2989            return new IXR_Error( 403, __( 'Invalid post type.' ) ); 
     2990 
     2991        $post_type = get_post_type_object( $post_type_name ); 
     2992 
     2993        if( ! current_user_can( $post_type->cap->edit_posts ) ) 
     2994            return new IXR_Error( 401, __( 'Sorry, you are not allowed to edit this post type.' ) ); 
     2995 
     2996        return $this->_prepare_post_type( $post_type, $fields ); 
     2997    } 
     2998 
     2999    /** 
     3000     * Retrieves a post types 
     3001     * 
     3002     * @access private 
     3003     * 
     3004     * @uses get_post_types() 
     3005     * @param array $args Method parameters. Contains: 
     3006     *  - int     $blog_id 
     3007     *  - string  $username 
     3008     *  - string  $password 
     3009     *  - array   $filter 
     3010     *  - array   $fields 
     3011     * @return array 
     3012     */ 
     3013    function wp_getPostTypes( $args ) { 
     3014        $this->escape( $args ); 
     3015 
     3016        $blog_id            = (int) $args[0]; 
     3017        $username           = $args[1]; 
     3018        $password           = $args[2]; 
     3019        $filter             = isset( $args[3] ) ? $args[3] : array( 'public' => true );  
     3020 
     3021        if ( isset( $args[4] ) )  
     3022            $fields = $args[4];  
     3023        else  
     3024            $fields = apply_filters( 'xmlrpc_default_posttype_fields', array( 'labels', 'capabilities', 'taxonomies' ), 'wp.getPostTypes' );  
     3025 
     3026        if ( ! $user = $this->login( $username, $password ) ) 
     3027            return $this->error; 
     3028 
     3029        do_action( 'xmlrpc_call', 'wp.getPostTypes' ); 
     3030 
     3031        $post_types = get_post_types( $filter, 'objects' ); 
     3032 
     3033        $struct = array(); 
     3034 
     3035        foreach( $post_types as $post_type ) { 
     3036            if( ! current_user_can( $post_type->cap->edit_posts ) ) 
     3037                continue; 
     3038 
     3039            $struct[$post_type->name] = $this->_prepare_post_type( $post_type, $fields ); 
     3040        } 
     3041 
     3042        return $struct; 
    28833043    } 
    28843044 
  • trunk/wp-includes/post.php

    r20216 r20271  
    13011301 
    13021302/** 
     1303 * Get all the post type features 
     1304 * 
     1305 * @since 3.4.0 
     1306 * @param string $post_type The post type 
     1307 * @return array 
     1308 */ 
     1309 
     1310function get_all_post_type_supports( $post_type ) { 
     1311    global $_wp_post_type_features; 
     1312 
     1313    if ( isset( $_wp_post_type_features[$post_type] ) ) 
     1314        return $_wp_post_type_features[$post_type]; 
     1315 
     1316    return array(); 
     1317} 
     1318 
     1319/** 
    13031320 * Checks a post type's support for a given feature 
    13041321 * 
Note: See TracChangeset for help on using the changeset viewer.