1Net::AMQP::Protocol::v0U_s8e(r3)Contributed Perl DocumenNteatt:i:oAnMQP::Protocol::v0_8(3)
2
3
4
6 Net::AMQP::Protocol::v0_8 - AMQP v0.8 (de)serialization and
7 representation
8
10 use Net::AMQP::Protocol::v0_8;
11
12 ...
13
14 my @frames = Net::AMQP->parse_raw_frames(\$input);
15
16 ...
17
18 my $frame = Net::AMQP::Frame::Method->new(
19 channel => 0,
20 method_frame => Net::AMQP::Protocol::Connection::StartOk->new(
21 client_properties => { ... },
22 mechanism => 'AMQPLAIN',
23 locale => 'en_US',
24 response => {
25 LOGIN => 'guest',
26 PASSWORD => 'guest',
27 },
28 ),
29 );
30
31 print OUT $frame->to_raw_frame();
32
34 This module implements the frame (de)serialization and representation
35 of the Advanced Message Queue Protocol (http://www.amqp.org/) version
36 0.8.
37
38 It is to be used in conjunction with client or server software that
39 does the actual TCP/IP communication.
40
42 Net::AMQP::Protocol::Connection::Start
43 This class implements the class Connection method Start, which is a
44 synchronous method.
45
46 This method starts the connection negotiation process by telling the
47 client the protocol version that the server proposes, along with a list
48 of security mechanisms which the client can use for authentication.
49
50 Each of the following represents a field in the specification. These
51 are the optional arguments to new() and are also read/write accessors:
52
53 version_major (type: octet)
54 Protocol major version
55
56 The protocol major version that the server agrees to use, which
57 cannot be higher than the client's major version.
58
59 version_minor (type: octet)
60 Protocol major version
61
62 The protocol minor version that the server agrees to use, which
63 cannot be higher than the client's minor version.
64
65 server_properties (type: table)
66 Server properties
67
68 mechanisms (type: longstr)
69 Available security mechanisms
70
71 A list of the security mechanisms that the server supports,
72 delimited by spaces. Currently ASL supports these mechanisms:
73 PLAIN.
74
75 locales (type: longstr)
76 Available message locales
77
78 A list of the message locales that the server supports, delimited
79 by spaces. The locale defines the language in which the server will
80 send reply texts.
81
82 Net::AMQP::Protocol::Connection::StartOk
83 This class implements the class Connection method StartOk, which is a
84 synchronous method.
85
86 This method selects a SASL security mechanism. ASL uses SASL (RFC2222)
87 to negotiate authentication and encryption.
88
89 Each of the following represents a field in the specification. These
90 are the optional arguments to new() and are also read/write accessors:
91
92 client_properties (type: table)
93 Client properties
94
95 mechanism (type: shortstr)
96 Selected security mechanism
97
98 A single security mechanisms selected by the client, which must be
99 one of those specified by the server.
100
101 response (type: longstr)
102 Security response data
103
104 A block of opaque data passed to the security mechanism. The
105 contents of this data are defined by the SASL security mechanism.
106 For the PLAIN security mechanism this is defined as a field table
107 holding two fields, LOGIN and PASSWORD.
108
109 locale (type: shortstr)
110 Selected message locale
111
112 A single message local selected by the client, which must be one of
113 those specified by the server.
114
115 Net::AMQP::Protocol::Connection::Secure
116 This class implements the class Connection method Secure, which is a
117 synchronous method.
118
119 The SASL protocol works by exchanging challenges and responses until
120 both peers have received sufficient information to authenticate each
121 other. This method challenges the client to provide more information.
122
123 Each of the following represents a field in the specification. These
124 are the optional arguments to new() and are also read/write accessors:
125
126 challenge (type: longstr)
127 Security challenge data
128
129 Challenge information, a block of opaque binary data passed to the
130 security mechanism.
131
132 Net::AMQP::Protocol::Connection::SecureOk
133 This class implements the class Connection method SecureOk, which is a
134 synchronous method.
135
136 This method attempts to authenticate, passing a block of SASL data for
137 the security mechanism at the server side.
138
139 Each of the following represents a field in the specification. These
140 are the optional arguments to new() and are also read/write accessors:
141
142 response (type: longstr)
143 Security response data
144
145 A block of opaque data passed to the security mechanism. The
146 contents of this data are defined by the SASL security mechanism.
147
148 Net::AMQP::Protocol::Connection::Tune
149 This class implements the class Connection method Tune, which is a
150 synchronous method.
151
152 This method proposes a set of connection configuration values to the
153 client. The client can accept and/or adjust these.
154
155 Each of the following represents a field in the specification. These
156 are the optional arguments to new() and are also read/write accessors:
157
158 channel_max (type: short)
159 Proposed maximum channels
160
161 The maximum total number of channels that the server allows per
162 connection. Zero means that the server does not impose a fixed
163 limit, but the number of allowed channels may be limited by
164 available server resources.
165
166 frame_max (type: long)
167 Proposed maximum frame size
168
169 The largest frame size that the server proposes for the connection.
170 The client can negotiate a lower value. Zero means that the server
171 does not impose any specific limit but may reject very large frames
172 if it cannot allocate resources for them.
173
174 heartbeat (type: short)
175 Desired heartbeat delay
176
177 The delay, in seconds, of the connection heartbeat that the server
178 wants. Zero means the server does not want a heartbeat.
179
180 Net::AMQP::Protocol::Connection::TuneOk
181 This class implements the class Connection method TuneOk, which is a
182 synchronous method.
183
184 This method sends the client's connection tuning parameters to the
185 server. Certain fields are negotiated, others provide capability
186 information.
187
188 Each of the following represents a field in the specification. These
189 are the optional arguments to new() and are also read/write accessors:
190
191 channel_max (type: short)
192 Negotiated maximum channels
193
194 The maximum total number of channels that the client will use per
195 connection. May not be higher than the value specified by the
196 server.
197
198 frame_max (type: long)
199 Negotiated maximum frame size
200
201 The largest frame size that the client and server will use for the
202 connection. Zero means that the client does not impose any specific
203 limit but may reject very large frames if it cannot allocate
204 resources for them. Note that the frame-max limit applies
205 principally to content frames, where large contents can be broken
206 into frames of arbitrary size.
207
208 heartbeat (type: short)
209 Desired heartbeat delay
210
211 The delay, in seconds, of the connection heartbeat that the client
212 wants. Zero means the client does not want a heartbeat.
213
214 Net::AMQP::Protocol::Connection::Open
215 This class implements the class Connection method Open, which is a
216 synchronous method.
217
218 This method opens a connection to a virtual host, which is a collection
219 of resources, and acts to separate multiple application domains within
220 a server.
221
222 Each of the following represents a field in the specification. These
223 are the optional arguments to new() and are also read/write accessors:
224
225 virtual_host (type: shortstr)
226 Virtual host name
227
228 The name of the virtual host to work with.
229
230 capabilities (type: shortstr)
231 Required capabilities
232
233 The client may specify a number of capability names, delimited by
234 spaces. The server can use this string to how to process the
235 client's connection request.
236
237 insist (type: bit)
238 Insist on connecting to server
239
240 In a configuration with multiple load-sharing servers, the server
241 may respond to a Connection.Open method with a Connection.Redirect.
242 The insist option tells the server that the client is insisting on
243 a connection to the specified server.
244
245 Net::AMQP::Protocol::Connection::OpenOk
246 This class implements the class Connection method OpenOk, which is a
247 synchronous method.
248
249 This method signals to the client that the connection is ready for use.
250
251 Each of the following represents a field in the specification. These
252 are the optional arguments to new() and are also read/write accessors:
253
254 known_hosts (type: shortstr)
255
256 Net::AMQP::Protocol::Connection::Redirect
257 This class implements the class Connection method Redirect, which is a
258 synchronous method.
259
260 This method redirects the client to another server, based on the
261 requested virtual host and/or capabilities.
262
263 Each of the following represents a field in the specification. These
264 are the optional arguments to new() and are also read/write accessors:
265
266 host (type: shortstr)
267 Server to connect to
268
269 Specifies the server to connect to. This is an IP address or a DNS
270 name, optionally followed by a colon and a port number. If no port
271 number is specified, the client should use the default port number
272 for the protocol.
273
274 known_hosts (type: shortstr)
275
276 Net::AMQP::Protocol::Connection::Close
277 This class implements the class Connection method Close, which is a
278 synchronous method.
279
280 This method indicates that the sender wants to close the connection.
281 This may be due to internal conditions (e.g. a forced shut-down) or due
282 to an error handling a specific method, i.e. an exception. When a close
283 is due to an exception, the sender provides the class and method id of
284 the method which caused the exception.
285
286 Each of the following represents a field in the specification. These
287 are the optional arguments to new() and are also read/write accessors:
288
289 reply_code (type: short)
290 reply_text (type: shortstr)
291 class_id (type: short)
292 Failing method class
293
294 When the close is provoked by a method exception, this is the class
295 of the method.
296
297 method_id (type: short)
298 Failing method ID
299
300 When the close is provoked by a method exception, this is the ID of
301 the method.
302
303 Net::AMQP::Protocol::Connection::CloseOk
304 This class implements the class Connection method CloseOk, which is a
305 synchronous method.
306
307 This method confirms a Connection.Close method and tells the recipient
308 that it is safe to release resources for the connection and close the
309 socket.
310
311 This class has no fields nor accessors.
312
313 Net::AMQP::Protocol::Channel::Open
314 This class implements the class Channel method Open, which is a
315 synchronous method.
316
317 This method opens a virtual connection (a channel).
318
319 Each of the following represents a field in the specification. These
320 are the optional arguments to new() and are also read/write accessors:
321
322 out_of_band (type: shortstr)
323 Out-of-band settings
324
325 Configures out-of-band transfers on this channel. The syntax and
326 meaning of this field will be formally defined at a later date.
327
328 Net::AMQP::Protocol::Channel::OpenOk
329 This class implements the class Channel method OpenOk, which is a
330 synchronous method.
331
332 This method signals to the client that the channel is ready for use.
333
334 This class has no fields nor accessors.
335
336 Net::AMQP::Protocol::Channel::Flow
337 This class implements the class Channel method Flow, which is a
338 synchronous method.
339
340 This method asks the peer to pause or restart the flow of content data.
341 This is a simple flow-control mechanism that a peer can use to avoid
342 oveflowing its queues or otherwise finding itself receiving more
343 messages than it can process. Note that this method is not intended for
344 window control. The peer that receives a request to stop sending
345 content should finish sending the current content, if any, and then
346 wait until it receives a Flow restart method.
347
348 Each of the following represents a field in the specification. These
349 are the optional arguments to new() and are also read/write accessors:
350
351 active (type: bit)
352 Start/stop content frames
353
354 If 1, the peer starts sending content frames. If 0, the peer stops
355 sending content frames.
356
357 Net::AMQP::Protocol::Channel::FlowOk
358 This class implements the class Channel method FlowOk, which is an
359 asynchronous method.
360
361 Confirms to the peer that a flow command was received and processed.
362
363 Each of the following represents a field in the specification. These
364 are the optional arguments to new() and are also read/write accessors:
365
366 active (type: bit)
367 Current flow setting
368
369 Confirms the setting of the processed flow method: 1 means the peer
370 will start sending or continue to send content frames; 0 means it
371 will not.
372
373 Net::AMQP::Protocol::Channel::Alert
374 This class implements the class Channel method Alert, which is an
375 asynchronous method.
376
377 This method allows the server to send a non-fatal warning to the
378 client. This is used for methods that are normally asynchronous and
379 thus do not have confirmations, and for which the server may detect
380 errors that need to be reported. Fatal errors are handled as channel or
381 connection exceptions; non-fatal errors are sent through this method.
382
383 Each of the following represents a field in the specification. These
384 are the optional arguments to new() and are also read/write accessors:
385
386 reply_code (type: short)
387 reply_text (type: shortstr)
388 details (type: table)
389 Detailed information for warning
390
391 A set of fields that provide more information about the problem.
392 The meaning of these fields are defined on a per-reply-code basis
393 (TO BE DEFINED).
394
395 Net::AMQP::Protocol::Channel::Close
396 This class implements the class Channel method Close, which is a
397 synchronous method.
398
399 This method indicates that the sender wants to close the channel. This
400 may be due to internal conditions (e.g. a forced shut-down) or due to
401 an error handling a specific method, i.e. an exception. When a close is
402 due to an exception, the sender provides the class and method id of the
403 method which caused the exception.
404
405 Each of the following represents a field in the specification. These
406 are the optional arguments to new() and are also read/write accessors:
407
408 reply_code (type: short)
409 reply_text (type: shortstr)
410 class_id (type: short)
411 Failing method class
412
413 When the close is provoked by a method exception, this is the class
414 of the method.
415
416 method_id (type: short)
417 Failing method ID
418
419 When the close is provoked by a method exception, this is the ID of
420 the method.
421
422 Net::AMQP::Protocol::Channel::CloseOk
423 This class implements the class Channel method CloseOk, which is a
424 synchronous method.
425
426 This method confirms a Channel.Close method and tells the recipient
427 that it is safe to release resources for the channel and close the
428 socket.
429
430 This class has no fields nor accessors.
431
432 Net::AMQP::Protocol::Access::Request
433 This class implements the class Access method Request, which is a
434 synchronous method.
435
436 This method requests an access ticket for an access realm. The server
437 responds by granting the access ticket. If the client does not have
438 access rights to the requested realm this causes a connection
439 exception. Access tickets are a per-channel resource.
440
441 Each of the following represents a field in the specification. These
442 are the optional arguments to new() and are also read/write accessors:
443
444 realm (type: shortstr)
445 Name of requested realm
446
447 exclusive (type: bit)
448 Request exclusive access
449
450 Request exclusive access to the realm. If the server cannot grant
451 this - because there are other active tickets for the realm - it
452 raises a channel exception.
453
454 passive (type: bit)
455 Request passive access
456
457 Request message passive access to the specified access realm.
458 Passive access lets a client get information about resources in the
459 realm but not to make any changes to them.
460
461 active (type: bit)
462 Request active access
463
464 Request message active access to the specified access realm.
465 Acvtive access lets a client get create and delete resources in the
466 realm.
467
468 write (type: bit)
469 Request write access
470
471 Request write access to the specified access realm. Write access
472 lets a client publish messages to all exchanges in the realm.
473
474 read (type: bit)
475 Request read access
476
477 Request read access to the specified access realm. Read access lets
478 a client consume messages from queues in the realm.
479
480 Net::AMQP::Protocol::Access::RequestOk
481 This class implements the class Access method RequestOk, which is a
482 synchronous method.
483
484 This method provides the client with an access ticket. The access
485 ticket is valid within the current channel and for the lifespan of the
486 channel.
487
488 Each of the following represents a field in the specification. These
489 are the optional arguments to new() and are also read/write accessors:
490
491 ticket (type: short)
492
493 Net::AMQP::Protocol::Exchange::Declare
494 This class implements the class Exchange method Declare, which is a
495 synchronous method.
496
497 This method creates an exchange if it does not already exist, and if
498 the exchange exists, verifies that it is of the correct and expected
499 class.
500
501 Each of the following represents a field in the specification. These
502 are the optional arguments to new() and are also read/write accessors:
503
504 ticket (type: short)
505 When a client defines a new exchange, this belongs to the access
506 realm of the ticket used. All further work done with that exchange
507 must be done with an access ticket for the same realm.
508
509 exchange (type: shortstr)
510 type (type: shortstr)
511 Exchange type
512
513 Each exchange belongs to one of a set of exchange types implemented
514 by the server. The exchange types define the functionality of the
515 exchange - i.e. how messages are routed through it. It is not valid
516 or meaningful to attempt to change the type of an existing
517 exchange.
518
519 passive (type: bit)
520 Do not create exchange
521
522 If set, the server will not create the exchange. The client can use
523 this to check whether an exchange exists without modifying the
524 server state.
525
526 durable (type: bit)
527 Request a durable exchange
528
529 If set when creating a new exchange, the exchange will be marked as
530 durable. Durable exchanges remain active when a server restarts.
531 Non-durable exchanges (transient exchanges) are purged if/when a
532 server restarts.
533
534 auto_delete (type: bit)
535 Auto-delete when unused
536
537 If set, the exchange is deleted when all queues have finished using
538 it.
539
540 internal (type: bit)
541 Create internal exchange
542
543 If set, the exchange may not be used directly by publishers, but
544 only when bound to other exchanges. Internal exchanges are used to
545 construct wiring that is not visible to applications.
546
547 nowait (type: bit)
548 Do not send a reply method
549
550 If set, the server will not respond to the method. The client
551 should not wait for a reply method. If the server could not
552 complete the method it will raise a channel or connection
553 exception.
554
555 arguments (type: table)
556 Arguments for declaration
557
558 A set of arguments for the declaration. The syntax and semantics of
559 these arguments depends on the server implementation. This field is
560 ignored if passive is 1.
561
562 Net::AMQP::Protocol::Exchange::DeclareOk
563 This class implements the class Exchange method DeclareOk, which is a
564 synchronous method.
565
566 This method confirms a Declare method and confirms the name of the
567 exchange, essential for automatically-named exchanges.
568
569 This class has no fields nor accessors.
570
571 Net::AMQP::Protocol::Exchange::Delete
572 This class implements the class Exchange method Delete, which is a
573 synchronous method.
574
575 This method deletes an exchange. When an exchange is deleted all queue
576 bindings on the exchange are cancelled.
577
578 Each of the following represents a field in the specification. These
579 are the optional arguments to new() and are also read/write accessors:
580
581 ticket (type: short)
582 exchange (type: shortstr)
583 if_unused (type: bit)
584 Delete only if unused
585
586 If set, the server will only delete the exchange if it has no queue
587 bindings. If the exchange has queue bindings the server does not
588 delete it but raises a channel exception instead.
589
590 nowait (type: bit)
591 Do not send a reply method
592
593 If set, the server will not respond to the method. The client
594 should not wait for a reply method. If the server could not
595 complete the method it will raise a channel or connection
596 exception.
597
598 Net::AMQP::Protocol::Exchange::DeleteOk
599 This class implements the class Exchange method DeleteOk, which is a
600 synchronous method.
601
602 This method confirms the deletion of an exchange.
603
604 This class has no fields nor accessors.
605
606 Net::AMQP::Protocol::Queue::Declare
607 This class implements the class Queue method Declare, which is a
608 synchronous method.
609
610 This method creates or checks a queue. When creating a new queue the
611 client can specify various properties that control the durability of
612 the queue and its contents, and the level of sharing for the queue.
613
614 Each of the following represents a field in the specification. These
615 are the optional arguments to new() and are also read/write accessors:
616
617 ticket (type: short)
618 When a client defines a new queue, this belongs to the access realm
619 of the ticket used. All further work done with that queue must be
620 done with an access ticket for the same realm.
621
622 The client provides a valid access ticket giving "active" access to
623 the realm in which the queue exists or will be created, or
624 "passive" access if the if-exists flag is set.
625
626 queue (type: shortstr)
627 passive (type: bit)
628 Do not create queue
629
630 If set, the server will not create the queue. The client can use
631 this to check whether a queue exists without modifying the server
632 state.
633
634 durable (type: bit)
635 Request a durable queue
636
637 If set when creating a new queue, the queue will be marked as
638 durable. Durable queues remain active when a server restarts. Non-
639 durable queues (transient queues) are purged if/when a server
640 restarts. Note that durable queues do not necessarily hold
641 persistent messages, although it does not make sense to send
642 persistent messages to a transient queue.
643
644 exclusive (type: bit)
645 Request an exclusive queue
646
647 Exclusive queues may only be consumed from by the current
648 connection. Setting the 'exclusive' flag always implies
649 'auto-delete'.
650
651 auto_delete (type: bit)
652 Auto-delete queue when unused
653
654 If set, the queue is deleted when all consumers have finished using
655 it. Last consumer can be cancelled either explicitly or because its
656 channel is closed. If there was no consumer ever on the queue, it
657 won't be deleted.
658
659 nowait (type: bit)
660 Do not send a reply method
661
662 If set, the server will not respond to the method. The client
663 should not wait for a reply method. If the server could not
664 complete the method it will raise a channel or connection
665 exception.
666
667 arguments (type: table)
668 Arguments for declaration
669
670 A set of arguments for the declaration. The syntax and semantics of
671 these arguments depends on the server implementation. This field is
672 ignored if passive is 1.
673
674 Net::AMQP::Protocol::Queue::DeclareOk
675 This class implements the class Queue method DeclareOk, which is a
676 synchronous method.
677
678 This method confirms a Declare method and confirms the name of the
679 queue, essential for automatically-named queues.
680
681 Each of the following represents a field in the specification. These
682 are the optional arguments to new() and are also read/write accessors:
683
684 queue (type: shortstr)
685 Reports the name of the queue. If the server generated a queue
686 name, this field contains that name.
687
688 message_count (type: long)
689 Number of messages in queue
690
691 Reports the number of messages in the queue, which will be zero for
692 newly-created queues.
693
694 consumer_count (type: long)
695 Number of consumers
696
697 Reports the number of active consumers for the queue. Note that
698 consumers can suspend activity (Channel.Flow) in which case they do
699 not appear in this count.
700
701 Net::AMQP::Protocol::Queue::Bind
702 This class implements the class Queue method Bind, which is a
703 synchronous method.
704
705 This method binds a queue to an exchange. Until a queue is bound it
706 will not receive any messages. In a classic messaging model, store-and-
707 forward queues are bound to a dest exchange and subscription queues are
708 bound to a dest_wild exchange.
709
710 Each of the following represents a field in the specification. These
711 are the optional arguments to new() and are also read/write accessors:
712
713 ticket (type: short)
714 The client provides a valid access ticket giving "active" access
715 rights to the queue's access realm.
716
717 queue (type: shortstr)
718 Specifies the name of the queue to bind. If the queue name is
719 empty, refers to the current queue for the channel, which is the
720 last declared queue.
721
722 exchange (type: shortstr)
723 The name of the exchange to bind to.
724
725 routing_key (type: shortstr)
726 Message routing key
727
728 Specifies the routing key for the binding. The routing key is used
729 for routing messages depending on the exchange configuration. Not
730 all exchanges use a routing key - refer to the specific exchange
731 documentation. If the routing key is empty and the queue name is
732 empty, the routing key will be the current queue for the channel,
733 which is the last declared queue.
734
735 nowait (type: bit)
736 Do not send a reply method
737
738 If set, the server will not respond to the method. The client
739 should not wait for a reply method. If the server could not
740 complete the method it will raise a channel or connection
741 exception.
742
743 arguments (type: table)
744 Arguments for binding
745
746 A set of arguments for the binding. The syntax and semantics of
747 these arguments depends on the exchange class.
748
749 Net::AMQP::Protocol::Queue::BindOk
750 This class implements the class Queue method BindOk, which is a
751 synchronous method.
752
753 This method confirms that the bind was successful.
754
755 This class has no fields nor accessors.
756
757 Net::AMQP::Protocol::Queue::Purge
758 This class implements the class Queue method Purge, which is a
759 synchronous method.
760
761 This method removes all messages from a queue. It does not cancel
762 consumers. Purged messages are deleted without any formal "undo"
763 mechanism.
764
765 Each of the following represents a field in the specification. These
766 are the optional arguments to new() and are also read/write accessors:
767
768 ticket (type: short)
769 The access ticket must be for the access realm that holds the
770 queue.
771
772 queue (type: shortstr)
773 Specifies the name of the queue to purge. If the queue name is
774 empty, refers to the current queue for the channel, which is the
775 last declared queue.
776
777 nowait (type: bit)
778 Do not send a reply method
779
780 If set, the server will not respond to the method. The client
781 should not wait for a reply method. If the server could not
782 complete the method it will raise a channel or connection
783 exception.
784
785 Net::AMQP::Protocol::Queue::PurgeOk
786 This class implements the class Queue method PurgeOk, which is a
787 synchronous method.
788
789 This method confirms the purge of a queue.
790
791 Each of the following represents a field in the specification. These
792 are the optional arguments to new() and are also read/write accessors:
793
794 message_count (type: long)
795 Number of messages purged
796
797 Reports the number of messages purged.
798
799 Net::AMQP::Protocol::Queue::Delete
800 This class implements the class Queue method Delete, which is a
801 synchronous method.
802
803 This method deletes a queue. When a queue is deleted any pending
804 messages are sent to a dead-letter queue if this is defined in the
805 server configuration, and all consumers on the queue are cancelled.
806
807 Each of the following represents a field in the specification. These
808 are the optional arguments to new() and are also read/write accessors:
809
810 ticket (type: short)
811 The client provides a valid access ticket giving "active" access
812 rights to the queue's access realm.
813
814 queue (type: shortstr)
815 Specifies the name of the queue to delete. If the queue name is
816 empty, refers to the current queue for the channel, which is the
817 last declared queue.
818
819 if_unused (type: bit)
820 Delete only if unused
821
822 If set, the server will only delete the queue if it has no
823 consumers. If the queue has consumers the server does does not
824 delete it but raises a channel exception instead.
825
826 if_empty (type: bit)
827 Delete only if empty
828
829 If set, the server will only delete the queue if it has no
830 messages. If the queue is not empty the server raises a channel
831 exception.
832
833 nowait (type: bit)
834 Do not send a reply method
835
836 If set, the server will not respond to the method. The client
837 should not wait for a reply method. If the server could not
838 complete the method it will raise a channel or connection
839 exception.
840
841 Net::AMQP::Protocol::Queue::DeleteOk
842 This class implements the class Queue method DeleteOk, which is a
843 synchronous method.
844
845 This method confirms the deletion of a queue.
846
847 Each of the following represents a field in the specification. These
848 are the optional arguments to new() and are also read/write accessors:
849
850 message_count (type: long)
851 Number of messages purged
852
853 Reports the number of messages purged.
854
855 Net::AMQP::Protocol::Basic::Qos
856 This class implements the class Basic method Qos, which is a
857 synchronous method.
858
859 This method requests a specific quality of service. The QoS can be
860 specified for the current channel or for all channels on the
861 connection. The particular properties and semantics of a qos method
862 always depend on the content class semantics. Though the qos method
863 could in principle apply to both peers, it is currently meaningful only
864 for the server.
865
866 Each of the following represents a field in the specification. These
867 are the optional arguments to new() and are also read/write accessors:
868
869 prefetch_size (type: long)
870 Prefetch window in octets
871
872 The client can request that messages be sent in advance so that
873 when the client finishes processing a message, the following
874 message is already held locally, rather than needing to be sent
875 down the channel. Prefetching gives a performance improvement. This
876 field specifies the prefetch window size in octets. The server will
877 send a message in advance if it is equal to or smaller in size than
878 the available prefetch size (and also falls into other prefetch
879 limits). May be set to zero, meaning "no specific limit", although
880 other prefetch limits may still apply. The prefetch-size is ignored
881 if the no-ack option is set.
882
883 prefetch_count (type: short)
884 Prefetch window in messages
885
886 Specifies a prefetch window in terms of whole messages. This field
887 may be used in combination with the prefetch-size field; a message
888 will only be sent in advance if both prefetch windows (and those at
889 the channel and connection level) allow it. The prefetch-count is
890 ignored if the no-ack option is set.
891
892 global (type: bit)
893 Apply to entire connection
894
895 By default the QoS settings apply to the current channel only. If
896 this field is set, they are applied to the entire connection.
897
898 Net::AMQP::Protocol::Basic::QosOk
899 This class implements the class Basic method QosOk, which is a
900 synchronous method.
901
902 This method tells the client that the requested QoS levels could be
903 handled by the server. The requested QoS applies to all active
904 consumers until a new QoS is defined.
905
906 This class has no fields nor accessors.
907
908 Net::AMQP::Protocol::Basic::Consume
909 This class implements the class Basic method Consume, which is a
910 synchronous method.
911
912 This method asks the server to start a "consumer", which is a transient
913 request for messages from a specific queue. Consumers last as long as
914 the channel they were created on, or until the client cancels them.
915
916 Each of the following represents a field in the specification. These
917 are the optional arguments to new() and are also read/write accessors:
918
919 ticket (type: short)
920 queue (type: shortstr)
921 Specifies the name of the queue to consume from. If the queue name
922 is null, refers to the current queue for the channel, which is the
923 last declared queue.
924
925 consumer_tag (type: shortstr)
926 Specifies the identifier for the consumer. The consumer tag is
927 local to a connection, so two clients can use the same consumer
928 tags. If this field is empty the server will generate a unique tag.
929
930 no_local (type: bit)
931 no_ack (type: bit)
932 exclusive (type: bit)
933 Request exclusive access
934
935 Request exclusive consumer access, meaning only this consumer can
936 access the queue.
937
938 nowait (type: bit)
939 Do not send a reply method
940
941 If set, the server will not respond to the method. The client
942 should not wait for a reply method. If the server could not
943 complete the method it will raise a channel or connection
944 exception.
945
946 Net::AMQP::Protocol::Basic::ConsumeOk
947 This class implements the class Basic method ConsumeOk, which is a
948 synchronous method.
949
950 The server provides the client with a consumer tag, which is used by
951 the client for methods called on the consumer at a later stage.
952
953 Each of the following represents a field in the specification. These
954 are the optional arguments to new() and are also read/write accessors:
955
956 consumer_tag (type: shortstr)
957 Holds the consumer tag specified by the client or provided by the
958 server.
959
960 Net::AMQP::Protocol::Basic::Cancel
961 This class implements the class Basic method Cancel, which is a
962 synchronous method.
963
964 This method cancels a consumer. This does not affect already delivered
965 messages, but it does mean the server will not send any more messages
966 for that consumer. The client may receive an abitrary number of
967 messages in between sending the cancel method and receiving the cancel-
968 ok reply.
969
970 Each of the following represents a field in the specification. These
971 are the optional arguments to new() and are also read/write accessors:
972
973 consumer_tag (type: shortstr)
974 nowait (type: bit)
975 Do not send a reply method
976
977 If set, the server will not respond to the method. The client
978 should not wait for a reply method. If the server could not
979 complete the method it will raise a channel or connection
980 exception.
981
982 Net::AMQP::Protocol::Basic::CancelOk
983 This class implements the class Basic method CancelOk, which is a
984 synchronous method.
985
986 This method confirms that the cancellation was completed.
987
988 Each of the following represents a field in the specification. These
989 are the optional arguments to new() and are also read/write accessors:
990
991 consumer_tag (type: shortstr)
992
993 Net::AMQP::Protocol::Basic::Publish
994 This class implements the class Basic method Publish, which is an
995 asynchronous method.
996
997 This method publishes a message to a specific exchange. The message
998 will be routed to queues as defined by the exchange configuration and
999 distributed to any active consumers when the transaction, if any, is
1000 committed.
1001
1002 Each of the following represents a field in the specification. These
1003 are the optional arguments to new() and are also read/write accessors:
1004
1005 ticket (type: short)
1006 exchange (type: shortstr)
1007 Specifies the name of the exchange to publish to. The exchange name
1008 can be empty, meaning the default exchange. If the exchange name is
1009 specified, and that exchange does not exist, the server will raise
1010 a channel exception.
1011
1012 routing_key (type: shortstr)
1013 Message routing key
1014
1015 Specifies the routing key for the message. The routing key is used
1016 for routing messages depending on the exchange configuration.
1017
1018 mandatory (type: bit)
1019 Indicate mandatory routing
1020
1021 This flag tells the server how to react if the message cannot be
1022 routed to a queue. If this flag is set, the server will return an
1023 unroutable message with a Return method. If this flag is zero, the
1024 server silently drops the message.
1025
1026 immediate (type: bit)
1027 Request immediate delivery
1028
1029 This flag tells the server how to react if the message cannot be
1030 routed to a queue consumer immediately. If this flag is set, the
1031 server will return an undeliverable message with a Return method.
1032 If this flag is zero, the server will queue the message, but with
1033 no guarantee that it will ever be consumed.
1034
1035 Net::AMQP::Protocol::Basic::Return
1036 This class implements the class Basic method Return, which is an
1037 asynchronous method.
1038
1039 This method returns an undeliverable message that was published with
1040 the "immediate" flag set, or an unroutable message published with the
1041 "mandatory" flag set. The reply code and text provide information about
1042 the reason that the message was undeliverable.
1043
1044 Each of the following represents a field in the specification. These
1045 are the optional arguments to new() and are also read/write accessors:
1046
1047 reply_code (type: short)
1048 reply_text (type: shortstr)
1049 exchange (type: shortstr)
1050 Specifies the name of the exchange that the message was originally
1051 published to.
1052
1053 routing_key (type: shortstr)
1054 Message routing key
1055
1056 Specifies the routing key name specified when the message was
1057 published.
1058
1059 Net::AMQP::Protocol::Basic::Deliver
1060 This class implements the class Basic method Deliver, which is an
1061 asynchronous method.
1062
1063 This method delivers a message to the client, via a consumer. In the
1064 asynchronous message delivery model, the client starts a consumer using
1065 the Consume method, then the server responds with Deliver methods as
1066 and when messages arrive for that consumer.
1067
1068 Each of the following represents a field in the specification. These
1069 are the optional arguments to new() and are also read/write accessors:
1070
1071 consumer_tag (type: shortstr)
1072 delivery_tag (type: longlong)
1073 redelivered (type: bit)
1074 exchange (type: shortstr)
1075 Specifies the name of the exchange that the message was originally
1076 published to.
1077
1078 routing_key (type: shortstr)
1079 Message routing key
1080
1081 Specifies the routing key name specified when the message was
1082 published.
1083
1084 Net::AMQP::Protocol::Basic::Get
1085 This class implements the class Basic method Get, which is a
1086 synchronous method.
1087
1088 This method provides a direct access to the messages in a queue using a
1089 synchronous dialogue that is designed for specific types of application
1090 where synchronous functionality is more important than performance.
1091
1092 Each of the following represents a field in the specification. These
1093 are the optional arguments to new() and are also read/write accessors:
1094
1095 ticket (type: short)
1096 queue (type: shortstr)
1097 Specifies the name of the queue to consume from. If the queue name
1098 is null, refers to the current queue for the channel, which is the
1099 last declared queue.
1100
1101 no_ack (type: bit)
1102
1103 Net::AMQP::Protocol::Basic::GetOk
1104 This class implements the class Basic method GetOk, which is a
1105 synchronous method.
1106
1107 This method delivers a message to the client following a get method. A
1108 message delivered by 'get-ok' must be acknowledged unless the no-ack
1109 option was set in the get method.
1110
1111 Each of the following represents a field in the specification. These
1112 are the optional arguments to new() and are also read/write accessors:
1113
1114 delivery_tag (type: longlong)
1115 redelivered (type: bit)
1116 exchange (type: shortstr)
1117 Specifies the name of the exchange that the message was originally
1118 published to. If empty, the message was published to the default
1119 exchange.
1120
1121 routing_key (type: shortstr)
1122 Message routing key
1123
1124 Specifies the routing key name specified when the message was
1125 published.
1126
1127 message_count (type: long)
1128 Number of messages pending
1129
1130 This field reports the number of messages pending on the queue,
1131 excluding the message being delivered. Note that this figure is
1132 indicative, not reliable, and can change arbitrarily as messages
1133 are added to the queue and removed by other clients.
1134
1135 Net::AMQP::Protocol::Basic::GetEmpty
1136 This class implements the class Basic method GetEmpty, which is a
1137 synchronous method.
1138
1139 This method tells the client that the queue has no messages available
1140 for the client.
1141
1142 Each of the following represents a field in the specification. These
1143 are the optional arguments to new() and are also read/write accessors:
1144
1145 cluster_id (type: shortstr)
1146 Cluster id
1147
1148 For use by cluster applications, should not be used by client
1149 applications.
1150
1151 Net::AMQP::Protocol::Basic::Ack
1152 This class implements the class Basic method Ack, which is an
1153 asynchronous method.
1154
1155 This method acknowledges one or more messages delivered via the Deliver
1156 or Get-Ok methods. The client can ask to confirm a single message or a
1157 set of messages up to and including a specific message.
1158
1159 Each of the following represents a field in the specification. These
1160 are the optional arguments to new() and are also read/write accessors:
1161
1162 delivery_tag (type: longlong)
1163 multiple (type: bit)
1164 Acknowledge multiple messages
1165
1166 If set to 1, the delivery tag is treated as "up to and including",
1167 so that the client can acknowledge multiple messages with a single
1168 method. If set to zero, the delivery tag refers to a single
1169 message. If the multiple field is 1, and the delivery tag is zero,
1170 tells the server to acknowledge all outstanding mesages.
1171
1172 Net::AMQP::Protocol::Basic::Reject
1173 This class implements the class Basic method Reject, which is an
1174 asynchronous method.
1175
1176 This method allows a client to reject a message. It can be used to
1177 interrupt and cancel large incoming messages, or return untreatable
1178 messages to their original queue.
1179
1180 Each of the following represents a field in the specification. These
1181 are the optional arguments to new() and are also read/write accessors:
1182
1183 delivery_tag (type: longlong)
1184 requeue (type: bit)
1185 Requeue the message
1186
1187 If this field is zero, the message will be discarded. If this bit
1188 is 1, the server will attempt to requeue the message.
1189
1190 Net::AMQP::Protocol::Basic::Recover
1191 This class implements the class Basic method Recover, which is an
1192 asynchronous method.
1193
1194 This method asks the broker to redeliver all unacknowledged messages on
1195 a specifieid channel. Zero or more messages may be redelivered.
1196
1197 Each of the following represents a field in the specification. These
1198 are the optional arguments to new() and are also read/write accessors:
1199
1200 requeue (type: bit)
1201 Requeue the message
1202
1203 If this field is zero, the message will be redelivered to the
1204 original recipient. If this bit is 1, the server will attempt to
1205 requeue the message, potentially then delivering it to an
1206 alternative subscriber.
1207
1208 Net::AMQP::Protocol::Basic::ContentHeader
1209 This class implements the class Basic method ContentHeader, which is an
1210 asynchronous method.
1211
1212 Each of the following represents a field in the specification. These
1213 are the optional arguments to new() and are also read/write accessors:
1214
1215 content_type (type: shortstr)
1216 content_encoding (type: shortstr)
1217 headers (type: table)
1218 delivery_mode (type: octet)
1219 priority (type: octet)
1220 correlation_id (type: shortstr)
1221 reply_to (type: shortstr)
1222 expiration (type: shortstr)
1223 message_id (type: shortstr)
1224 timestamp (type: timestamp)
1225 type (type: shortstr)
1226 user_id (type: shortstr)
1227 app_id (type: shortstr)
1228 cluster_id (type: shortstr)
1229
1230 Net::AMQP::Protocol::File::Qos
1231 This class implements the class File method Qos, which is a synchronous
1232 method.
1233
1234 This method requests a specific quality of service. The QoS can be
1235 specified for the current channel or for all channels on the
1236 connection. The particular properties and semantics of a qos method
1237 always depend on the content class semantics. Though the qos method
1238 could in principle apply to both peers, it is currently meaningful only
1239 for the server.
1240
1241 Each of the following represents a field in the specification. These
1242 are the optional arguments to new() and are also read/write accessors:
1243
1244 prefetch_size (type: long)
1245 Prefetch window in octets
1246
1247 The client can request that messages be sent in advance so that
1248 when the client finishes processing a message, the following
1249 message is already held locally, rather than needing to be sent
1250 down the channel. Prefetching gives a performance improvement. This
1251 field specifies the prefetch window size in octets. May be set to
1252 zero, meaning "no specific limit". Note that other prefetch limits
1253 may still apply. The prefetch-size is ignored if the no-ack option
1254 is set.
1255
1256 prefetch_count (type: short)
1257 Prefetch window in messages
1258
1259 Specifies a prefetch window in terms of whole messages. This is
1260 compatible with some file API implementations. This field may be
1261 used in combination with the prefetch-size field; a message will
1262 only be sent in advance if both prefetch windows (and those at the
1263 channel and connection level) allow it. The prefetch-count is
1264 ignored if the no-ack option is set.
1265
1266 global (type: bit)
1267 Apply to entire connection
1268
1269 By default the QoS settings apply to the current channel only. If
1270 this field is set, they are applied to the entire connection.
1271
1272 Net::AMQP::Protocol::File::QosOk
1273 This class implements the class File method QosOk, which is a
1274 synchronous method.
1275
1276 This method tells the client that the requested QoS levels could be
1277 handled by the server. The requested QoS applies to all active
1278 consumers until a new QoS is defined.
1279
1280 This class has no fields nor accessors.
1281
1282 Net::AMQP::Protocol::File::Consume
1283 This class implements the class File method Consume, which is a
1284 synchronous method.
1285
1286 This method asks the server to start a "consumer", which is a transient
1287 request for messages from a specific queue. Consumers last as long as
1288 the channel they were created on, or until the client cancels them.
1289
1290 Each of the following represents a field in the specification. These
1291 are the optional arguments to new() and are also read/write accessors:
1292
1293 ticket (type: short)
1294 queue (type: shortstr)
1295 Specifies the name of the queue to consume from. If the queue name
1296 is null, refers to the current queue for the channel, which is the
1297 last declared queue.
1298
1299 consumer_tag (type: shortstr)
1300 Specifies the identifier for the consumer. The consumer tag is
1301 local to a connection, so two clients can use the same consumer
1302 tags. If this field is empty the server will generate a unique tag.
1303
1304 no_local (type: bit)
1305 no_ack (type: bit)
1306 exclusive (type: bit)
1307 Request exclusive access
1308
1309 Request exclusive consumer access, meaning only this consumer can
1310 access the queue.
1311
1312 nowait (type: bit)
1313 Do not send a reply method
1314
1315 If set, the server will not respond to the method. The client
1316 should not wait for a reply method. If the server could not
1317 complete the method it will raise a channel or connection
1318 exception.
1319
1320 Net::AMQP::Protocol::File::ConsumeOk
1321 This class implements the class File method ConsumeOk, which is a
1322 synchronous method.
1323
1324 This method provides the client with a consumer tag which it MUST use
1325 in methods that work with the consumer.
1326
1327 Each of the following represents a field in the specification. These
1328 are the optional arguments to new() and are also read/write accessors:
1329
1330 consumer_tag (type: shortstr)
1331 Holds the consumer tag specified by the client or provided by the
1332 server.
1333
1334 Net::AMQP::Protocol::File::Cancel
1335 This class implements the class File method Cancel, which is a
1336 synchronous method.
1337
1338 This method cancels a consumer. This does not affect already delivered
1339 messages, but it does mean the server will not send any more messages
1340 for that consumer.
1341
1342 Each of the following represents a field in the specification. These
1343 are the optional arguments to new() and are also read/write accessors:
1344
1345 consumer_tag (type: shortstr)
1346 nowait (type: bit)
1347 Do not send a reply method
1348
1349 If set, the server will not respond to the method. The client
1350 should not wait for a reply method. If the server could not
1351 complete the method it will raise a channel or connection
1352 exception.
1353
1354 Net::AMQP::Protocol::File::CancelOk
1355 This class implements the class File method CancelOk, which is a
1356 synchronous method.
1357
1358 This method confirms that the cancellation was completed.
1359
1360 Each of the following represents a field in the specification. These
1361 are the optional arguments to new() and are also read/write accessors:
1362
1363 consumer_tag (type: shortstr)
1364
1365 Net::AMQP::Protocol::File::Open
1366 This class implements the class File method Open, which is a
1367 synchronous method.
1368
1369 This method requests permission to start staging a message. Staging
1370 means sending the message into a temporary area at the recipient end
1371 and then delivering the message by referring to this temporary area.
1372 Staging is how the protocol handles partial file transfers - if a
1373 message is partially staged and the connection breaks, the next time
1374 the sender starts to stage it, it can restart from where it left off.
1375
1376 Each of the following represents a field in the specification. These
1377 are the optional arguments to new() and are also read/write accessors:
1378
1379 identifier (type: shortstr)
1380 Staging identifier
1381
1382 This is the staging identifier. This is an arbitrary string chosen
1383 by the sender. For staging to work correctly the sender must use
1384 the same staging identifier when staging the same message a second
1385 time after recovery from a failure. A good choice for the staging
1386 identifier would be the SHA1 hash of the message properties data
1387 (including the original filename, revised time, etc.).
1388
1389 content_size (type: longlong)
1390 Message content size
1391
1392 The size of the content in octets. The recipient may use this
1393 information to allocate or check available space in advance, to
1394 avoid "disk full" errors during staging of very large messages.
1395
1396 Net::AMQP::Protocol::File::OpenOk
1397 This class implements the class File method OpenOk, which is a
1398 synchronous method.
1399
1400 This method confirms that the recipient is ready to accept staged data.
1401 If the message was already partially-staged at a previous time the
1402 recipient will report the number of octets already staged.
1403
1404 Each of the following represents a field in the specification. These
1405 are the optional arguments to new() and are also read/write accessors:
1406
1407 staged_size (type: longlong)
1408 Already staged amount
1409
1410 The amount of previously-staged content in octets. For a new
1411 message this will be zero.
1412
1413 Net::AMQP::Protocol::File::Stage
1414 This class implements the class File method Stage, which is an
1415 asynchronous method.
1416
1417 This method stages the message, sending the message content to the
1418 recipient from the octet offset specified in the Open-Ok method.
1419
1420 This class has no fields nor accessors.
1421
1422 Net::AMQP::Protocol::File::Publish
1423 This class implements the class File method Publish, which is an
1424 asynchronous method.
1425
1426 This method publishes a staged file message to a specific exchange. The
1427 file message will be routed to queues as defined by the exchange
1428 configuration and distributed to any active consumers when the
1429 transaction, if any, is committed.
1430
1431 Each of the following represents a field in the specification. These
1432 are the optional arguments to new() and are also read/write accessors:
1433
1434 ticket (type: short)
1435 exchange (type: shortstr)
1436 Specifies the name of the exchange to publish to. The exchange name
1437 can be empty, meaning the default exchange. If the exchange name is
1438 specified, and that exchange does not exist, the server will raise
1439 a channel exception.
1440
1441 routing_key (type: shortstr)
1442 Message routing key
1443
1444 Specifies the routing key for the message. The routing key is used
1445 for routing messages depending on the exchange configuration.
1446
1447 mandatory (type: bit)
1448 Indicate mandatory routing
1449
1450 This flag tells the server how to react if the message cannot be
1451 routed to a queue. If this flag is set, the server will return an
1452 unroutable message with a Return method. If this flag is zero, the
1453 server silently drops the message.
1454
1455 immediate (type: bit)
1456 Request immediate delivery
1457
1458 This flag tells the server how to react if the message cannot be
1459 routed to a queue consumer immediately. If this flag is set, the
1460 server will return an undeliverable message with a Return method.
1461 If this flag is zero, the server will queue the message, but with
1462 no guarantee that it will ever be consumed.
1463
1464 identifier (type: shortstr)
1465 Staging identifier
1466
1467 This is the staging identifier of the message to publish. The
1468 message must have been staged. Note that a client can send the
1469 Publish method asynchronously without waiting for staging to
1470 finish.
1471
1472 Net::AMQP::Protocol::File::Return
1473 This class implements the class File method Return, which is an
1474 asynchronous method.
1475
1476 This method returns an undeliverable message that was published with
1477 the "immediate" flag set, or an unroutable message published with the
1478 "mandatory" flag set. The reply code and text provide information about
1479 the reason that the message was undeliverable.
1480
1481 Each of the following represents a field in the specification. These
1482 are the optional arguments to new() and are also read/write accessors:
1483
1484 reply_code (type: short)
1485 reply_text (type: shortstr)
1486 exchange (type: shortstr)
1487 Specifies the name of the exchange that the message was originally
1488 published to.
1489
1490 routing_key (type: shortstr)
1491 Message routing key
1492
1493 Specifies the routing key name specified when the message was
1494 published.
1495
1496 Net::AMQP::Protocol::File::Deliver
1497 This class implements the class File method Deliver, which is an
1498 asynchronous method.
1499
1500 This method delivers a staged file message to the client, via a
1501 consumer. In the asynchronous message delivery model, the client starts
1502 a consumer using the Consume method, then the server responds with
1503 Deliver methods as and when messages arrive for that consumer.
1504
1505 Each of the following represents a field in the specification. These
1506 are the optional arguments to new() and are also read/write accessors:
1507
1508 consumer_tag (type: shortstr)
1509 delivery_tag (type: longlong)
1510 redelivered (type: bit)
1511 exchange (type: shortstr)
1512 Specifies the name of the exchange that the message was originally
1513 published to.
1514
1515 routing_key (type: shortstr)
1516 Message routing key
1517
1518 Specifies the routing key name specified when the message was
1519 published.
1520
1521 identifier (type: shortstr)
1522 Staging identifier
1523
1524 This is the staging identifier of the message to deliver. The
1525 message must have been staged. Note that a server can send the
1526 Deliver method asynchronously without waiting for staging to
1527 finish.
1528
1529 Net::AMQP::Protocol::File::Ack
1530 This class implements the class File method Ack, which is an
1531 asynchronous method.
1532
1533 This method acknowledges one or more messages delivered via the Deliver
1534 method. The client can ask to confirm a single message or a set of
1535 messages up to and including a specific message.
1536
1537 Each of the following represents a field in the specification. These
1538 are the optional arguments to new() and are also read/write accessors:
1539
1540 delivery_tag (type: longlong)
1541 multiple (type: bit)
1542 Acknowledge multiple messages
1543
1544 If set to 1, the delivery tag is treated as "up to and including",
1545 so that the client can acknowledge multiple messages with a single
1546 method. If set to zero, the delivery tag refers to a single
1547 message. If the multiple field is 1, and the delivery tag is zero,
1548 tells the server to acknowledge all outstanding mesages.
1549
1550 Net::AMQP::Protocol::File::Reject
1551 This class implements the class File method Reject, which is an
1552 asynchronous method.
1553
1554 This method allows a client to reject a message. It can be used to
1555 return untreatable messages to their original queue. Note that file
1556 content is staged before delivery, so the client will not use this
1557 method to interrupt delivery of a large message.
1558
1559 Each of the following represents a field in the specification. These
1560 are the optional arguments to new() and are also read/write accessors:
1561
1562 delivery_tag (type: longlong)
1563 requeue (type: bit)
1564 Requeue the message
1565
1566 If this field is zero, the message will be discarded. If this bit
1567 is 1, the server will attempt to requeue the message.
1568
1569 Net::AMQP::Protocol::File::ContentHeader
1570 This class implements the class File method ContentHeader, which is an
1571 asynchronous method.
1572
1573 Each of the following represents a field in the specification. These
1574 are the optional arguments to new() and are also read/write accessors:
1575
1576 content_type (type: shortstr)
1577 content_encoding (type: shortstr)
1578 headers (type: table)
1579 priority (type: octet)
1580 reply_to (type: shortstr)
1581 message_id (type: shortstr)
1582 filename (type: shortstr)
1583 timestamp (type: timestamp)
1584 cluster_id (type: shortstr)
1585
1586 Net::AMQP::Protocol::Stream::Qos
1587 This class implements the class Stream method Qos, which is a
1588 synchronous method.
1589
1590 This method requests a specific quality of service. The QoS can be
1591 specified for the current channel or for all channels on the
1592 connection. The particular properties and semantics of a qos method
1593 always depend on the content class semantics. Though the qos method
1594 could in principle apply to both peers, it is currently meaningful only
1595 for the server.
1596
1597 Each of the following represents a field in the specification. These
1598 are the optional arguments to new() and are also read/write accessors:
1599
1600 prefetch_size (type: long)
1601 Prefetch window in octets
1602
1603 The client can request that messages be sent in advance so that
1604 when the client finishes processing a message, the following
1605 message is already held locally, rather than needing to be sent
1606 down the channel. Prefetching gives a performance improvement. This
1607 field specifies the prefetch window size in octets. May be set to
1608 zero, meaning "no specific limit". Note that other prefetch limits
1609 may still apply.
1610
1611 prefetch_count (type: short)
1612 Prefetch window in messages
1613
1614 Specifies a prefetch window in terms of whole messages. This field
1615 may be used in combination with the prefetch-size field; a message
1616 will only be sent in advance if both prefetch windows (and those at
1617 the channel and connection level) allow it.
1618
1619 consume_rate (type: long)
1620 Transfer rate in octets/second
1621
1622 Specifies a desired transfer rate in octets per second. This is
1623 usually determined by the application that uses the streaming data.
1624 A value of zero means "no limit", i.e. as rapidly as possible.
1625
1626 global (type: bit)
1627 Apply to entire connection
1628
1629 By default the QoS settings apply to the current channel only. If
1630 this field is set, they are applied to the entire connection.
1631
1632 Net::AMQP::Protocol::Stream::QosOk
1633 This class implements the class Stream method QosOk, which is a
1634 synchronous method.
1635
1636 This method tells the client that the requested QoS levels could be
1637 handled by the server. The requested QoS applies to all active
1638 consumers until a new QoS is defined.
1639
1640 This class has no fields nor accessors.
1641
1642 Net::AMQP::Protocol::Stream::Consume
1643 This class implements the class Stream method Consume, which is a
1644 synchronous method.
1645
1646 This method asks the server to start a "consumer", which is a transient
1647 request for messages from a specific queue. Consumers last as long as
1648 the channel they were created on, or until the client cancels them.
1649
1650 Each of the following represents a field in the specification. These
1651 are the optional arguments to new() and are also read/write accessors:
1652
1653 ticket (type: short)
1654 queue (type: shortstr)
1655 Specifies the name of the queue to consume from. If the queue name
1656 is null, refers to the current queue for the channel, which is the
1657 last declared queue.
1658
1659 consumer_tag (type: shortstr)
1660 Specifies the identifier for the consumer. The consumer tag is
1661 local to a connection, so two clients can use the same consumer
1662 tags. If this field is empty the server will generate a unique tag.
1663
1664 no_local (type: bit)
1665 exclusive (type: bit)
1666 Request exclusive access
1667
1668 Request exclusive consumer access, meaning only this consumer can
1669 access the queue.
1670
1671 nowait (type: bit)
1672 Do not send a reply method
1673
1674 If set, the server will not respond to the method. The client
1675 should not wait for a reply method. If the server could not
1676 complete the method it will raise a channel or connection
1677 exception.
1678
1679 Net::AMQP::Protocol::Stream::ConsumeOk
1680 This class implements the class Stream method ConsumeOk, which is a
1681 synchronous method.
1682
1683 This method provides the client with a consumer tag which it may use in
1684 methods that work with the consumer.
1685
1686 Each of the following represents a field in the specification. These
1687 are the optional arguments to new() and are also read/write accessors:
1688
1689 consumer_tag (type: shortstr)
1690 Holds the consumer tag specified by the client or provided by the
1691 server.
1692
1693 Net::AMQP::Protocol::Stream::Cancel
1694 This class implements the class Stream method Cancel, which is a
1695 synchronous method.
1696
1697 This method cancels a consumer. Since message delivery is asynchronous
1698 the client may continue to receive messages for a short while after
1699 canceling a consumer. It may process or discard these as appropriate.
1700
1701 Each of the following represents a field in the specification. These
1702 are the optional arguments to new() and are also read/write accessors:
1703
1704 consumer_tag (type: shortstr)
1705 nowait (type: bit)
1706 Do not send a reply method
1707
1708 If set, the server will not respond to the method. The client
1709 should not wait for a reply method. If the server could not
1710 complete the method it will raise a channel or connection
1711 exception.
1712
1713 Net::AMQP::Protocol::Stream::CancelOk
1714 This class implements the class Stream method CancelOk, which is a
1715 synchronous method.
1716
1717 This method confirms that the cancellation was completed.
1718
1719 Each of the following represents a field in the specification. These
1720 are the optional arguments to new() and are also read/write accessors:
1721
1722 consumer_tag (type: shortstr)
1723
1724 Net::AMQP::Protocol::Stream::Publish
1725 This class implements the class Stream method Publish, which is an
1726 asynchronous method.
1727
1728 This method publishes a message to a specific exchange. The message
1729 will be routed to queues as defined by the exchange configuration and
1730 distributed to any active consumers as appropriate.
1731
1732 Each of the following represents a field in the specification. These
1733 are the optional arguments to new() and are also read/write accessors:
1734
1735 ticket (type: short)
1736 exchange (type: shortstr)
1737 Specifies the name of the exchange to publish to. The exchange name
1738 can be empty, meaning the default exchange. If the exchange name is
1739 specified, and that exchange does not exist, the server will raise
1740 a channel exception.
1741
1742 routing_key (type: shortstr)
1743 Message routing key
1744
1745 Specifies the routing key for the message. The routing key is used
1746 for routing messages depending on the exchange configuration.
1747
1748 mandatory (type: bit)
1749 Indicate mandatory routing
1750
1751 This flag tells the server how to react if the message cannot be
1752 routed to a queue. If this flag is set, the server will return an
1753 unroutable message with a Return method. If this flag is zero, the
1754 server silently drops the message.
1755
1756 immediate (type: bit)
1757 Request immediate delivery
1758
1759 This flag tells the server how to react if the message cannot be
1760 routed to a queue consumer immediately. If this flag is set, the
1761 server will return an undeliverable message with a Return method.
1762 If this flag is zero, the server will queue the message, but with
1763 no guarantee that it will ever be consumed.
1764
1765 Net::AMQP::Protocol::Stream::Return
1766 This class implements the class Stream method Return, which is an
1767 asynchronous method.
1768
1769 This method returns an undeliverable message that was published with
1770 the "immediate" flag set, or an unroutable message published with the
1771 "mandatory" flag set. The reply code and text provide information about
1772 the reason that the message was undeliverable.
1773
1774 Each of the following represents a field in the specification. These
1775 are the optional arguments to new() and are also read/write accessors:
1776
1777 reply_code (type: short)
1778 reply_text (type: shortstr)
1779 exchange (type: shortstr)
1780 Specifies the name of the exchange that the message was originally
1781 published to.
1782
1783 routing_key (type: shortstr)
1784 Message routing key
1785
1786 Specifies the routing key name specified when the message was
1787 published.
1788
1789 Net::AMQP::Protocol::Stream::Deliver
1790 This class implements the class Stream method Deliver, which is an
1791 asynchronous method.
1792
1793 This method delivers a message to the client, via a consumer. In the
1794 asynchronous message delivery model, the client starts a consumer using
1795 the Consume method, then the server responds with Deliver methods as
1796 and when messages arrive for that consumer.
1797
1798 Each of the following represents a field in the specification. These
1799 are the optional arguments to new() and are also read/write accessors:
1800
1801 consumer_tag (type: shortstr)
1802 delivery_tag (type: longlong)
1803 exchange (type: shortstr)
1804 Specifies the name of the exchange that the message was originally
1805 published to.
1806
1807 queue (type: shortstr)
1808 Specifies the name of the queue that the message came from. Note
1809 that a single channel can start many consumers on different queues.
1810
1811 Net::AMQP::Protocol::Stream::ContentHeader
1812 This class implements the class Stream method ContentHeader, which is
1813 an asynchronous method.
1814
1815 Each of the following represents a field in the specification. These
1816 are the optional arguments to new() and are also read/write accessors:
1817
1818 content_type (type: shortstr)
1819 content_encoding (type: shortstr)
1820 headers (type: table)
1821 priority (type: octet)
1822 timestamp (type: timestamp)
1823
1824 Net::AMQP::Protocol::Tx::Select
1825 This class implements the class Tx method Select, which is a
1826 synchronous method.
1827
1828 This method sets the channel to use standard transactions. The client
1829 must use this method at least once on a channel before using the Commit
1830 or Rollback methods.
1831
1832 This class has no fields nor accessors.
1833
1834 Net::AMQP::Protocol::Tx::SelectOk
1835 This class implements the class Tx method SelectOk, which is a
1836 synchronous method.
1837
1838 This method confirms to the client that the channel was successfully
1839 set to use standard transactions.
1840
1841 This class has no fields nor accessors.
1842
1843 Net::AMQP::Protocol::Tx::Commit
1844 This class implements the class Tx method Commit, which is a
1845 synchronous method.
1846
1847 This method commits all messages published and acknowledged in the
1848 current transaction. A new transaction starts immediately after a
1849 commit.
1850
1851 This class has no fields nor accessors.
1852
1853 Net::AMQP::Protocol::Tx::CommitOk
1854 This class implements the class Tx method CommitOk, which is a
1855 synchronous method.
1856
1857 This method confirms to the client that the commit succeeded. Note that
1858 if a commit fails, the server raises a channel exception.
1859
1860 This class has no fields nor accessors.
1861
1862 Net::AMQP::Protocol::Tx::Rollback
1863 This class implements the class Tx method Rollback, which is a
1864 synchronous method.
1865
1866 This method abandons all messages published and acknowledged in the
1867 current transaction. A new transaction starts immediately after a
1868 rollback.
1869
1870 This class has no fields nor accessors.
1871
1872 Net::AMQP::Protocol::Tx::RollbackOk
1873 This class implements the class Tx method RollbackOk, which is a
1874 synchronous method.
1875
1876 This method confirms to the client that the rollback succeeded. Note
1877 that if an rollback fails, the server raises a channel exception.
1878
1879 This class has no fields nor accessors.
1880
1881 Net::AMQP::Protocol::Dtx::Select
1882 This class implements the class Dtx method Select, which is a
1883 synchronous method.
1884
1885 This method sets the channel to use distributed transactions. The
1886 client must use this method at least once on a channel before using the
1887 Start method.
1888
1889 This class has no fields nor accessors.
1890
1891 Net::AMQP::Protocol::Dtx::SelectOk
1892 This class implements the class Dtx method SelectOk, which is a
1893 synchronous method.
1894
1895 This method confirms to the client that the channel was successfully
1896 set to use distributed transactions.
1897
1898 This class has no fields nor accessors.
1899
1900 Net::AMQP::Protocol::Dtx::Start
1901 This class implements the class Dtx method Start, which is a
1902 synchronous method.
1903
1904 This method starts a new distributed transaction. This must be the
1905 first method on a new channel that uses the distributed transaction
1906 mode, before any methods that publish or consume messages.
1907
1908 Each of the following represents a field in the specification. These
1909 are the optional arguments to new() and are also read/write accessors:
1910
1911 dtx_identifier (type: shortstr)
1912 Transaction identifier
1913
1914 The distributed transaction key. This identifies the transaction so
1915 that the AMQP server can coordinate with the distributed
1916 transaction coordinator.
1917
1918 Net::AMQP::Protocol::Dtx::StartOk
1919 This class implements the class Dtx method StartOk, which is a
1920 synchronous method.
1921
1922 This method confirms to the client that the transaction started. Note
1923 that if a start fails, the server raises a channel exception.
1924
1925 This class has no fields nor accessors.
1926
1927 Net::AMQP::Protocol::Tunnel::Request
1928 This class implements the class Tunnel method Request, which is an
1929 asynchronous method.
1930
1931 This method tunnels a block of binary data, which can be an encoded
1932 AMQP method or other data. The binary data is sent as the content for
1933 the Tunnel.Request method.
1934
1935 Each of the following represents a field in the specification. These
1936 are the optional arguments to new() and are also read/write accessors:
1937
1938 meta_data (type: table)
1939 Meta data for the tunnelled block
1940
1941 This field table holds arbitrary meta-data that the sender needs to
1942 pass to the recipient.
1943
1944 Net::AMQP::Protocol::Tunnel::ContentHeader
1945 This class implements the class Tunnel method ContentHeader, which is
1946 an asynchronous method.
1947
1948 Each of the following represents a field in the specification. These
1949 are the optional arguments to new() and are also read/write accessors:
1950
1951 headers (type: table)
1952 proxy_name (type: shortstr)
1953 data_name (type: shortstr)
1954 durable (type: octet)
1955 broadcast (type: octet)
1956
1957 Net::AMQP::Protocol::Test::Integer
1958 This class implements the class Test method Integer, which is a
1959 synchronous method.
1960
1961 This method tests the peer's capability to correctly marshal integer
1962 data.
1963
1964 Each of the following represents a field in the specification. These
1965 are the optional arguments to new() and are also read/write accessors:
1966
1967 integer_1 (type: octet)
1968 Octet test value
1969
1970 An octet integer test value.
1971
1972 integer_2 (type: short)
1973 Short test value
1974
1975 A short integer test value.
1976
1977 integer_3 (type: long)
1978 Long test value
1979
1980 A long integer test value.
1981
1982 integer_4 (type: longlong)
1983 Long-long test value
1984
1985 A long long integer test value.
1986
1987 operation (type: octet)
1988 Operation to test
1989
1990 The client must execute this operation on the provided integer test
1991 fields and return the result.
1992
1993 Net::AMQP::Protocol::Test::IntegerOk
1994 This class implements the class Test method IntegerOk, which is a
1995 synchronous method.
1996
1997 This method reports the result of an Integer method.
1998
1999 Each of the following represents a field in the specification. These
2000 are the optional arguments to new() and are also read/write accessors:
2001
2002 result (type: longlong)
2003 Result value
2004
2005 The result of the tested operation.
2006
2007 Net::AMQP::Protocol::Test::String
2008 This class implements the class Test method String, which is a
2009 synchronous method.
2010
2011 This method tests the peer's capability to correctly marshal string
2012 data.
2013
2014 Each of the following represents a field in the specification. These
2015 are the optional arguments to new() and are also read/write accessors:
2016
2017 string_1 (type: shortstr)
2018 Short string test value
2019
2020 An short string test value.
2021
2022 string_2 (type: longstr)
2023 Long string test value
2024
2025 A long string test value.
2026
2027 operation (type: octet)
2028 Operation to test
2029
2030 The client must execute this operation on the provided string test
2031 fields and return the result.
2032
2033 Net::AMQP::Protocol::Test::StringOk
2034 This class implements the class Test method StringOk, which is a
2035 synchronous method.
2036
2037 This method reports the result of a String method.
2038
2039 Each of the following represents a field in the specification. These
2040 are the optional arguments to new() and are also read/write accessors:
2041
2042 result (type: longstr)
2043 Result value
2044
2045 The result of the tested operation.
2046
2047 Net::AMQP::Protocol::Test::Table
2048 This class implements the class Test method Table, which is a
2049 synchronous method.
2050
2051 This method tests the peer's capability to correctly marshal field
2052 table data.
2053
2054 Each of the following represents a field in the specification. These
2055 are the optional arguments to new() and are also read/write accessors:
2056
2057 table (type: table)
2058 Field table of test values
2059
2060 A field table of test values.
2061
2062 integer_op (type: octet)
2063 Operation to test on integers
2064
2065 The client must execute this operation on the provided field table
2066 integer values and return the result.
2067
2068 string_op (type: octet)
2069 Operation to test on strings
2070
2071 The client must execute this operation on the provided field table
2072 string values and return the result.
2073
2074 Net::AMQP::Protocol::Test::TableOk
2075 This class implements the class Test method TableOk, which is a
2076 synchronous method.
2077
2078 This method reports the result of a Table method.
2079
2080 Each of the following represents a field in the specification. These
2081 are the optional arguments to new() and are also read/write accessors:
2082
2083 integer_result (type: longlong)
2084 Integer result value
2085
2086 The result of the tested integer operation.
2087
2088 string_result (type: longstr)
2089 String result value
2090
2091 The result of the tested string operation.
2092
2093 Net::AMQP::Protocol::Test::Content
2094 This class implements the class Test method Content, which is a
2095 synchronous method.
2096
2097 This method tests the peer's capability to correctly marshal content.
2098
2099 This class has no fields nor accessors.
2100
2101 Net::AMQP::Protocol::Test::ContentOk
2102 This class implements the class Test method ContentOk, which is a
2103 synchronous method.
2104
2105 This method reports the result of a Content method. It contains the
2106 content checksum and echoes the original content as provided.
2107
2108 Each of the following represents a field in the specification. These
2109 are the optional arguments to new() and are also read/write accessors:
2110
2111 content_checksum (type: long)
2112 Content hash
2113
2114 The 32-bit checksum of the content, calculated by adding the
2115 content into a 32-bit accumulator.
2116
2117
2118
2119perl v5.36.0 2023-01-20 Net::AMQP::Protocol::v0_8(3)