2017 © Pedro Peláez
 

library laravel-jsonrpc

Laravel JSON-RPC 2.0 Server

image

upgate/laravel-jsonrpc

Laravel JSON-RPC 2.0 Server

  • Wednesday, March 7, 2018
  • by upgate
  • Repository
  • 2 Watchers
  • 15 Stars
  • 1,872 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 3 Forks
  • 0 Open issues
  • 14 Versions
  • 48 % Grown

The README.md

JSON-RPC Server for Laravel/Lumen

Build Status StandWithUkraine, (*1)

Stand With Ukraine, (*2)

📢 Updates from Ukrainian Open Source Community

🇷🇺 Обращение к гражданам России

Quick How-To

  • Install with composer: composer require upgate/laravel-jsonrpc
  • In your RouteServiceProvider, do something like this:
// ...
use Upgate\LaravelJsonRpc\Contract\ServerInterface as JsonRpcServerContract;

class RouteServiceProvider extends ServiceProvider
{
    // ...
    public function map(Router $router)
    {
        $router->group(
            ['namespace' => $this->namespace],
            function (Router $router) {
                // Create an instance of JsonRpcServer
                $jsonRpcServer = $this->app->make(JsonRpcServerContract::class);
                // Set default controller namespace
                $jsonRpcServer->setControllerNamespace($this->namespace);
                // Register middleware aliases configured for Laravel router
                $jsonRpcServer->registerMiddlewareAliases($router->getMiddleware());

                require app_path('Http/routes.php');
            }
        );
    }
}
  • Use $jsonRpcServer in your routes.php, like this:
$router->post('/jsonrpc', function (Illuminate\Http\Request $request) use ($jsonRpcServer) {
    $jsonRpcServer->router()
        ->addMiddlewares(['fooMiddleware', 'barMiddleware', 'auth:rpcGuard']) // Middleware alias names or class names.
                                                                              // Parameters may be specified by separating
                                                                              // the middleware name and parameters with a :
        ->bindController('foo', 'FooController') // for 'foo.$method' methods invoke FooController->$method(),
                                                 // for 'foo' method invoke FooConroller->index()
        ->bind('bar', 'MyController@bar') // for 'bar' method invoke MyController->bar()
        ->group(
            ['bazMiddleware'], // add bazMiddleware for methods in this group
            function ($jsonRpcRouter) {
                // for 'bar.baz' method invoke MyController->bazz()
                $jsonRpcRouter->bind('bar.baz', 'MyController@bazz');
            }
        );

    // Run json-rpc server with $request passed to middlewares as a handle() method argument
    return $jsonRpcServer->run($request);
});

See ServerTest and RouterTest for more examples., (*3)

Exception handling

Descendants of Upgate\LaravelJsonRpc\Exception\JsonRpcException represent JSON-RPC errors according to the spec (see Upgate\LaravelJsonRpc\Server\ErrorCode)., (*4)

Other exceptions are logged and converted to INTERNAL_ERROR responses by default., (*5)

Use Upgate\LaravelJsonRpc\Server\Server::onException() to register custom exception handlers:, (*6)

use Upgate\LaravelJsonRpc\Server;

$jsonRpcServer->onException(
    SomeExceptionClass::class,
    function (SomeExceptionClass $e, Server\Request $request = null) {
        $message = "Some Message";
        $code = -32099;
        return Server\RequestResponse::constructErrorResponse($request ? $request->getId() : null, $message, $code);
    }
);

$jsonRpcServer->onException(
    \Throwable::class, // catch-all
    function (\Throwable $e, Server\Request $request = null) {
        $message = "Some Other Message";
        $code = -32098;
        return Server\RequestResponse::constructErrorResponse($request ? $request->getId() : null, $message, $code);
    }
);

See ServerTest:: testSingleRequestWithExceptionHandler() and ServerTest::testExceptionHandlersPriority() for more examples., (*7)

JSON-RPC Request Forms

(since v0.3.0), (*8)

Upgate\LaravelJsonRpc\Server\FormRequest is similar to Laravel form requests, but validates JSON-RPC parameters instead., (*9)

Example:, (*10)

use Upgate\LaravelJsonRpc\Server\FormRequest as JsonRpcFormRequest;

class MyJsonRpcFormRequest extends JsonRpcFormRequest
{
    public function rules(): array
    {
        return [
            'id'    => 'required|numeric',
            'email' => 'required|email',
        ];
    }
}

class MyController
{
    public function myAction(MyJsonRpcFormRequest $jsonRpcRequest)
    {
        $email = $jsonRpcRequest->email; // or $jsonRpcRequest->get('email');
        $allParams = $jsonRpcRequest->all();
        // ...
    }
}

If validation fails, the INVALID_PARAMS error response is returned, with validation error details in data.violations., (*11)

See the ServerFormRequestTest for more examples., (*12)

The Versions

09/02 2018

dev-feature/form-request

dev-feature/form-request

Laravel JSON-RPC 2.0 Server

  Sources   Download

BSD-2-Clause

The Requires

 

The Development Requires

laravel json-rpc

18/01 2018

0.2.2

0.2.2.0

Laravel JSON-RPC 2.0 Server

  Sources   Download

BSD-2-Clause

The Requires

 

The Development Requires

laravel json-rpc

18/01 2018

dev-fix/require-php71

dev-fix/require-php71

Laravel JSON-RPC 2.0 Server

  Sources   Download

BSD-2-Clause

The Requires

 

The Development Requires

laravel json-rpc

02/10 2017

0.2.1

0.2.1.0

Laravel JSON-RPC 2.0 Server

  Sources   Download

BSD-2-Clause

The Requires

 

The Development Requires

laravel json-rpc

30/09 2017

0.2.0

0.2.0.0

Laravel JSON-RPC 2.0 Server

  Sources   Download

BSD-2-Clause

The Requires

 

The Development Requires

laravel json-rpc

21/08 2016

0.1.6

0.1.6.0

Laravel JSON-RPC 2.0 Server

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel json-rpc

03/11 2015

0.1.5

0.1.5.0

Laravel JSON-RPC 2.0 Server

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel json-rpc

03/11 2015

0.1.4

0.1.4.0

Laravel JSON-RPC 2.0 Server

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel json-rpc

02/11 2015

0.1.3

0.1.3.0

Laravel JSON-RPC 2.0 Adapter

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel json-rpc

02/11 2015

0.1.2

0.1.2.0

Laravel JSON-RPC 2.0 Adapter

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel json-rpc

02/11 2015

0.1.1

0.1.1.0

Laravel JSON-RPC 2.0 Adapter

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel json-rpc

02/11 2015

0.1.0

0.1.0.0

Laravel JSON-RPC 2.0 Adapter

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel json-rpc