README.md

# JSONRPC2.Plug

An Elixir `plug` library for extending an HTTP server with JSONRPC 2.0 protocol services. It's HTTP transport level. For use both in the Phoenix application and pure `plug`-compatable server.

## Installation

The package can be installed by adding `jsonrpc2_plug` to your list of dependencies in `mix.exs`:

```elixir
def deps do
  [
    {:jsonrpc2_plug, "~> 2.0.0"}
  ]
end
```

## Usage

### Services

It uses [`jsonrpc2_service`](https://github.com/undr/jsonrpc2_service) library for service creation.

### Pure `plug`-compatable server

```elixir
use Plug.Router

forward "/jsonrpc", to: JSONRPC2.Plug, init_opts: CalculatorService
```

`CalculatorService` is a service build by [`jsonrpc2_service`](https://github.com/undr/jsonrpc2_service) library

You can handle errors outside of `plug`. Add `Plug.ErrorHandler` into a router and define `&handle_errors/2` function ([read more](https://hexdocs.pm/plug/Plug.ErrorHandler.html)). 

```elixir
  use Plug.ErrorHandler

  @impl Plug.ErrorHandler
  def handle_errors(conn, %{kind: kind, reason: reason, stack: stacktrace}) do
    kind |> Exception.format(reason, stacktrace) |> Logger.error()

    case conn do
      %{request_path: "/jsonrpc"} ->
        JSONRPC2.Plug.send_error(conn, kind, reason)

      _ ->
        send_resp(conn, 500, "Someting went wrong")
    end
  end
```

### Phoenix server

```elixir

forward "/jsonrpc", JSONRPC2.Plug, CalculatorService
```

Documentation can be generated with [ExDoc](https://github.com/elixir-lang/ex_doc)
and published on [HexDocs](https://hexdocs.pm). Once published, the docs can
be found at [https://hexdocs.pm/jsonrpc2_plug](https://hexdocs.pm/jsonrpc2_plug).