felixfbecker / advanced-json-rpc
A more advanced JSONRPC implementation
Installs: 58 833 531
Dependents: 8
Suggesters: 0
Security: 0
Stars: 254
Watchers: 6
Forks: 16
Open Issues: 16
Requires
- php: ^7.1 || ^8.0
- netresearch/jsonmapper: ^1.0 || ^2.0 || ^3.0 || ^4.0
- phpdocumentor/reflection-docblock: ^4.3.4 || ^5.0.0
Requires (Dev)
- phpunit/phpunit: ^7.0 || ^8.0
- dev-master
- v3.2.1
- v3.2.0
- v3.1.2
- v3.1.1
- v3.1.0
- v3.0.4
- v3.0.3
- v3.0.2
- v3.0.1
- v3.0.0
- v2.0.3
- v2.0.2
- v2.0.1
- v2.0.0
- v1.2.10
- v1.2.9
- v1.2.8
- v1.2.7
- v1.2.6
- v1.2.5
- v1.2.4
- v1.2.3
- v1.2.2
- v1.2.1
- v1.2.0
- v1.1.0
- v1.0.0
- dev-semantic-release-15.0.0-126.1.0
- dev-semantic-release-14.0.0-121.1.0
- dev-semantic-release-13.0.0-104.1.0
- dev-semantic-release-12.0.0-78.1.0
- dev-semantic-release-11.0.0-40.1.0
- dev-@semantic-release/last-release-git-tag-2.0.0-40.1.0
- dev-semantic-release-10
- dev-phpdocumentor/reflection-docblock-4.0.0-#2.0.0
This package is auto-updated.
Last update: 2024-10-12 05:51:30 UTC
README
Provides basic classes for requests and responses in JSONRPC and a Dispatcher
class that can decode a JSONRPC request
and call appropriate methods on a target, coercing types of parameters by type-hints and @param
tags.
Supports nested targets: If the method is something like myNestedTarget->theMethod
, the dispatcher will look for a
myNestedTarget
property on the target and call theMethod
on it. The delimiter is configurable and defaults to the
PHP object operator ->
.
Example
use AdvancedJsonRpc\Dispatcher; class Argument { public $aProperty; } class Target { public function someMethod(Argument $arg) { // $arg instanceof Argument === true // $arg->aProperty === 123 return 'Hello World'; } } $dispatcher = new Dispatcher(new Target()); $result = $dispatcher->dispatch(' { "jsonrpc": "2.0", "id": 1, "method": "someMethod", "params": { "arg": {"aProperty": 123} } } '); // $result === "Hello World"
Nested Targets
use AdvancedJsonRpc\Dispatcher; class TextDocumentManager { public function didOpen(string $uri) { return 'Thank you for this information'; } } class LanguageServer { public $textDocument; public function __construct() { $this->textDocument = new TextDocumentManager(); } } $dispatcher = new Dispatcher(new LanguageServer(), '/'); $result = $dispatcher->dispatch(' { "jsonrpc": "2.0", "id": 1, "method": "textDocument/didOpen", "params": { "uri": "file:///c/Users/felix/test.php" } } '); // $result === "Thank you for this information"