sakura/app/routers/api-router.php

364 lines
10 KiB
PHP

<?php
namespace Sakura\Routers;
use WP_REST_Controller;
use WP_REST_Server;
use Sakura\Controllers\ConfigurationController;
use Sakura\Controllers\InitStateController;
use Sakura\Controllers\MenuController;
use Sakura\Controllers\PostController;
use Sakura\Controllers\AuthorController;
use Sakura\Controllers\MediaController;
use Sakura\Controllers\CategoryController;
use Sakura\Controllers\TagController;
use Sakura\Controllers\CommentController;
use Sakura\Lib\ClassWpRestCommentsController;
use Sakura\Lib\ClassWpRestPostsController;
class ApiRouter extends WP_REST_Controller
{
public function __construct()
{
$this->namespace = 'sakura/v1';
$this->register_rest_routes();
$this->register_rest_fields();
}
/**
* Add routers
* @since 1.0.0
* @license MIT
* @author mashirozx <moezhx@outlook.com>
*/
public function register_rest_routes()
{
add_action('rest_api_init', [new ConfigurationController(), 'register_routes']);
add_action('rest_api_init', function () {
// theme's initial states
register_rest_route(
$this->namespace,
'/init-state',
[
'methods' => WP_REST_Server::READABLE,
'callback' => [new InitStateController(), 'show'],
'permission_callback' => function () {
return true;
}
]
);
// get menu items
register_rest_route(
$this->namespace,
'/menu',
[
'methods' => WP_REST_Server::READABLE,
'callback' => [new MenuController(), 'show'],
'permission_callback' => function () {
return true;
}
]
);
// initial comment ancestor meta
// TODO: AUTH
register_rest_route(
$this->namespace,
'/init-comments-ancestor-meta',
[
'methods' => WP_REST_Server::READABLE,
'callback' => [new InitStateController(), 'init_ancestor_meta_show'],
'permission_callback' => function () {
return true;
}
]
);
// initial comment ua info meta
// TODO: AUTH
register_rest_route(
$this->namespace,
'/init-comments-user-agent-info-meta',
[
'methods' => WP_REST_Server::READABLE,
'callback' => [new InitStateController(), 'init_user_agent_info_meta_show'],
'permission_callback' => function () {
return true;
}
]
);
$rest_comments_controller = new ClassWpRestCommentsController();
// custom create comment
register_rest_route(
$this->namespace,
'/comments',
[
'methods' => WP_REST_Server::CREATABLE,
'callback' => [$rest_comments_controller, 'create_item'],
'permission_callback' => [$rest_comments_controller, 'create_item_permissions_check'],
]
);
// custom edit comment
register_rest_route(
$this->namespace,
'/comments' . '/(?P<id>[\d]+)',
array(
'args' => array(
'id' => array(
'description' => __('Unique identifier for the comment.'),
'type' => 'integer',
),
),
array(
'methods' => WP_REST_Server::EDITABLE,
'callback' => [$rest_comments_controller, 'update_item'],
'permission_callback' => [$rest_comments_controller, 'update_item_permissions_check'],
'args' => $this->get_endpoint_args_for_item_schema(WP_REST_Server::EDITABLE),
),
array(
'methods' => WP_REST_Server::DELETABLE,
'callback' => [$rest_comments_controller, 'delete_item'],
'permission_callback' => [$rest_comments_controller, 'delete_item_permissions_check'],
'args' => array(
'force' => array(
'type' => 'boolean',
'default' => false,
'description' => __('Whether to bypass Trash and force deletion.'),
),
'password' => array(
'description' => __('The password for the parent post of the comment (if the post is password protected).'),
'type' => 'string',
),
),
),
'schema' => array($this, 'get_public_item_schema'),
)
);
// @deprecated using PostQueryHelper instaed
// $rest_posts_controller = new ClassWpRestPostsController('post');
// custom get posts by category slugs
// register_rest_route(
// $this->namespace,
// '/posts',
// array(
// array(
// 'methods' => WP_REST_Server::READABLE,
// 'callback' => array($rest_posts_controller, 'get_items'),
// 'permission_callback' => array($rest_posts_controller, 'get_items_permissions_check'),
// 'args' => $rest_posts_controller->get_collection_params_mod(),
// ),
// array(
// 'methods' => WP_REST_Server::CREATABLE,
// 'callback' => array($rest_posts_controller, 'create_item'),
// 'permission_callback' => array($rest_posts_controller, 'create_item_permissions_check'),
// 'args' => $rest_posts_controller->get_endpoint_args_for_item_schema(WP_REST_Server::CREATABLE),
// ),
// 'schema' => array($rest_posts_controller, 'get_public_item_schema_mod'),
// )
// );
});
}
/**
* Add fields to existing endpoint
* @since 1.0.0
* @license MIT
* @author mashirozx <moezhx@outlook.com>
*/
public function register_rest_fields()
{
// add fields to /posts & /pages endpoint
add_action('rest_api_init', function () {
$this->register_wp_post_rest_fields(['post', 'page']);
});
// add fields to /comments endpoint
add_action('rest_api_init', function () {
$this->register_wp_comment_rest_fields(['comment']);
});
}
/**
* Common method of adding rest api fields to WP_POST output
*
* @param array $object_type
* @return void
*/
public function register_wp_post_rest_fields(array $object_type)
{
/**
* Add comment_count field to $post
*/
register_rest_field(
$object_type,
'comment_count',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return PostController::get_comments_number($post['id']);
},
'update_callback' => null,
'schema' => null
]
);
register_rest_field(
$object_type,
'view_count',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return PostController::get_post_views($post['id']);
},
'update_callback' => null,
'schema' => null
]
);
register_rest_field(
$object_type,
'words_count',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return PostController::get_post_word_count($post['id']);
},
'update_callback' => null,
'schema' => null
]
);
/**
* Add markdown field to $post['content]
*/
register_rest_field(
$object_type,
'content',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return PostController::rest_api_post_content_filter($post);
},
'update_callback' => null,
'schema' => null
]
);
/**
* Add plain field to $post['excerpt]
*/
register_rest_field(
$object_type,
'excerpt',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return PostController::rest_api_post_excerpt_filter($post);
},
'update_callback' => null,
'schema' => null
]
);
register_rest_field(
$object_type,
'author_meta',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return AuthorController::get_author_meta($post['author']);
},
'update_callback' => null,
'schema' => null
]
);
register_rest_field(
$object_type,
'featured_media_meta',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return MediaController::get_attachment_metadata($post['featured_media']);
},
'update_callback' => null,
'schema' => null
]
);
register_rest_field(
$object_type,
'categories_meta',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return CategoryController::get_the_category($post['id']);
},
'update_callback' => null,
'schema' => null
]
);
register_rest_field(
$object_type,
'tags_meta',
[
'get_callback' => function ($post, $attr, $request, $object_type) {
return TagController::get_the_tags($post['id']);
},
'update_callback' => null,
'schema' => null
]
);
// end of public func
}
/**
* Common method of adding rest api fields to WP_COMMENT output
*
* @param array $object_type
* @return void
*/
public static function register_wp_comment_rest_fields(array $object_type)
{
/**
* Add markdown field to $post['content]
*/
register_rest_field(
$object_type,
'content',
[
'get_callback' => function ($comment, $attr, $request, $object_type) {
return CommentController::rest_api_comment_content_filter($comment);
},
'update_callback' => null,
'schema' => null
]
);
// get the custom meta fields
register_rest_field(
$object_type,
'meta_fields',
[
'get_callback' => function ($comment, $attr, $request, $object_type) {
return CommentController::get_comment_meta_fields($comment['id']);
},
'update_callback' => null,
'schema' => null
]
);
// get comment children preview
// register_rest_field(
// $object_type,
// 'children_preview',
// [
// 'get_callback' => function ($comment, $attr, $request, $object_type) {
// return CommentController::get_comment_children($comment['id'], 3, 1, 0, 'DESC');
// },
// 'update_callback' => null,
// 'schema' => null
// ]
// );
}
}