haruncpi/wp-api

An elegant WordPress REST API routing system

v1.0.1 2023-12-15 05:42 UTC

This package is not auto-updated.

Last update: 2024-05-03 07:43:25 UTC


README

68747470733a2f2f62616467656e2e6e65742f62616467652f6c6963656e63652f434320425920342e302f323342434342 68747470733a2f2f62616467656e2e6e65742f7061636b61676973742f762f686172756e6370692f77702d617069 68747470733a2f2f62616467656e2e6e65742f7061636b61676973742f64742f686172756e6370692f77702d617069

An elegant WordPress REST API routing system.

WP API

Support

Buy Me A Coffee

Documentation

Installation

composer require haruncpi/wp-api

Configuration

In your plugin init file, write this simple config code.

ApiConfig::set_route_file( __DIR__ . '/api-routes.php' )
		->set_namespace( 'MyPlugin\Api' )
		->init();

Route Define

Open api-routes.php file and write route

Syntax

ApiRoute::get( $prefix, $endpoint, $callback, $auth = false );
ApiRoute::post( $prefix, $endpoint, $callback, $auth = false );

// Multiple route in a prefix group.
ApiRoute::prefix( $prefix, function( ApiRoute $route ) {
    $route->get( $endpoint, $callback, $auth = false );
    $route->post( $endpoint, $callback, $auth = false );
});

Where

  • $prefix is your plugin name with api version. Example: myplugin/v1
  • By default, $auth is false means the endpoint can be access without authentication.
  • To make a endpoint secure pass a callback in the place of $auth

Example

ApiRoute::get( 'myplugin/v1', '/me', 'ApiController@me' );

Secure route

ApiRoute::get( 'myplugin/v1', '/me', 'ApiController@me', 'AuthController@check' );

Various way to write callback.

ApiRoute::get( 'myplugin/v1', '/me', 'ApiController@me' );
ApiRoute::get( 'myplugin/v1', '/me', array( ApiController:class, 'me' ) );
ApiRoute::get( 'myplugin/v1', '/me', array( 'MyPlugin\Api\ApiController', 'me' ) );
ApiRoute::get( 'myplugin/v1', '/me', function() {
    // Do something.
});

Multiple route register

ApiRoute::prefix( 'myplugin/v1', function( ApiRoute $route ) {
    $route->get( '/products', 'ApiController@products' );
    $route->get( '/categories', 'ApiController@categories' );
});

With auth check

// With auth check
ApiRoute::prefix( 'myplugin/v1', function( ApiRoute $route ) {
    $route->get( '/me', 'ApiController@me' );
    $route->get( '/settings', 'ApiController@settings' );
    $route->post( '/logout', 'ApiController@logout' );
})->auth( 'AuthController@check' );

Plugin Example

API Plugin is a WordPress example plugin for this composer package.