rabbitmq-server/deps/rabbitmq_cli
Daniil Fedotov b802fcdf87 Do not try to connect to the RabbitMQ node before executing command
Commands are supposed to return bardpc errors, which are handled by output,
so there is no need to connect to the node before calling the run function.
2017-06-07 16:21:53 +01:00
..
config Update copyright line to year 2017 2017-01-10 15:42:40 +01:00
include
lib Do not try to connect to the RabbitMQ node before executing command 2017-06-07 16:21:53 +01:00
test Do not try to connect to the RabbitMQ node before executing command 2017-06-07 16:21:53 +01:00
.gitignore Ignore ./log 2017-02-02 00:14:21 +03:00
CODE_OF_CONDUCT.md Copy Code of Conduct document from rabbitmq-server 2016-12-14 14:27:21 +03:00
COMMAND_TUTORIAL.md Fix typo in tutorial file name 2016-11-30 17:35:18 +01:00
CONTRIBUTING.md Update CONTRIBUTING.md 2017-03-09 14:52:18 +03:00
DESIGN.md Make it possible to specify erlang cookie from command line 2017-04-03 14:46:26 +01:00
Makefile Makefile: Load the new `rabbitmq-early-plugin.mk` early-stage plugin 2017-05-16 18:02:10 +02:00
README.md Bump Elixir version requirement. 2017-05-19 11:20:17 +01:00
erlang.mk Update erlang.mk 2017-05-16 18:01:58 +02:00
mix.exs Bumped a dependency version to fix some warnings 2017-05-22 12:54:43 +01:00
rabbitmq-components.mk Update rabbitmq-components.mk 2017-06-02 17:53:44 +03:00

README.md

RabbitMQ CLI Tools

This is the next generation implementation of rabbitmqctl and other RabbitMQ CLI tools.

This project is a work in progress and targets RabbitMQ 3.7.0 (currently the master branch). For production use, go with the rabbitmqctl distributed with the RabbitMQ version you use.

Goals

Team RabbitMQ wanted a set of tools that

  • Was extensible from/with plugins
  • Supported pluggable output formats (in particular machine-friendly ones)
  • Had good test coverage
  • Wasn't as coupled to the server repository
  • Could be used as a low risk vehicle for Elixir evaluation

Supported RabbitMQ Versions

This version of CLI tools targets RabbitMQ master (future 3.7.0). Some operations (for example, the list_* ones) will not work with earlier server releases.

Building

Requirements

Building this project requires Elixir 1.4.4 or greater.

Command line tools depend on rabbitmq-common. Dependencies are being resolved by erlang.mk

Building Standalone Executables

This repo produces a rabbitmqctl executable which can be used as different tools by copying or symlinking it with different names.

Currently rabbitmq-plugins and rabbitmq-diagnostics tools are supported.

To generate the executable, run

make

Usage

rabbitmqctl

rabbitmqctl [-n node] [-t timeout] [-q] {command} [command options...]

See the rabbitmqctl man page for a full list of options.

Testing

See CONTRIBUTING.md.

Developing

Adding a New Command

Conventions

RabbitMQ CLI tools use module name conventions to match the command-line actions (commands) to modules. The convention is outlined in the CommandBehaviour module.

Command Module Interface

Each command module must implement the RabbitMQ.CLI.CommandBehaviour behaviour, which includes the following functions:

  • validate(args, opts), which returns either :ok or a tuple of {:validation_failure, failure_detail} where failure detail is typically one of: :too_many_args, :not_enough_args or {:bad_argument, String.t}.

  • merge_defaults(args, opts), which is used to return updated arguments and/or options.

  • run(args, opts), where the actual command is implemented. Here, args is a list of command-specific parameters and opts is a Map containing option flags.

  • usage, which returns a string describing the command, its arguments and its optional flags.

  • banner(args, opts), which returns a string to be printed before the command output.

There are also a number of optional callbacks:

  • switches, which returns command specific switches.
  • aliases, which returns a list of command aliases (if any).
  • formatter: what output formatter should be used by default.
  • usage_additional: extra values appended to the usage output to provide additional command-specific documentation.
  • scopes: what scopes this command appears in. Scopes associate tools (e.g. rabbitmqctl, rabbitmq-diagnostics) with commands.

Tutorial

We have a tutorial that demonstrates how to add a CLI command that deletes a queue.

Examples

See lib/rabbitmq/cli/ctl/commands/status_command.ex and test/status_command_test.exs for simple examples.

The project is licensed under the MPL, the same license as RabbitMQ.

(c) Pivotal Software, Inc, 2016-2017.