Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
rabbitmq_http_api_client
Advanced tools
This gem is a RabbitMQ HTTP API client for Ruby. It supports
and will support more HTTP API features in the future
All supported RabbitMQ release series.
All versions require RabbitMQ Management UI plugin to be installed and enabled.
Add this line to your application's Gemfile:
gem 'rabbitmq_http_api_client', '>= 2.2.0'
And then execute:
bundle install
Or install it yourself as:
gem install rabbitmq_http_api_client
To require the client:
require "rabbitmq/http/client"
Use RabbitMQ::HTTP::Client#connect
to specify RabbitMQ HTTP API endpoint (e.g. http://127.0.0.1:15672
) and credentials:
require "rabbitmq/http/client"
endpoint = "http://127.0.0.1:15672"
client = RabbitMQ::HTTP::Client.new(endpoint, username: "guest", password: "guest")
Alternatively, credentials can be specified in the endpoint URI:
require "rabbitmq/http/client"
client = RabbitMQ::HTTP::Client.new("http://guest:guest@127.0.0.1:15672")
All client methods return arrays or hash-like structures that can be used
like JSON, via Hash#[]
or regular method access:
r = client.overview
puts r[:rabbitmq_version]
puts r.erlang_version
All additional options other than :username
and :password
are passed
to Faraday::Connection. So, it is possible to use HTTPS
like so:
c = RabbitMQ::HTTP::Client.new("https://127.0.0.1:15672/", username: "guest", password: "guest", ssl: {
client_cer: ...,
client_key: ...,
ca_file: ...,
ca_path: ...,
cert_store: ...
})
Or, if you have good reasons to do so, disable peer verification:
c = RabbitMQ::HTTP::Client.new("https://127.0.0.1:15672/", username: "guest", password: "guest", ssl: {
verify: false
})
# Get cluster information overview
h = client.overview
# List cluster nodes with detailed status info for each one of them
nodes = client.list_nodes
n = nodes.first
puts n.mem_used
puts n.run_queue
# Get detailed status of a node
n = client.node_info("rabbit@localhost")
puts n.disk_free
puts n.proc_used
puts n.fd_total
# Get Management Plugin extension list
xs = client.list_extensions
# List all the entities (vhosts, queues, exchanges, bindings, users, etc)
defs = client.list_definitions
# List all connections to a node
conns = client.list_connections
conn = conns.first
puts conn.name
puts conn.client_properties.product
# Get a connection information by name
conns = client.list_connections
conn = client.connection_info(conns.first.name)
puts conn.name
puts conn.client_properties.product
# Forcefully close a connection
conns = client.list_connections
client.close_connection(conns.first.name)
# List all channels
channs = client.list_channels
ch = channs.first
puts ch.number
puts ch.prefetch_count
puts ch.name
# Get a channel information by name
conns = client.list_channels
conn = client.channel_info(conns.first.name)
puts conn.name
# List all exchanges in the cluster
xs = client.list_exchanges
x = xs.first
puts x.type
puts x.name
puts x.vhost
puts x.durable
puts x.auto_delete
# List all exchanges in a vhost
xs = client.list_exchanges("myapp.production")
x = xs.first
puts x.type
puts x.name
puts x.vhost
# Get information about an exchange in a vhost
x = client.exchange_info("/", "log.events")
puts x.type
puts x.name
puts x.vhost
# List all exchanges in a vhost for which an exchange is the source
client.list_bindings_by_source("/", "log.events")
# List all exchanges in a vhost for which an exchange is the destination
client.list_bindings_by_destination("/", "command.handlers.email")
# List all queues in a node
qs = client.list_queues
q = qs.first
puts q.name
puts q.auto_delete
puts q.durable
puts q.backing_queue_status
puts q.active_consumers
# Get information about a queue
client.queue_info("/", "collector1.megacorp.local")
# Declare a queue
client.declare_queue("/", "collector1.megacorp.local", :durable => false, :auto_delete => true)
# Delete a queue
client.delete_queue("/", "collector1.megacorp.local")
# List bindings for a queue
bs = client.list_queue_bindings("/", "collector1.megacorp.local")
# Purge a queue
client.purge_queue("/", "collector1.megacorp.local")
# Fetch messages from a queue
ms = client.get_messages("/", "collector1.megacorp.local", :count => 10, :requeue => false, :encoding => "auto")
m = ms.first
puts m.properties.content_type
puts m.payload
puts m.payload_encoding
# List all bindings
bs = client.list_bindings
b = bs.first
puts b.destination
puts b.destination_type
puts b.source
puts b.routing_key
puts b.vhost
# List all bindings in a vhost
bs = client.list_bindings("/")
# List all bindings between an exchange and a queue
bs = client.list_bindings_between_queue_and_exchange("/", "collector1.megacorp.local", "log.events")
# List all vhosts
vs = client.list_vhosts
v = vs.first
puts v.name
puts v.tracing
# Get information about a vhost
v = client.vhost_info("/")
puts v.name
puts v.tracing
# Create a vhost
client.create_vhost("myapp.staging")
# Delete a vhost
client.delete_vhost("myapp.staging")
# List all users
us = client.list_users
u = us.first
puts u.name
puts u.password_hash
puts u.tags
# Get information about a user
u = client.user_info("guest")
puts u.name
puts u.password_hash
puts u.tags
# Update information about a user
client.update_user("myapp", :tags => "services,policymaker,management", :password => "t0ps3krEt")
# Delete a user
client.delete_user("myapp")
# List all permissions
ps = client.list_permissions
puts p.user
puts p.read
puts p.write
puts p.configure
puts p.vhost
# List all permissions in a vhost
ps = client.list_permissions("/")
puts p.user
puts p.read
puts p.write
puts p.configure
puts p.vhost
# List permissions of a user
ps = client.user_permissions("guest")
# List permissions of a user in a vhost
ps = client.list_permissions_of("/", "guest")
# Update permissions of a user in a vhost
ps = client.update_permissions_of("/", "guest", :write => ".*", :read => ".*", :configure => ".*")
# Clear permissions of a user in a vhost
ps = client.clear_permissions_of("/", "guest")
Before running the test suites, run a script that will set up the local node:
export RUBY_RABBITMQ_HTTP_API_CLIENT_RABBITMQCTL="rabbitmqctl"
export RUBY_RABBITMQ_HTTP_API_CLIENT_RABBITMQ_PLUGINS="rabbitmq-plugins"
./bin/ci/before_build.sh
To run all specs:
bundle install
bundle exec rspec -cfd spec
The test suite assumes that RabbitMQ is running locally with stock settings and rabbitmq-management plugin enabled.
git checkout -b my-new-feature
)git commit -am 'Add some feature'
)git push origin my-new-feature
)Double-licensed under the MIT and Mozilla Public License (same as RabbitMQ).
(c) Michael S. Klishin, 2012-2020.
FAQs
Unknown package
We found that rabbitmq_http_api_client demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.