hametuha/rest-pattern

Rest API Patten class for easy create rest-api based WordPress

Installs: 7 360

Dependents: 2

Suggesters: 0

Security: 0

Stars: 0

Watchers: 2

Forks: 0

Open Issues: 0

Language:Shell

Type:wordpress-library

1.1.1 2022-12-05 06:30 UTC

This package is auto-updated.

Last update: 2024-04-05 09:08:20 UTC


README

Rest API Pattern class for easy create rest-api based WordPress.

Travis CI

Installation

composer require haemtuha/rest-pattern

Then include autoload.php in your themes or plugins.

Implementation

This library is abstarct class for REST API. Inherit this class like below:

<?php
namespace Vendor\Library\RestApi;

use Hametuha\RestPattern\RestApiBase;

class UsersApi extends RestApiBase {

	protected $namespace = 'vendor';

	protectd $route = 'user/(?P<user_id>\d+)';

	protected function get_args( $request ) {
		return [
			'user_id' => [
				'required' => true,
				'validate_callback' => function( $var ) {
					return $var && get_userdata( $var );
				}
			],
		];
	}
	
	protected function handle_get( $request ) {
		return [
			'success' => true,
			'user' => get_userdata( $request->get_param( 'user_id' ) ),
		];
	}

}

handle_*** method will handel your request. They should return JSON convertible object(array, object), WP_REST_Restponse, or WP_Error. Alternatively, you can throw Exception in request handler and then will be automatically converted to WP_Error.

License

GPL 3.0 or later.