Class: RubyNestNats::Client
- Inherits:
-
Object
- Object
- RubyNestNats::Client
- Defined in:
- lib/ruby_nest_nats/client.rb
Overview
The RubyNestNats::Client
class provides a basic interface for subscribing to messages by subject & queue, and replying to those messages. It also logs most functionality if desired.
Class Attribute Summary collapse
-
.default_queue ⇒ Object
:nodoc:.
-
.logger ⇒ Object
:nodoc:.
Class Method Summary collapse
-
.reply_to(subject, queue: nil, &block) ⇒ Object
Register a message handler with the
RubyNestNats::Client::reply_to
method. -
.start! ⇒ Object
Start listening for messages with the
RubyNestNats::Client::start!
method. -
.started? ⇒ Boolean
Returns
true
if::start!
has already been called (meaning the client is listening to NATS messages). -
.stopped? ⇒ Boolean
Opposite of
::started?
: returnsfalse
if::start!
has already been called (meaning the client is listening to NATS messages).
Class Attribute Details
.default_queue ⇒ Object
:nodoc:
14 15 16 |
# File 'lib/ruby_nest_nats/client.rb', line 14 def default_queue @default_queue end |
.logger ⇒ Object
:nodoc:
14 15 16 |
# File 'lib/ruby_nest_nats/client.rb', line 14 def logger @logger end |
Class Method Details
.reply_to(subject, queue: nil, &block) ⇒ Object
Register a message handler with the RubyNestNats::Client::reply_to
method. Pass a subject string as the first argument (either a static subject string or a pattern to match more than one subject). Specify a queue (or don’t) with the queue:
option. If you don’t provide the queue:
option, it will be set to the value of default_queue
, or to nil
(no queue) if a default queue hasn’t been set.
The result of the given block will be published in reply to the message. The block is passed two arguments when a message matching the subject is received: data
and subject
. The data
argument is the payload of the message (JSON objects/arrays will be parsed into string-keyed Hash
objects/Array
objects, respectively). The subject
argument is the subject of the message received (mostly only useful if a pattern was specified instead of a static subject string).
101 102 103 104 105 106 |
# File 'lib/ruby_nest_nats/client.rb', line 101 def reply_to(subject, queue: nil, &block) queue = Utils.presence(queue) || default_queue queue_desc = " in queue '#{queue}'" if queue log("Registering a reply handler for subject '#{subject}'#{queue_desc}", level: :debug) register_reply!(subject: subject.to_s, handler: block, queue: queue.to_s) end |
.start! ⇒ Object
Start listening for messages with the RubyNestNats::Client::start!
method. This will spin up a non-blocking thread that subscribes to subjects (as specified by invocation(s) of ::reply_to
) and waits for messages to come in. When a message is received, the appropriate ::reply_to
block will be used to compute a response, and that response will be published.
NOTE: If an error is raised in one of the handlers, RubyNestNats::Client
will restart automatically.
NOTE: You can invoke ::reply_to
to create additional message subscriptions after RubyNestNats::Client.start!
, but be aware that this forces the client to restart. You may see (benign, already-handled) errors in the logs generated when this restart happens. It will force the client to restart and re-subscribe after _each additional ::reply_to
invoked after ::start!
._ So, if you have a lot of additional ::reply_to
invocations, you may want to consider refactoring so that your call to RubyNestNats::Client.start!
occurs after those additions.
NOTE: The ::start!
method can be safely called multiple times; only the first will be honored, and any subsequent calls to ::start!
after the client is already started will do nothing (except write a _“NATS is already running”_ log to the logger at the DEBUG
level).
136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 |
# File 'lib/ruby_nest_nats/client.rb', line 136 def start! log("Starting NATS", level: :debug) if started? log("NATS is already running", level: :debug) return end started! self.current_thread = Thread.new do Thread.handle_interrupt(StandardError => :never) do Thread.handle_interrupt(StandardError => :immediate) { listen } rescue NATS::ConnectError => e log("Could not connect to NATS server:", level: :error) log(e., level: :error, indent: 2) Thread.current.exit rescue NewSubscriptionsError => e log("New subscriptions! Restarting...", level: :info) restart! raise e # TODO: there has to be a better way rescue StandardError => e log("Encountered an error:", level: :error) log(e., level: :error, indent: 2) restart! raise e end end end |
.started? ⇒ Boolean
Returns true
if ::start!
has already been called (meaning the client is listening to NATS messages). Returns false
if it has not yet been called, or if it has been stopped.
58 59 60 |
# File 'lib/ruby_nest_nats/client.rb', line 58 def started? @started ||= false end |
.stopped? ⇒ Boolean
Opposite of ::started?
: returns false
if ::start!
has already been called (meaning the client is listening to NATS messages). Returns true
if it has not yet been called, or if it has been stopped.
65 66 67 |
# File 'lib/ruby_nest_nats/client.rb', line 65 def stopped? !started? end |