Boltx.ResponseEncoder (Boltx v0.0.6)
This module provides functions to encode a query result or data containing Boltx.Types into various format.
For now, only JSON is supported.
Encoding is handled by protocols to allow override if a specific implemention is required. See targeted protocol documentation for more information
Summary
Functions
    
      
      Link to this function
    
    
  encode(response, atom)
@spec encode(any(), :json) :: {:ok, String.t()} | {:error, Jason.EncodeError.t() | Exception.t()}
Encode the data in json format.
This is done is 2 steps:
- first, the data is converted into a jsonable format
- the result is encoded in json via Jason
Both of these steps are overridable, see:
- for step 1: Boltx.ResponseEncoder.Json
- for step 2 (depending of your preferred library):
- Boltx.ResponseEncoder.Json.Jason
- Boltx.ResponseEncoder.Json.Poison
Example
iex> data = %{"t1" => %Boltx.Types.Node{
...>     id: 69,
...>     labels: ["Test"],
...>     properties: %{
...>       "created" => %Boltx.Types.DateTimeWithTZOffset{
...>         naive_datetime: ~N[2016-05-24 13:26:08.543],
...>         timezone_offset: 7200
...>       },
...>       "uuid" => 12345
...>     }
...>   }
...> }
iex> Boltx.ResponseEncoder.encode(data, :json)
{:ok, ~S|{"t1":{"id":69,"labels":["Test"],"properties":{"created":"2016-05-24T13:26:08.543+02:00","uuid":12345}}}|}
iex> Boltx.ResponseEncoder.encode("\xFF", :json)
{:error, %Jason.EncodeError{message: "invalid byte 0xFF in <<255>>"}}
    
      
      Link to this function
    
    
  encode!(response, atom)
Encode the data in json format.
Similar to encode/1 except it will unwrap the error tuple and raise in case of errors.
Example
iex> data = %{"t1" => %Boltx.Types.Node{
...>     id: 69,
...>     labels: ["Test"],
...>     properties: %{
...>       "created" => %Boltx.Types.DateTimeWithTZOffset{
...>         naive_datetime: ~N[2016-05-24 13:26:08.543],
...>         timezone_offset: 7200
...>       },
...>       "uuid" => 12345
...>     }
...>   }
...> }
iex> Boltx.ResponseEncoder.encode!(data, :json)
~S|{"t1":{"id":69,"labels":["Test"],"properties":{"created":"2016-05-24T13:26:08.543+02:00","uuid":12345}}}|
iex> Boltx.ResponseEncoder.encode!("\xFF", :json)
** (Jason.EncodeError) invalid byte 0xFF in <<255>>