Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/tattdcodemonkey/mon_handler

Elixir GenServer used to monitor a GenEvent event handler
https://github.com/tattdcodemonkey/mon_handler

Last synced: 1 day ago
JSON representation

Elixir GenServer used to monitor a GenEvent event handler

Awesome Lists containing this project

README

        

MonHandler - Monitored Event Handler
==========
[![Hex version](https://img.shields.io/hexpm/v/mon_handler.svg "Hex
version")](https://hex.pm/packages/mon_handler)

This is a minimal `GenServer` module that is used to monitor an event handler.

To use simply call `add_mon_handler` or `start_link` with the `GenEvent` event manager, event handler and args for your event handler. Optionally you can also pass arguments for the `MonHandler` `GenServer`.

`MonHanlder` will handle messages from the event manager if the event handler terminates. For normal terminations `MonHandler` will stop. For terminations due to errors `MonHandler` will re-add the event handler to the event manager.

### Use Cases

Basic:
```elixir
iex(x)> {:ok, manager} = GenEvent.start_link
{:ok, #PID}
iex(x)> {:ok, mon_han} = MonHandler.start_link(manager, YourEventHandler, event_handler_args, gen_server_args)
{:ok, #PID}
iex(x)> GenEvent.notify(manager, {:your_event, "some data"})
:ok
iex(x)> MonHandler.remove_handler(mon_han)
:ok
```
Starting with a supervisor
```elixir
mon_handler_config = MonHandler.get_config(manager, YourEventHandler, event_handler_args)
supervise([worker(MonHandler, [mon_handler_config, []])], [strategy: :one_for_one])
```

If you want to use MonHandler for multiple handlers within a single app you will need to give each an `id` when adding them to the supervisor.
```elixir
supervise(
[
worker(
MonHandler,
[
MonHandler.get_config(:manager_one, YourEventHandler, []),
[]
],
[id: :first_handler]
),
worker(
MonHandler,
[
MonHandler.get_config(:manager_two, YourSecondEventHandler, []),
[]
],
[id: :second_handler]
)
],
[strategy: :one_for_one]
)
```