Class: RightAws::SqsGen2
- Inherits:
-
Object
- Object
- RightAws::SqsGen2
- Defined in:
- lib/sqs/right_sqs_gen2.rb
Overview
RightAws::SqsGen2 – RightScale’s Amazon SQS interface, API version 2008-01-01 and later. The RightAws::SqsGen2 class provides a complete interface to the second generation of Amazon’s Simple Queue Service. For explanations of the semantics of each call, please refer to Amazon’s documentation at developer.amazonwebservices.com/connect/kbcategory.jspa?categoryID=31
RightAws::SqsGen2 is built atop RightAws::SqsGen2Interface, a lower-level procedural API that may be appropriate for certain programs.
Error handling: all operations raise an RightAws::AwsError in case of problems. Note that transient errors are automatically retried.
sqs = RightAws::SqsGen2.new(aws_access_key_id, aws_secret_access_key)
queue1 = sqs.queue('my_awesome_queue')
...
queue2 = RightAws::SqsGen2::Queue.create(sqs, 'my_cool_queue', true)
puts queue2.size
...
= queue2.receive
.visibility = 0
puts
...
queue2.clear(true)
queue2.('Ola-la!')
= queue2.pop
...
NB: Second-generation SQS has eliminated the entire access grant mechanism present in Gen 1.
Params is a hash:
{:server => 'queue.amazonaws.com' # Amazon service host: 'queue.amazonaws.com' (default)
:port => 443 # Amazon service port: 80 or 443 (default)
:signature_version => '0' # The signature version : '0' or '1'(default)
:logger => Logger Object} # Logger instance: logs to STDOUT if omitted }
Defined Under Namespace
Instance Attribute Summary collapse
-
#interface ⇒ Object
readonly
Returns the value of attribute interface.
Instance Method Summary collapse
-
#initialize(aws_access_key_id = nil, aws_secret_access_key = nil, params = {}) ⇒ SqsGen2
constructor
A new instance of SqsGen2.
-
#queue(queue_name, create = true, visibility = nil) ⇒ Object
Returns Queue instance by queue name.
-
#queues(prefix = nil) ⇒ Object
Retrieves a list of queues.
Constructor Details
#initialize(aws_access_key_id = nil, aws_secret_access_key = nil, params = {}) ⇒ SqsGen2
Returns a new instance of SqsGen2.
68 69 70 |
# File 'lib/sqs/right_sqs_gen2.rb', line 68 def initialize(aws_access_key_id=nil, aws_secret_access_key=nil, params={}) @interface = SqsGen2Interface.new(aws_access_key_id, aws_secret_access_key, params) end |
Instance Attribute Details
#interface ⇒ Object (readonly)
Returns the value of attribute interface.
66 67 68 |
# File 'lib/sqs/right_sqs_gen2.rb', line 66 def interface @interface end |
Instance Method Details
#queue(queue_name, create = true, visibility = nil) ⇒ Object
Returns Queue instance by queue name. If the queue does not exist at Amazon SQS and create
is true, the method creates it.
RightAws::SqsGen2.queue('my_awesome_queue') #=> #<RightAws::SqsGen2::Queue:0xb7b626e4 ... >
88 89 90 91 92 |
# File 'lib/sqs/right_sqs_gen2.rb', line 88 def queue(queue_name, create=true, visibility=nil) url = @interface.queue_url_by_name(queue_name) url = (create ? @interface.create_queue(queue_name, visibility) : nil) unless url url ? Queue.new(self, url) : nil end |
#queues(prefix = nil) ⇒ Object
Retrieves a list of queues. Returns an array
of Queue
instances.
RightAws::Sqs.queues #=> array of queues
77 78 79 80 81 |
# File 'lib/sqs/right_sqs_gen2.rb', line 77 def queues(prefix=nil) @interface.list_queues(prefix).map do |url| Queue.new(self, url) end end |