hare v0.2.2 Hare.Context.Action.DeleteExchange

This module implements a Hare.Context.Action behaviour to delete an exchange from the AMQP server.

Config

Configuration must be a Keyword.t with the following fields:

  • :name - the name of the exchange
  • :opts - (defaults to []) the options to be given to the adapter
  • :export_as - (defaults to nil) the key to export the deleted exchange to

The :export_as config allows the action to export a Hare.Core.Exchange struct to be used later by other steps (for example: to redeclare it with another type).

alias Hare.Context.Action.DeleteExchange

config = [name: "foo",
          opts: [no_wait: true],
          export_as: :deleted_ex]

exports = %{}

DeleteExchange.run(chan, config, exports)
# => {:ok, nil, %{deleted_ex: %Hare.Core.Exchange{chan: chan, name: "foo"}}}

Summary

Types

The action configuration

Functions

Runs the action

Validates the given config format

Types

config()
config() :: [name: binary, opts: Keyword.t, export_as: atom]

The action configuration

Functions

run(chan, config, exports)

Runs the action.

It receives a open AMQP channel, the config of the action, and the exports map, containing data from previous run actions.

It may return 4 possible values:

  • :ok - On success (info is %{} by default)
  • {:ok, info} - On success, providing some info about the execution of the step
  • {:ok, info, exports} - On success, providing some info, with a modified exports map
  • {:error, reason} - On error

Callback implementation for Hare.Context.Action.run/3.

validate(config)

Validates the given config format.

It must return :ok if config is valid, and {:error, reason} if it is invalid.

Callback implementation for Hare.Context.Action.validate/1.