Si vous trouvez quelque chose que vous ne comprenez pas, vous pouvez le laisser dans les commentaires et nous essaierons de vous aider rapidement.
Classe de base utilisée pour accéder aux statuts des messages via l'API REST.
Description
Voir aussi
- WP_REST_Controller
Source
Fichier : wp-includes/rest-api/endpoints/class-wp-rest-post-statuses-controller.php
classWP_REST_Post_Statuses_ControllerextendsWP_REST_Controller{/** * Constructor. * * @since 4.7.0 */publicfunction__construct(){$this->namespace='wp/v2';$this->rest_base='statuses';}/** * Registers the routes for the objects of the controller. * * @since 4.7.0 * * @see register_rest_route() */publicfunctionregister_routes(){register_rest_route($this->namespace,'/'$this->rest_base,array(array('methods'=>WP_REST_Server::READABLE,'callback'=>array($this,'get_items'),'permission_callback'=>array($this,'get_items_permissions_check'),'args'=>$this->get_collection_params(),),'schema'=>array($this,'get_public_item_schema'),));register_rest_route($this->namespace,'/'$this->rest_base'/(?P[w-]+)' ,array('args'=>array('status'=>array('description'=>__('An alphanumeric identifier for the status.'),'type'=>'string',),),array('methods'=>WP_REST_Server::READABLE,'callback'=>array($this,'get_item'),'permission_callback'=>array($this,'get_item_permissions_check'),'args'=>array('context'=>$this->get_context_param(array('default'=>'view')),),),'schema'=>array($this,'get_public_item_schema'),));}/** * Checks whether a given request has permission to read post statuses. * * @since 4.7.0 * * @param WP_REST_Request $request Full details about the request. * @return true|WP_Error True if the request has read access, WP_Error object otherwise. */publicfunctionget_items_permissions_check($request){if('edit'===$request['context']){$types=get_post_types(array('show_in_rest'=>true),'objects');foreach($typesas$type){if(current_user_can($type->cap->edit_posts)){returntrue;}}returnnewWP_Error('rest_cannot_view',__('Sorry, you are not allowed to manage post statuses.'),array('status'=>rest_authorization_required_code()));}returntrue;}/** * Retrieves all post statuses, depending on user context. * * @since 4.7.0 * * @param WP_REST_Request $request Full details about the request. * @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure. */publicfunctionget_items($request){$data=array();$statuses=get_post_stati(array('internal'=>false),'object');$statuses['trash']=get_post_status_object('trash');foreach($statusesas$slug=>$obj){$ret=$this->check_read_permission($obj);if(!$ret){continue;}$status=$this->prepare_item_for_response($obj,$request);$data[$obj->name]=$this->prepare_response_for_collection($status);}returnrest_ensure_response($data);}/** * Checks if a given request has access to read a post status. * * @since 4.7.0 * * @param WP_REST_Request $request Full details about the request. * @return true|WP_Error True if the request has read access for the item, WP_Error object otherwise. */publicfunctionget_item_permissions_check($request){$status=get_post_status_object($request['status']);if(empty($status)){returnnewWP_Error('rest_status_invalid',__('Invalid status.'),array('status'=>404));}$check=$this->check_read_permission($status);if(!$check){returnnewWP_Error('rest_cannot_read_status',__('Cannot view status.'),array('status'=>rest_authorization_required_code()));}returntrue;}/** * Checks whether a given post status should be visible. * * @since 4.7.0 * * @param object $status Post status. * @return bool True if the post status is visible, otherwise false. */protectedfunctioncheck_read_permission($status){if(true===$status->public){returntrue;}if(false===$status->internal||'trash'===$status->name){$types=get_post_types(array('show_in_rest'=>true),'objects');foreach($typesas$type){if(current_user_can($type->cap->edit_posts)){returntrue;}}}returnfalse;}/** * Retrieves a specific post status. * * @since 4.7.0 * * @param WP_REST_Request $request Full details about the request. * @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure. */publicfunctionget_item($request){$obj=get_post_status_object($request['status']);if(empty($obj)){returnnewWP_Error('rest_status_invalid',__('Invalid status.'),array('status'=>404));}$data=$this->prepare_item_for_response($obj,$request);returnrest_ensure_response($data);}/** * Prepares a post status object for serialization. * * @since 4.7.0 * * @param stdClass $status Post status data. * @param WP_REST_Request $request Full details about the request. * @return WP_REST_Response Post status data. */publicfunctionprepare_item_for_response($status,$request){$fields=$this->get_fields_for_response($request);$data=array();if(in_array('name',$fields,true)){$data['name']=$status->label;}if(in_array('private',$fields,true)){$data['private']=(bool)$status->private;}if(in_array('protected',$fields,true)){$data['protected']=(bool)$status->protected;}if(in_array('public',$fields,true)){$data['public']=(bool)$status->public;}if(in_array('queryable',$fields,true)){$data['queryable']=(bool)$status->publicly_queryable;}if(in_array('show_in_list',$fields,true)){$data['show_in_list']=(bool)$status->show_in_admin_all_list;}if(in_array('slug',$fields,true)){$data['slug']=$status->name;}if(in_array('date_floating',$fields,true)){$data['date_floating']=$status->date_floating;}$context=!empty($request['context'])?$request['context']:'view';$data=$this->add_additional_fields_to_object($data,$request);$data=$this->filter_response_by_context($data,$context);$response=rest_ensure_response($data);if('publish'===$status->name){$response->add_link('archives',rest_url('wp/v2/posts'));}else{$response->add_link('archives',add_query_arg('status',$status->name,rest_url('wp/v2/posts')));}/** * Filters a post status returned from the REST API. * * Allows modification of the status data right before it is returned. * * @since 4.7.0 * * @param WP_REST_Response $response The response object. * @param object $status The original post status object. * @param WP_REST_Request $request Request used to generate the response. */returnapply_filters('rest_prepare_status',$response,$status,$request);}/** * Retrieves the post status' schema, conforming to JSON Schema. * * @since 4.7.0 * * @return array Item schema data. */publicfunctionget_item_schema(){if($this->schema){return$this->add_additional_fields_schema($this->schema);}$schema=array('$schema'=>'http://json-schema.org/draft-04/schema#','title'=>'status','type'=>'object','properties'=>array('name'=>array('description'=>__('The title for the status.'),'type'=>'string','context'=>array('embed','view','edit'),'readonly'=>true,),'private'=>array('description'=>__('Whether posts with this status should be private.'),'type'=>'boolean','context'=>array('edit'),'readonly'=>true,),'protected'=>array('description'=>__('Whether posts with this status should be protected.'),'type'=>'boolean','context'=>array('edit'),'readonly'=>true,),'public'=>array('description'=>__('Whether posts of this status should be shown in the front end of the site.'),'type'=>'boolean','context'=>array('view','edit'),'readonly'=>true,),'queryable'=>array('description'=>__('Whether posts with this status should be publicly-queryable.'),'type'=>'boolean','context'=>array('view','edit'),'readonly'=>true,),'show_in_list'=>array('description'=>__('Whether to include posts in the edit listing for their post type.'),'type'=>'boolean','context'=>array('edit'),'readonly'=>true,),'slug'=>array('description'=>__('An alphanumeric identifier for the status.'),'type'=>'string','context'=>array('embed','view','edit'),'readonly'=>true,),'date_floating'=>array('description'=>__('Whether posts of this status may have floating published dates.'),'type'=>'boolean','context'=>array('view','edit'),'readonly'=>true,),),);$this->schema=$schema;return$this->add_additional_fields_schema($this->schema);}/** * Retrieves the query params for collections. * * @since 4.7.0 * * @return array Collection parameters. */publicfunctionget_collection_params(){returnarray('context'=>$this->get_context_param(array('default'=>'view')),);}}
Related
Utilise
Utilisations | Description |
---|---|
wp-includes/rest-api/endpoints/class-wp-rest-controller.php : WP_REST_Controller |
Contrôleur de base principal pour gérer et interagir avec les éléments de l'API REST. |
Méthodes
- __construct - Constructeur.
- check_read_permission - Vérifie si un statut de post donné doit être visible.
- get_collection_params - Récupère les paramètres de requête pour les collections.
- get_item - Récupère un statut de message spécifique.
- get_item_permissions_check - Vérifie si une requête donnée a l'accès pour lire un post status.
- get_item_schema - Récupère le schéma du post status', conforme au schéma JSON.
- get_items - Récupère tous les statuts de post, en fonction du contexte de l'utilisateur.
- get_items_permissions_check - Vérifie si une requête donnée a la permission de lire les statuts de post.
- prepare_item_for_response - Prépare un objet de statut de post pour la sérialisation.
- register_routes - Enregistre les routes pour les objets du contrôleur.
Changelog
Version | Description |
---|---|
4.7.0 | Introduit. |
Avis et notes
Nous serions ravis que vous puissiez partager cet article s'il vous a aidé.