An open API service indexing awesome lists of open source software.

https://github.com/valiot/relix

Remote Elixir Library for Elixir
https://github.com/valiot/relix

Last synced: 12 days ago
JSON representation

Remote Elixir Library for Elixir

Awesome Lists containing this project

README

          

![Relix Logo](https://github.com/valiot/relix/blob/a19b7019305a8e560d4fb19f235b819aaa912a9b/priv/static/images/relix.png)

# Relix

![Valiot - Tech](https://img.shields.io/badge/Valiot-Tech-blue.svg?style=flat-square&logo=data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2ZXJzaW9uPSIxLjEiIHdpZHRoPSIxMDAwIiBoZWlnaHQ9IjEwMDAiIHZpZXdCb3g9IjAgMCAxMDAwIDEwMDAiIHhtbDpzcGFjZT0icHJlc2VydmUiPgo8ZGVzYz5DcmVhdGVkIHdpdGggRmFicmljLmpzIDMuNS4wPC9kZXNjPgo8ZGVmcz4KPC9kZWZzPgo8cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJyZ2JhKDAsMCwwLDApIi8+CjxnIHRyYW5zZm9ybT0ibWF0cml4KDIyLjc4ODcgMCAwIDIyLjc4ODcgODY4Ljc3OTggNTAwLjQ0MjMpIiBpZD0iUGF0aF83IiBjbGlwLXBhdGg9InVybCgjQ0xJUFBBVEhfNCkiPgo8Y2xpcFBhdGggaWQ9IkNMSVBQQVRIXzQiPgoJPHJlY3QgdHJhbnNmb3JtPSJtYXRyaXgoMSAwIDAgMSAxNi42ODA2IC0wLjAxOTQpIiBpZD0iU1ZHSURfMDAwMDAxODMyMDg5MzM5Njg1NTk2MTc4NjAwMDAwMDM2ODQ5MTQ5NzA0NjEzMzA1OTlfIiB4PSItNTQuMzUiIHk9Ii0xMS4yIiByeD0iMCIgcnk9IjAiIHdpZHRoPSIxMDguNyIgaGVpZ2h0PSIyMi40Ii8+CjwvY2xpcFBhdGg+CjxwYXRoIHN0eWxlPSJzdHJva2U6IG5vbmU7IHN0cm9rZS13aWR0aDogMTsgc3Ryb2tlLWRhc2hhcnJheTogbm9uZTsgc3Ryb2tlLWxpbmVjYXA6IGJ1dHQ7IHN0cm9rZS1kYXNob2Zmc2V0OiAwOyBzdHJva2UtbGluZWpvaW46IG1pdGVyOyBzdHJva2UtbWl0ZXJsaW1pdDogNDsgaXMtY3VzdG9tLWZvbnQ6IG5vbmU7IGZvbnQtZmlsZS11cmw6IG5vbmU7IGZpbGw6IHJnYig4MCwyNTAsMTIpOyBmaWxsLXJ1bGU6IG5vbnplcm87IG9wYWNpdHk6IDE7IiB0cmFuc2Zvcm09IiB0cmFuc2xhdGUoLTM4LjE2OTQsIC0xMS45MTk0KSIgZD0iTSA0My4zIDIwLjQgTCAzNi43IDIgYyAtMC40IC0xIC0xLjUgLTEuNSAtMi41IC0xLjIgYyAtMSAwLjQgLTEuNSAxLjUgLTEuMiAyLjUgbCAwIDAgbCA2LjYgMTguNSBjIDAuNCAxIDEuNSAxLjYgMi41IDEuMiBTIDQzLjcgMjEuNSA0My4zIDIwLjQgTCA0My4zIDIwLjQiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIvPgo8L2c+CjxnIHRyYW5zZm9ybT0ibWF0cml4KDIyLjc4ODcgMCAwIDIyLjc4ODcgMzAxLjQ0OTggNDk3LjQ4NjUpIiBpZD0iUGF0aF84IiBjbGlwLXBhdGg9InVybCgjQ0xJUFBBVEhfNSkiPgo8Y2xpcFBhdGggaWQ9IkNMSVBQQVRIXzUiPgoJPHJlY3QgdHJhbnNmb3JtPSJtYXRyaXgoMSAwIDAgMSA0MS41NzU4IDAuMTEwMykiIGlkPSJTVkdJRF8wMDAwMDE4MzIwODkzMzk2ODU1OTYxNzg2MDAwMDAwMzY4NDkxNDk3MDQ2MTMzMDU5OV8iIHg9Ii01NC4zNSIgeT0iLTExLjIiIHJ4PSIwIiByeT0iMCIgd2lkdGg9IjEwOC43IiBoZWlnaHQ9IjIyLjQiLz4KPC9jbGlwUGF0aD4KPHBhdGggc3R5bGU9InN0cm9rZTogbm9uZTsgc3Ryb2tlLXdpZHRoOiAxOyBzdHJva2UtZGFzaGFycmF5OiBub25lOyBzdHJva2UtbGluZWNhcDogYnV0dDsgc3Ryb2tlLWRhc2hvZmZzZXQ6IDA7IHN0cm9rZS1saW5lam9pbjogbWl0ZXI7IHN0cm9rZS1taXRlcmxpbWl0OiA0OyBpcy1jdXN0b20tZm9udDogbm9uZTsgZm9udC1maWxlLXVybDogbm9uZTsgZmlsbDogcmdiKDAsMTYyLDI1NSk7IGZpbGwtcnVsZTogbm9uemVybzsgb3BhY2l0eTogMTsiIHRyYW5zZm9ybT0iIHRyYW5zbGF0ZSgtMTMuMjc0MiwgLTExLjc4OTcpIiBkPSJNIDI2IDEuNyBjIC0yLjUgLTEuNyAtNS45IC0xIC03LjYgMS41IGMgLTAuMyAwLjQgLTAuNSAwLjggLTAuNiAxLjIgbCAtMi42IDcuNCBsIC0wLjUgMS4zIGMgMCAwIC0xLjUgNC4zIC0xLjYgNC40IGMgLTAuMiAwLjcgLTAuOSAxLjEgLTEuNyAxLjEgYyAtMC43IDAgLTEuMyAtMC40IC0xLjYgLTEuMSBjIC0wLjEgLTAuMSAtMS42IC00LjQgLTEuNiAtNC40IEwgNC40IDIgQyA0IDEgMi45IDAuNCAxLjggMC44IFMgMC4zIDIuMyAwLjcgMy4zIGMgMCAwIDAgMCAwIDAgbCAzLjUgOS44IGwgMi4yIDYuMSBjIDAuOCAyLjIgMi44IDMuNyA1LjIgMy43IGMgMi40IDAuMSA0LjUgLTEuNCA1LjIgLTMuNiBsIDIgLTUuOCBsIDEgLTIuOSBsIDEuOCAtNS4xIEMgMjIuMiAzLjQgMjMuOSAxLjkgMjYgMS43IiBzdHJva2UtbGluZWNhcD0icm91bmQiLz4KPC9nPgo8ZyB0cmFuc2Zvcm09Im1hdHJpeCgyMi43ODg3IDAgMCAyMi43ODg3IDY2Ni4wOTE3IDUzNC42MjUzKSIgaWQ9IlBhdGhfOSIgY2xpcC1wYXRoPSJ1cmwoI0NMSVBQQVRIXzYpIj4KPGNsaXBQYXRoIGlkPSJDTElQUEFUSF82Ij4KCTxyZWN0IHRyYW5zZm9ybT0ibWF0cml4KDEgMCAwIDEgMjUuNTc0OCAtMS41MTk0KSIgaWQ9IlNWR0lEXzAwMDAwMTgzMjA4OTMzOTY4NTU5NjE3ODYwMDAwMDAzNjg0OTE0OTcwNDYxMzMwNTk5XyIgeD0iLTU0LjM1IiB5PSItMTEuMiIgcng9IjAiIHJ5PSIwIiB3aWR0aD0iMTA4LjciIGhlaWdodD0iMjIuNCIvPgo8L2NsaXBQYXRoPgo8cGF0aCBzdHlsZT0ic3Ryb2tlOiBub25lOyBzdHJva2Utd2lkdGg6IDE7IHN0cm9rZS1kYXNoYXJyYXk6IG5vbmU7IHN0cm9rZS1saW5lY2FwOiBidXR0OyBzdHJva2UtZGFzaG9mZnNldDogMDsgc3Ryb2tlLWxpbmVqb2luOiBtaXRlcjsgc3Ryb2tlLW1pdGVybGltaXQ6IDQ7IGlzLWN1c3RvbS1mb250OiBub25lOyBmb250LWZpbGUtdXJsOiBub25lOyBmaWxsOiByZ2IoODAsMjUwLDEyKTsgZmlsbC1ydWxlOiBub256ZXJvOyBvcGFjaXR5OiAxOyIgdHJhbnNmb3JtPSIgdHJhbnNsYXRlKC0yOS4yNzUyLCAtMTMuNDE5NCkiIGQ9Ik0gMzMuOCAyMC40IEwgMjguNCA1LjEgYyAtMC40IC0xIC0xLjUgLTEuNSAtMi41IC0xLjIgcyAtMS41IDEuNSAtMS4yIDIuNSBsIDUuNCAxNS4zIGMgMC40IDEgMS41IDEuNiAyLjUgMS4yIEMgMzMuNyAyMi42IDM0LjIgMjEuNSAzMy44IDIwLjQiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIvPgo8L2c+Cjwvc3ZnPg==)
![version - 0.1.2](https://img.shields.io/badge/version-0.1.2-white.svg?style=flat-square&color=lightgray)

**Remote Execution Library for Elixir**

Relix provides rpc interfacing with `Relix.RPC`.

The `Relix.RPC` module provides a struct for holding rpc call data

```elixir
iex(relix@127.0.0.1)1> Relix.RPC.new
%Relix.RPC{
node: nil,
module: nil,
function: nil,
args: [],
response: nil,
resp_body: nil,
status: nil,
attempts: 0
}
```

The `:node` field is quite handy and can be set for a string, which is expected to be contained in the
target RPC node name, or `:self` for performing RPC calls to itself.

```elixir
iex(relix@127.0.0.1)2> rpc = %Relix.RPC{
node: :self,
module: Relix.RPC,
function: :new,
args: []
}

iex(relix@127.0.0.1)3> rpc |> RPC.execute() |> RPC.response()
{:ok,
%Relix.RPC{
node: nil,
module: nil,
function: nil,
args: [],
response: nil,
resp_body: nil,
status: nil,
attempts: 0
}}
```

`RPC.execute()` will perform an RPC call with provided parameters. If the RPC call succeeded, it will set `RPC.status: :executed`, and the response will be set under `RPC.resp_body` and can be extracted by `RPC.response()`

If no nodes are reachable satisfying the provided `node:` identifier, `RPC.execute` will set `RPC.status: :not_reachable`.

`RPC.response()` extracts the response if `RPC.status: executed` to `{:ok, RPC.resp_body}`. If the current status `RPC.status` is different from `:executed`, it returns `{:error, :not_executed}`.

If the RPC response is on the form `{:error, _} = function_error`. such `function_error` will be returned.

## Installation

If [available in Hex](https://hex.pm/docs/publish), the package can be installed
by adding `relix` to your list of dependencies in `mix.exs`:

```elixir
def deps do
[
{:relix, "~> 0.1.1"}
]
end
```

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 .