rubywmq 0.3.0-i386-mswin32-mq6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/LICENSE +13 -0
- data/README +73 -0
- data/doc/classes/WMQ.html +6300 -0
- data/doc/classes/WMQ/Message.html +376 -0
- data/doc/classes/WMQ/Message.src/M000001.html +77 -0
- data/doc/classes/WMQ/Message.src/M000002.html +27 -0
- data/doc/classes/WMQ/Queue.html +1459 -0
- data/doc/classes/WMQ/Queue.src/M000003.html +205 -0
- data/doc/classes/WMQ/Queue.src/M000004.html +107 -0
- data/doc/classes/WMQ/Queue.src/M000005.html +198 -0
- data/doc/classes/WMQ/Queue.src/M000006.html +66 -0
- data/doc/classes/WMQ/Queue.src/M000007.html +203 -0
- data/doc/classes/WMQ/Queue.src/M000008.html +265 -0
- data/doc/classes/WMQ/Queue.src/M000009.html +120 -0
- data/doc/classes/WMQ/Queue.src/M000010.html +28 -0
- data/doc/classes/WMQ/Queue.src/M000011.html +30 -0
- data/doc/classes/WMQ/Queue.src/M000012.html +31 -0
- data/doc/classes/WMQ/Queue.src/M000013.html +31 -0
- data/doc/classes/WMQ/Queue.src/M000014.html +31 -0
- data/doc/classes/WMQ/QueueManager.html +1529 -0
- data/doc/classes/WMQ/QueueManager.src/M000015.html +182 -0
- data/doc/classes/WMQ/QueueManager.src/M000016.html +194 -0
- data/doc/classes/WMQ/QueueManager.src/M000017.html +92 -0
- data/doc/classes/WMQ/QueueManager.src/M000018.html +70 -0
- data/doc/classes/WMQ/QueueManager.src/M000019.html +49 -0
- data/doc/classes/WMQ/QueueManager.src/M000020.html +49 -0
- data/doc/classes/WMQ/QueueManager.src/M000021.html +63 -0
- data/doc/classes/WMQ/QueueManager.src/M000022.html +61 -0
- data/doc/classes/WMQ/QueueManager.src/M000023.html +65 -0
- data/doc/classes/WMQ/QueueManager.src/M000024.html +232 -0
- data/doc/classes/WMQ/QueueManager.src/M000025.html +30 -0
- data/doc/classes/WMQ/QueueManager.src/M000026.html +31 -0
- data/doc/classes/WMQ/QueueManager.src/M000027.html +31 -0
- data/doc/classes/WMQ/QueueManager.src/M000028.html +38 -0
- data/doc/classes/WMQ/QueueManager.src/M000029.html +33 -0
- data/doc/classes/WMQ/QueueManager.src/M000030.html +21 -0
- data/doc/classes/WMQ/QueueManager.src/M000031.html +284 -0
- data/doc/classes/WMQ/QueueManager.src/M000032.html +24 -0
- data/doc/classes/WMQ/QueueManager.src/M000033.html +18 -0
- data/doc/classes/WMQ/QueueManager.src/M000034.html +46 -0
- data/doc/classes/WMQ/QueueManager.src/M000035.html +27 -0
- data/doc/classes/WMQ/WMQException.html +111 -0
- data/doc/created.rid +1 -0
- data/doc/files/ext/lib/wmq_const_admin_rb.html +128 -0
- data/doc/files/ext/lib/wmq_const_rb.html +128 -0
- data/doc/files/ext/lib/wmq_temp_rb.html +122 -0
- data/doc/files/ext/wmq_c.html +101 -0
- data/doc/files/ext/wmq_message_c.html +101 -0
- data/doc/files/ext/wmq_queue_c.html +101 -0
- data/doc/files/ext/wmq_queue_manager_c.html +101 -0
- data/doc/fr_class_index.html +31 -0
- data/doc/fr_file_index.html +33 -0
- data/doc/fr_method_index.html +61 -0
- data/doc/index.html +24 -0
- data/doc/rdoc-style.css +208 -0
- data/examples/each_a.rb +31 -0
- data/examples/each_b.rb +40 -0
- data/examples/each_header.rb +37 -0
- data/examples/files_to_q.cfg +24 -0
- data/examples/files_to_q.rb +46 -0
- data/examples/get_a.rb +34 -0
- data/examples/get_client.rb +50 -0
- data/examples/put1_a.rb +24 -0
- data/examples/put1_b.rb +32 -0
- data/examples/put1_c.rb +31 -0
- data/examples/put_a.rb +34 -0
- data/examples/put_b.rb +42 -0
- data/examples/put_dlh.rb +40 -0
- data/examples/put_dynamic_q.rb +37 -0
- data/examples/put_rfh.rb +66 -0
- data/examples/put_rfh2_a.rb +42 -0
- data/examples/put_rfh2_b.rb +42 -0
- data/examples/put_xmit_q.rb +32 -0
- data/examples/q_to_files.cfg +17 -0
- data/examples/q_to_files.rb +47 -0
- data/examples/request.rb +59 -0
- data/examples/server.rb +96 -0
- data/lib/wmq.rb +25 -0
- data/lib/wmq/wmq.so +0 -0
- data/lib/wmq/wmq_const.rb +745 -0
- data/lib/wmq/wmq_const_admin.rb +555 -0
- data/lib/wmq/wmq_temp.rb +197 -0
- data/tests/test.rb +299 -0
- metadata +131 -0
@@ -0,0 +1,120 @@
|
|
1
|
+
<?xml version="1.0" encoding="iso-8859-1"?>
|
2
|
+
<!DOCTYPE html
|
3
|
+
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
4
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
5
|
+
|
6
|
+
<html>
|
7
|
+
<head>
|
8
|
+
<title>each (WMQ::Queue)</title>
|
9
|
+
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
10
|
+
<link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
|
11
|
+
</head>
|
12
|
+
<body class="standalone-code">
|
13
|
+
<pre>/*
|
14
|
+
* For each message found on the queue, the supplied block is executed
|
15
|
+
*
|
16
|
+
* Note:
|
17
|
+
* * If no messages are found on the queue during the supplied wait interval,
|
18
|
+
* then the supplied block will not be called at all
|
19
|
+
* * If :mode=>:browse is supplied when opening the queue then Queue#each will automatically
|
20
|
+
* set MQGMO_BROWSE_FIRST and MQGMO_BROWSE_NEXT as required
|
21
|
+
*
|
22
|
+
* Returns:
|
23
|
+
* * true: If at least one message was succesfully processed
|
24
|
+
* * false: If no messages were retrieved from the queue
|
25
|
+
*
|
26
|
+
* Example:
|
27
|
+
* require 'wmq/wmq'
|
28
|
+
*
|
29
|
+
* WMQ::QueueManager.connect(:q_mgr_name=>'REID') do |qmgr|
|
30
|
+
* qmgr.open_queue(:q_name=>'TEST.QUEUE', :mode=>:input) do |queue|
|
31
|
+
* queue.each do |message|
|
32
|
+
* puts "Data Received: #{message.data}"
|
33
|
+
* end
|
34
|
+
* end
|
35
|
+
* puts 'Completed.'
|
36
|
+
* end
|
37
|
+
*/
|
38
|
+
VALUE Queue_each(int argc, VALUE *argv, VALUE self)
|
39
|
+
{
|
40
|
+
VALUE message = Qnil;
|
41
|
+
VALUE match = Qnil;
|
42
|
+
VALUE options = Qnil;
|
43
|
+
VALUE result = Qfalse;
|
44
|
+
VALUE proc, hash;
|
45
|
+
MQLONG browse = 0;
|
46
|
+
|
47
|
+
PQUEUE pq;
|
48
|
+
Data_Get_Struct(self, QUEUE, pq);
|
49
|
+
|
50
|
+
/* Extract parameters and code block (Proc) */
|
51
|
+
rb_scan_args(argc, argv, "01&", &hash, &proc);
|
52
|
+
|
53
|
+
if(NIL_P(hash))
|
54
|
+
{
|
55
|
+
hash = rb_hash_new();
|
56
|
+
}
|
57
|
+
else
|
58
|
+
{
|
59
|
+
message = rb_hash_aref(hash, ID2SYM(ID_message));
|
60
|
+
match = rb_hash_aref(hash, ID2SYM(ID_match));
|
61
|
+
options = rb_hash_aref(hash, ID2SYM(ID_options));
|
62
|
+
}
|
63
|
+
|
64
|
+
if (NIL_P(message))
|
65
|
+
{
|
66
|
+
message = rb_funcall(wmq_message, ID_new, 0);
|
67
|
+
rb_hash_aset(hash, ID2SYM(ID_message), message);
|
68
|
+
}
|
69
|
+
|
70
|
+
if (NIL_P(match))
|
71
|
+
{
|
72
|
+
rb_hash_aset(hash, ID2SYM(ID_match), LONG2NUM(MQMO_NONE));
|
73
|
+
}
|
74
|
+
|
75
|
+
/* If queue is open for browse, set Borwse first indicator */
|
76
|
+
if(pq->open_options & MQOO_BROWSE)
|
77
|
+
{
|
78
|
+
MQLONG get_options;
|
79
|
+
if(NIL_P(options))
|
80
|
+
{
|
81
|
+
get_options = MQGMO_BROWSE_FIRST;
|
82
|
+
}
|
83
|
+
else
|
84
|
+
{
|
85
|
+
get_options = NUM2LONG(options) | MQGMO_BROWSE_FIRST;
|
86
|
+
}
|
87
|
+
rb_hash_aset(hash, ID2SYM(ID_options), LONG2NUM(get_options));
|
88
|
+
|
89
|
+
if(pq->trace_level>1) printf("WMQ::Queue#each MQGMO_BROWSE_FIRST set, get options:%ld\n", get_options);
|
90
|
+
browse = 1;
|
91
|
+
}
|
92
|
+
|
93
|
+
while(Queue_get(self, hash))
|
94
|
+
{
|
95
|
+
result = Qtrue;
|
96
|
+
|
97
|
+
/* Call code block passing in message */
|
98
|
+
rb_funcall( proc, ID_call, 1, message );
|
99
|
+
|
100
|
+
if(browse)
|
101
|
+
{
|
102
|
+
MQLONG get_options;
|
103
|
+
if(NIL_P(options))
|
104
|
+
{
|
105
|
+
get_options = MQGMO_BROWSE_NEXT;
|
106
|
+
}
|
107
|
+
else
|
108
|
+
{
|
109
|
+
get_options = (NUM2LONG(options) - MQGMO_BROWSE_FIRST) | MQGMO_BROWSE_NEXT;
|
110
|
+
}
|
111
|
+
rb_hash_aset(hash, ID2SYM(ID_options), LONG2NUM(get_options));
|
112
|
+
|
113
|
+
if(pq->trace_level>1) printf("WMQ::Queue#each MQGMO_BROWSE_NEXT set, get options:%ld\n", get_options);
|
114
|
+
}
|
115
|
+
}
|
116
|
+
|
117
|
+
return result;
|
118
|
+
}</pre>
|
119
|
+
</body>
|
120
|
+
</html>
|
@@ -0,0 +1,28 @@
|
|
1
|
+
<?xml version="1.0" encoding="iso-8859-1"?>
|
2
|
+
<!DOCTYPE html
|
3
|
+
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
4
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
5
|
+
|
6
|
+
<html>
|
7
|
+
<head>
|
8
|
+
<title>name (WMQ::Queue)</title>
|
9
|
+
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
10
|
+
<link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
|
11
|
+
</head>
|
12
|
+
<body class="standalone-code">
|
13
|
+
<pre>/*
|
14
|
+
* Returns the queue name => String
|
15
|
+
*/
|
16
|
+
VALUE Queue_name(VALUE self)
|
17
|
+
{
|
18
|
+
/* If Queue is open, return opened name, otherwise return original name */
|
19
|
+
PQUEUE pq;
|
20
|
+
Data_Get_Struct(self, QUEUE, pq);
|
21
|
+
if (pq->hobj)
|
22
|
+
{
|
23
|
+
return rb_iv_get(self,"@name");
|
24
|
+
}
|
25
|
+
return rb_iv_get(self,"@original_name");
|
26
|
+
}</pre>
|
27
|
+
</body>
|
28
|
+
</html>
|
@@ -0,0 +1,30 @@
|
|
1
|
+
<?xml version="1.0" encoding="iso-8859-1"?>
|
2
|
+
<!DOCTYPE html
|
3
|
+
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
4
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
5
|
+
|
6
|
+
<html>
|
7
|
+
<head>
|
8
|
+
<title>comp_code (WMQ::Queue)</title>
|
9
|
+
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
10
|
+
<link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
|
11
|
+
</head>
|
12
|
+
<body class="standalone-code">
|
13
|
+
<pre>/*
|
14
|
+
* Return the completion code for the last MQ operation on this queue instance
|
15
|
+
*
|
16
|
+
* Returns => FixNum
|
17
|
+
* * WMQ::MQCC_OK 0
|
18
|
+
* * WMQ::MQCC_WARNING 1
|
19
|
+
* * WMQ::MQCC_FAILED 2
|
20
|
+
* * WMQ::MQCC_UNKNOWN -1
|
21
|
+
*
|
22
|
+
*/
|
23
|
+
VALUE Queue_comp_code(VALUE self)
|
24
|
+
{
|
25
|
+
PQUEUE pq;
|
26
|
+
Data_Get_Struct(self, QUEUE, pq);
|
27
|
+
return LONG2NUM(pq->comp_code);
|
28
|
+
}</pre>
|
29
|
+
</body>
|
30
|
+
</html>
|
@@ -0,0 +1,31 @@
|
|
1
|
+
<?xml version="1.0" encoding="iso-8859-1"?>
|
2
|
+
<!DOCTYPE html
|
3
|
+
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
4
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
5
|
+
|
6
|
+
<html>
|
7
|
+
<head>
|
8
|
+
<title>reason_code (WMQ::Queue)</title>
|
9
|
+
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
10
|
+
<link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
|
11
|
+
</head>
|
12
|
+
<body class="standalone-code">
|
13
|
+
<pre>/*
|
14
|
+
* Return the reason code for the last MQ operation on this queue instance
|
15
|
+
*
|
16
|
+
* Returns => FixNum
|
17
|
+
* * For a complete list of reason codes, please see WMQ Constants or
|
18
|
+
* the WebSphere MQ documentation for Reason Codes
|
19
|
+
*
|
20
|
+
* Note
|
21
|
+
* * The list of Reason Codes varies depending on the version of WebSphere MQ
|
22
|
+
* and the operating system on which Ruby WMQ was compiled
|
23
|
+
*/
|
24
|
+
VALUE Queue_reason_code(VALUE self)
|
25
|
+
{
|
26
|
+
PQUEUE pq;
|
27
|
+
Data_Get_Struct(self, QUEUE, pq);
|
28
|
+
return LONG2NUM(pq->reason_code);
|
29
|
+
}</pre>
|
30
|
+
</body>
|
31
|
+
</html>
|
@@ -0,0 +1,31 @@
|
|
1
|
+
<?xml version="1.0" encoding="iso-8859-1"?>
|
2
|
+
<!DOCTYPE html
|
3
|
+
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
4
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
5
|
+
|
6
|
+
<html>
|
7
|
+
<head>
|
8
|
+
<title>reason (WMQ::Queue)</title>
|
9
|
+
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
10
|
+
<link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
|
11
|
+
</head>
|
12
|
+
<body class="standalone-code">
|
13
|
+
<pre>/*
|
14
|
+
* Returns a textual representation of the reason_code for the last MQ operation on this queue instance
|
15
|
+
*
|
16
|
+
* Returns => String
|
17
|
+
* * For a complete list of reasons, please see WMQ Constants or
|
18
|
+
* the WebSphere MQ documentation for Reason Codes
|
19
|
+
*
|
20
|
+
* Note
|
21
|
+
* * The list of Reason Codes varies depending on the version of WebSphere MQ
|
22
|
+
* and the operating system on which Ruby WMQ was compiled
|
23
|
+
*/
|
24
|
+
VALUE Queue_reason(VALUE self)
|
25
|
+
{
|
26
|
+
PQUEUE pq;
|
27
|
+
Data_Get_Struct(self, QUEUE, pq);
|
28
|
+
return rb_str_new2(wmq_reason(pq->reason_code));
|
29
|
+
}</pre>
|
30
|
+
</body>
|
31
|
+
</html>
|
@@ -0,0 +1,31 @@
|
|
1
|
+
<?xml version="1.0" encoding="iso-8859-1"?>
|
2
|
+
<!DOCTYPE html
|
3
|
+
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
4
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
5
|
+
|
6
|
+
<html>
|
7
|
+
<head>
|
8
|
+
<title>open? (WMQ::Queue)</title>
|
9
|
+
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
10
|
+
<link rel="stylesheet" href="../../.././rdoc-style.css" type="text/css" media="screen" />
|
11
|
+
</head>
|
12
|
+
<body class="standalone-code">
|
13
|
+
<pre>/*
|
14
|
+
* Returns whether this queue is currently open
|
15
|
+
*
|
16
|
+
* Returns:
|
17
|
+
* * true : The queue is open
|
18
|
+
* * false: The queue is _not_ open
|
19
|
+
*/
|
20
|
+
VALUE Queue_open_q(VALUE self)
|
21
|
+
{
|
22
|
+
PQUEUE pq;
|
23
|
+
Data_Get_Struct(self, QUEUE, pq);
|
24
|
+
if (pq->hobj)
|
25
|
+
{
|
26
|
+
return Qtrue;
|
27
|
+
}
|
28
|
+
return Qfalse;
|
29
|
+
}</pre>
|
30
|
+
</body>
|
31
|
+
</html>
|
@@ -0,0 +1,1529 @@
|
|
1
|
+
<?xml version="1.0" encoding="iso-8859-1"?>
|
2
|
+
<!DOCTYPE html
|
3
|
+
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
4
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
5
|
+
|
6
|
+
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
7
|
+
<head>
|
8
|
+
<title>Class: WMQ::QueueManager</title>
|
9
|
+
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
10
|
+
<meta http-equiv="Content-Script-Type" content="text/javascript" />
|
11
|
+
<link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
|
12
|
+
<script type="text/javascript">
|
13
|
+
// <![CDATA[
|
14
|
+
|
15
|
+
function popupCode( url ) {
|
16
|
+
window.open(url, "Code", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=150,width=400")
|
17
|
+
}
|
18
|
+
|
19
|
+
function toggleCode( id ) {
|
20
|
+
if ( document.getElementById )
|
21
|
+
elem = document.getElementById( id );
|
22
|
+
else if ( document.all )
|
23
|
+
elem = eval( "document.all." + id );
|
24
|
+
else
|
25
|
+
return false;
|
26
|
+
|
27
|
+
elemStyle = elem.style;
|
28
|
+
|
29
|
+
if ( elemStyle.display != "block" ) {
|
30
|
+
elemStyle.display = "block"
|
31
|
+
} else {
|
32
|
+
elemStyle.display = "none"
|
33
|
+
}
|
34
|
+
|
35
|
+
return true;
|
36
|
+
}
|
37
|
+
|
38
|
+
// Make codeblocks hidden by default
|
39
|
+
document.writeln( "<style type=\"text/css\">div.method-source-code { display: none }</style>" )
|
40
|
+
|
41
|
+
// ]]>
|
42
|
+
</script>
|
43
|
+
|
44
|
+
</head>
|
45
|
+
<body>
|
46
|
+
|
47
|
+
|
48
|
+
|
49
|
+
<div id="classHeader">
|
50
|
+
<table class="header-table">
|
51
|
+
<tr class="top-aligned-row">
|
52
|
+
<td><strong>Class</strong></td>
|
53
|
+
<td class="class-name-in-header">WMQ::QueueManager</td>
|
54
|
+
</tr>
|
55
|
+
<tr class="top-aligned-row">
|
56
|
+
<td><strong>In:</strong></td>
|
57
|
+
<td>
|
58
|
+
<a href="../../files/ext/wmq_c.html">
|
59
|
+
ext/wmq.c
|
60
|
+
</a>
|
61
|
+
<br />
|
62
|
+
<a href="../../files/ext/lib/wmq_temp_rb.html">
|
63
|
+
ext/lib/wmq_temp.rb
|
64
|
+
</a>
|
65
|
+
<br />
|
66
|
+
</td>
|
67
|
+
</tr>
|
68
|
+
|
69
|
+
<tr class="top-aligned-row">
|
70
|
+
<td><strong>Parent:</strong></td>
|
71
|
+
<td>
|
72
|
+
Object
|
73
|
+
</td>
|
74
|
+
</tr>
|
75
|
+
</table>
|
76
|
+
</div>
|
77
|
+
<!-- banner header -->
|
78
|
+
|
79
|
+
<div id="bodyContent">
|
80
|
+
|
81
|
+
|
82
|
+
|
83
|
+
<div id="contextContent">
|
84
|
+
|
85
|
+
|
86
|
+
|
87
|
+
</div>
|
88
|
+
|
89
|
+
<div id="method-list">
|
90
|
+
<h3 class="section-bar">Methods</h3>
|
91
|
+
|
92
|
+
<div class="name-list">
|
93
|
+
<a href="#M000020">access_queue</a>
|
94
|
+
<a href="#M000023">backout</a>
|
95
|
+
<a href="#M000021">begin</a>
|
96
|
+
<a href="#M000022">commit</a>
|
97
|
+
<a href="#M000025">comp_code</a>
|
98
|
+
<a href="#M000015">connect</a>
|
99
|
+
<a href="#M000017">connect</a>
|
100
|
+
<a href="#M000029">connected?</a>
|
101
|
+
<a href="#M000018">disconnect</a>
|
102
|
+
<a href="#M000028">exception_on_error</a>
|
103
|
+
<a href="#M000031">execute</a>
|
104
|
+
<a href="#M000032">method_missing</a>
|
105
|
+
<a href="#M000033">mqsc</a>
|
106
|
+
<a href="#M000030">name</a>
|
107
|
+
<a href="#M000016">new</a>
|
108
|
+
<a href="#M000019">open_queue</a>
|
109
|
+
<a href="#M000024">put</a>
|
110
|
+
<a href="#M000035">put_to_dead_letter_q</a>
|
111
|
+
<a href="#M000034">put_to_reply_q</a>
|
112
|
+
<a href="#M000027">reason</a>
|
113
|
+
<a href="#M000026">reason_code</a>
|
114
|
+
</div>
|
115
|
+
</div>
|
116
|
+
|
117
|
+
</div>
|
118
|
+
|
119
|
+
|
120
|
+
<!-- if includes -->
|
121
|
+
|
122
|
+
<div id="section">
|
123
|
+
|
124
|
+
|
125
|
+
|
126
|
+
|
127
|
+
|
128
|
+
|
129
|
+
|
130
|
+
|
131
|
+
<!-- if method_list -->
|
132
|
+
<div id="methods">
|
133
|
+
<h3 class="section-bar">Public Class methods</h3>
|
134
|
+
|
135
|
+
<div id="method-M000015" class="method-detail">
|
136
|
+
<a name="M000015"></a>
|
137
|
+
|
138
|
+
<div class="method-heading">
|
139
|
+
<a href="QueueManager.src/M000015.html" target="Code" class="method-signature"
|
140
|
+
onclick="popupCode('QueueManager.src/M000015.html');return false;">
|
141
|
+
<span class="method-name">connect(...)<br />
|
142
|
+
</span>
|
143
|
+
</a>
|
144
|
+
</div>
|
145
|
+
|
146
|
+
<div class="method-description">
|
147
|
+
<p>
|
148
|
+
Connect to the queue manager, then disconnect once the supplied code block
|
149
|
+
completes
|
150
|
+
</p>
|
151
|
+
<p>
|
152
|
+
Parameters:
|
153
|
+
</p>
|
154
|
+
<ul>
|
155
|
+
<li>Since the number of parameters can vary dramatically, all parameters are
|
156
|
+
passed by name in a hash
|
157
|
+
|
158
|
+
</li>
|
159
|
+
<li>Summary of parameters and their WebSphere MQ equivalents:
|
160
|
+
|
161
|
+
</li>
|
162
|
+
</ul>
|
163
|
+
<pre>
|
164
|
+
WMQ::QueueManager.connect( # WebSphere MQ Equivalents:
|
165
|
+
:q_mgr_name => 'queue_manager name',
|
166
|
+
:exception_on_error => true, # n/a
|
167
|
+
:connect_options => WMQ::MQCNO_FASTBATH_BINDING # MQCNO.Options
|
168
|
+
|
169
|
+
:trace_level => 0, # n/a
|
170
|
+
|
171
|
+
# Common client connection parameters
|
172
|
+
:channel_name => 'svrconn channel name', # MQCD.ChannelName
|
173
|
+
:connection_name => 'localhost(1414)', # MQCD.ConnectionName
|
174
|
+
:transport_type => WMQ::MQXPT_TCP, # MQCD.TransportType
|
175
|
+
|
176
|
+
# Advanced client connections parameters
|
177
|
+
:max_msg_length => 65535, # MQCD.MaxMsgLength
|
178
|
+
:security_exit => 'Name of security exit', # MQCD.SecurityExit
|
179
|
+
:send_exit => 'Name of send exit', # MQCD.SendExit
|
180
|
+
:receive_exit => 'Name of receive exit', # MQCD.ReceiveExit
|
181
|
+
:security_user_data => 'Security exit User data', # MQCD.SecurityUserData
|
182
|
+
:send_user_data => 'Send exit user data', # MQCD.SendUserData
|
183
|
+
:receive_user_data => 'Receive exit user data', # MQCD.ReceiveUserData
|
184
|
+
:heartbeat_interval => 1, # MQCD.HeartbeatInterval
|
185
|
+
:remote_security_id => 'Remote Security id', # MQCD.RemoteSecurityId
|
186
|
+
:ssl_cipher_spec => 'SSL Cipher Spec', # MQCD.SSLCipherSpec
|
187
|
+
:keep_alive_interval=> -1, # MQCD.KeepAliveInterval
|
188
|
+
:mode_name => 'LU6.2 Mode Name', # MQCD.ModeName
|
189
|
+
:tp_name => 'LU6.2 Transaction pgm name', # MQCD.TpName
|
190
|
+
:user_identifier => 'LU 6.2 Userid', # MQCD.UserIdentifier
|
191
|
+
:password => 'LU6.2 Password', # MQCD.Password
|
192
|
+
:long_remote_user_id=> 'Long remote user identifier', # MQCD.LongRemoteUserId (Ptr, Length)
|
193
|
+
:ssl_peer_name => 'SSL Peer name', # MQCD.SSLPeerName (Ptr, Length)
|
194
|
+
|
195
|
+
# SSL Options
|
196
|
+
:key_repository => '/var/mqm/qmgrs/.../key', # MQSCO.KeyRepository
|
197
|
+
:crypto_hardware => 'GSK_ACCELERATOR_NCIPHER_NF_ON', # MQSCO.CryptoHardware
|
198
|
+
)
|
199
|
+
</pre>
|
200
|
+
<p>
|
201
|
+
Optional Parameters
|
202
|
+
</p>
|
203
|
+
<ul>
|
204
|
+
<li>:q_mgr_name => String
|
205
|
+
|
206
|
+
<ul>
|
207
|
+
<li>Name of the existing WebSphere MQ <a href="Queue.html">Queue</a> Manager to
|
208
|
+
connect to
|
209
|
+
|
210
|
+
</li>
|
211
|
+
<li>Default:
|
212
|
+
|
213
|
+
<pre>
|
214
|
+
- Server connections will connect to the default queue manager
|
215
|
+
- Client connections will connect to whatever queue
|
216
|
+
manager is found at the host and port number as specified
|
217
|
+
by the connection_name
|
218
|
+
</pre>
|
219
|
+
</li>
|
220
|
+
</ul>
|
221
|
+
</li>
|
222
|
+
<li>:<a href="QueueManager.html#M000028">exception_on_error</a> => true or
|
223
|
+
false
|
224
|
+
|
225
|
+
<pre>
|
226
|
+
Determines whether WMQ::WMQExceptions are thrown whenever
|
227
|
+
an error occurs during a WebSphere MQ operation (connect, put, get, etc..)
|
228
|
+
|
229
|
+
Default: true
|
230
|
+
</pre>
|
231
|
+
</li>
|
232
|
+
<li>:connect_options => FixNum
|
233
|
+
|
234
|
+
<ul>
|
235
|
+
<li>One or more of the following values:
|
236
|
+
|
237
|
+
<pre>
|
238
|
+
WMQ::MQCNO_STANDARD_BINDING
|
239
|
+
WMQ::MQCNO_FASTPATH_BINDING
|
240
|
+
WMQ::MQCNO_SHARED_BINDING
|
241
|
+
WMQ::MQCNO_ISOLATED_BINDING
|
242
|
+
WMQ::MQCNO_ACCOUNTING_MQI_ENABLED
|
243
|
+
WMQ::MQCNO_ACCOUNTING_MQI_DISABLED
|
244
|
+
WMQ::MQCNO_ACCOUNTING_Q_ENABLED
|
245
|
+
WMQ::MQCNO_ACCOUNTING_Q_DISABLED
|
246
|
+
WMQ::MQCNO_NONE
|
247
|
+
</pre>
|
248
|
+
</li>
|
249
|
+
<li>Multiple values can be or’d together. E.g.
|
250
|
+
|
251
|
+
<pre>
|
252
|
+
:connect_options=>WMQ::MQCNO_FASTPATH_BINDING | WMQ::MQCNO_ACCOUNTING_MQI_ENABLED
|
253
|
+
</pre>
|
254
|
+
</li>
|
255
|
+
<li>Please see the WebSphere MQ MQCNO data type documentation for more details
|
256
|
+
|
257
|
+
<pre>
|
258
|
+
Default: WMQ::MQCNO_NONE
|
259
|
+
</pre>
|
260
|
+
</li>
|
261
|
+
</ul>
|
262
|
+
</li>
|
263
|
+
<li>:trace_level => FixNum
|
264
|
+
|
265
|
+
<ul>
|
266
|
+
<li>Turns on low-level tracing of the WebSphere MQ API calls to stdout.
|
267
|
+
|
268
|
+
<ul>
|
269
|
+
<li>0: No tracing
|
270
|
+
|
271
|
+
</li>
|
272
|
+
<li>1: MQ API tracing only (MQCONNX, MQOPEN, MQPUT, etc..)
|
273
|
+
|
274
|
+
</li>
|
275
|
+
<li>2: Include Ruby <a href="../WMQ.html">WMQ</a> tracing
|
276
|
+
|
277
|
+
</li>
|
278
|
+
<li>3: Verbose logging (Recommended for when reporting problems in Ruby <a
|
279
|
+
href="../WMQ.html">WMQ</a>)
|
280
|
+
|
281
|
+
</li>
|
282
|
+
</ul>
|
283
|
+
<pre>
|
284
|
+
Default: 0
|
285
|
+
</pre>
|
286
|
+
</li>
|
287
|
+
</ul>
|
288
|
+
</li>
|
289
|
+
</ul>
|
290
|
+
<p>
|
291
|
+
Common Client Connection Parameters (Client connections only)
|
292
|
+
</p>
|
293
|
+
<ul>
|
294
|
+
<li>:connection_name => String (Mandatory for client connections)
|
295
|
+
|
296
|
+
<ul>
|
297
|
+
<li>Connection name, made up of the host name (or ip address) and the port
|
298
|
+
number
|
299
|
+
|
300
|
+
</li>
|
301
|
+
<li>E.g.
|
302
|
+
|
303
|
+
<pre>
|
304
|
+
'mymachine.domain.com(1414)'
|
305
|
+
'192.168.0.1(1417)'
|
306
|
+
</pre>
|
307
|
+
</li>
|
308
|
+
</ul>
|
309
|
+
</li>
|
310
|
+
<li>:channel_name => String
|
311
|
+
|
312
|
+
<ul>
|
313
|
+
<li>Name of SVRCONN channel defined on the <a
|
314
|
+
href="QueueManager.html">QueueManager</a> for Client Connections
|
315
|
+
|
316
|
+
</li>
|
317
|
+
<li>Default Value:
|
318
|
+
|
319
|
+
<pre>
|
320
|
+
'SYSTEM.DEF.SVRCONN'
|
321
|
+
</pre>
|
322
|
+
</li>
|
323
|
+
</ul>
|
324
|
+
</li>
|
325
|
+
<li>:transport_type => WMQ::MQXPT_TCP, # MQCD.TransportType
|
326
|
+
|
327
|
+
<ul>
|
328
|
+
<li>Valid Values:
|
329
|
+
|
330
|
+
<pre>
|
331
|
+
WMQ::MQXPT_LOCAL
|
332
|
+
WMQ::MQXPT_LU62
|
333
|
+
WMQ::MQXPT_TCP
|
334
|
+
WMQ::MQXPT_NETBIOS
|
335
|
+
WMQ::MQXPT_SPX
|
336
|
+
WMQ::MQXPT_DECNET
|
337
|
+
WMQ::MQXPT_UDP
|
338
|
+
</pre>
|
339
|
+
</li>
|
340
|
+
<li>Default Value:
|
341
|
+
|
342
|
+
<pre>
|
343
|
+
WMQ::MQXPT_TCP
|
344
|
+
</pre>
|
345
|
+
</li>
|
346
|
+
</ul>
|
347
|
+
</li>
|
348
|
+
</ul>
|
349
|
+
<p>
|
350
|
+
For the Advanced Client Connection parameters, please see the WebSphere MQ
|
351
|
+
documentation
|
352
|
+
</p>
|
353
|
+
<p>
|
354
|
+
Note:
|
355
|
+
</p>
|
356
|
+
<ul>
|
357
|
+
<li>If an exception is not caught in the code block, the current unit of work
|
358
|
+
is automatically backed out, before disconnecting from the queue manager.
|
359
|
+
|
360
|
+
</li>
|
361
|
+
</ul>
|
362
|
+
<p>
|
363
|
+
Local Server Connection Example:
|
364
|
+
</p>
|
365
|
+
<pre>
|
366
|
+
require 'wmq/wmq'
|
367
|
+
|
368
|
+
WMQ::QueueManager.connect(:q_mgr_name=>'REID') do |qmgr|
|
369
|
+
qmgr.put(:q_name=>'TEST.QUEUE', :data => 'Hello World')
|
370
|
+
end
|
371
|
+
</pre>
|
372
|
+
<p>
|
373
|
+
Client Connection Example:
|
374
|
+
</p>
|
375
|
+
<pre>
|
376
|
+
require 'wmq/wmq_client'
|
377
|
+
|
378
|
+
WMQ::QueueManager.connect(
|
379
|
+
:channel_name => 'SYSTEM.DEF.SVRCONN',
|
380
|
+
:transport_type => WMQ::MQXPT_TCP,
|
381
|
+
:connection_name => 'localhost(1414)' ) do |qmgr|
|
382
|
+
qmgr.open_queue(:q_name=>'TEST.QUEUE', :mode=>:input) do |queue|
|
383
|
+
|
384
|
+
message = WMQ::Message.new
|
385
|
+
if queue.get(:message => message)
|
386
|
+
puts "Data Received: #{message.data}"
|
387
|
+
else
|
388
|
+
puts 'No message available'
|
389
|
+
end
|
390
|
+
end
|
391
|
+
end
|
392
|
+
</pre>
|
393
|
+
</div>
|
394
|
+
</div>
|
395
|
+
|
396
|
+
<div id="method-M000016" class="method-detail">
|
397
|
+
<a name="M000016"></a>
|
398
|
+
|
399
|
+
<div class="method-heading">
|
400
|
+
<a href="QueueManager.src/M000016.html" target="Code" class="method-signature"
|
401
|
+
onclick="popupCode('QueueManager.src/M000016.html');return false;">
|
402
|
+
<span class="method-name">new(...)<br />
|
403
|
+
</span>
|
404
|
+
</a>
|
405
|
+
</div>
|
406
|
+
|
407
|
+
<div class="method-description">
|
408
|
+
<p>
|
409
|
+
Parameters:
|
410
|
+
</p>
|
411
|
+
<ul>
|
412
|
+
<li>Since the number of parameters can vary dramatically, all parameters are
|
413
|
+
passed by name in a hash
|
414
|
+
|
415
|
+
</li>
|
416
|
+
<li>See <a href="QueueManager.html#M000016">QueueManager.new</a> for details on
|
417
|
+
all the parameters
|
418
|
+
|
419
|
+
</li>
|
420
|
+
</ul>
|
421
|
+
<p>
|
422
|
+
Note:
|
423
|
+
</p>
|
424
|
+
<ul>
|
425
|
+
<li>It is not recommended to use this method, rather use <a
|
426
|
+
href="QueueManager.html#M000015">QueueManager.connect</a>, since it will
|
427
|
+
automatically disconnect from the queue manager. It also deals with backing
|
428
|
+
out the current unit of work in the event of an unhandled exception. E.g.
|
429
|
+
Syntax Error
|
430
|
+
|
431
|
+
</li>
|
432
|
+
<li>RuntimeError and ArgumentError exceptions are always thrown regardless of
|
433
|
+
the value of :<a href="QueueManager.html#M000028">exception_on_error</a>
|
434
|
+
|
435
|
+
</li>
|
436
|
+
</ul>
|
437
|
+
<p>
|
438
|
+
Todo:
|
439
|
+
</p>
|
440
|
+
<ul>
|
441
|
+
<li>Support multiple send and receive exits
|
442
|
+
|
443
|
+
</li>
|
444
|
+
</ul>
|
445
|
+
</div>
|
446
|
+
</div>
|
447
|
+
|
448
|
+
<h3 class="section-bar">Public Instance methods</h3>
|
449
|
+
|
450
|
+
<div id="method-M000020" class="method-detail">
|
451
|
+
<a name="M000020"></a>
|
452
|
+
|
453
|
+
<div class="method-heading">
|
454
|
+
<a href="QueueManager.src/M000020.html" target="Code" class="method-signature"
|
455
|
+
onclick="popupCode('QueueManager.src/M000020.html');return false;">
|
456
|
+
<span class="method-name">open_queue(...)<br />
|
457
|
+
access_queue(...)<br />
|
458
|
+
</span>
|
459
|
+
</a>
|
460
|
+
</div>
|
461
|
+
|
462
|
+
<div class="method-description">
|
463
|
+
<p>
|
464
|
+
Open the specified queue, then close it once the supplied code block has
|
465
|
+
completed
|
466
|
+
</p>
|
467
|
+
<p>
|
468
|
+
Parameters:
|
469
|
+
</p>
|
470
|
+
<ul>
|
471
|
+
<li>Since the number of parameters can vary dramatically, all parameters are
|
472
|
+
passed by name in a hash
|
473
|
+
|
474
|
+
</li>
|
475
|
+
<li>See <a href="Queue.html#M000003">Queue.open</a> for the complete list of
|
476
|
+
parameters, except that :queue_manager is <b>not</b> required since it is
|
477
|
+
supplied automatically by this method
|
478
|
+
|
479
|
+
</li>
|
480
|
+
</ul>
|
481
|
+
<p>
|
482
|
+
Example:
|
483
|
+
</p>
|
484
|
+
<pre>
|
485
|
+
require 'wmq/wmq_client'
|
486
|
+
|
487
|
+
WMQ::QueueManager.connect(:q_mgr_name=>'REID', :connection_name=>'localhost(1414)') do |qmgr|
|
488
|
+
qmgr.open_queue(:q_name=>'TEST.QUEUE', :mode=>:output) do |queue|
|
489
|
+
queue.put(:data => 'Hello World')
|
490
|
+
end
|
491
|
+
end
|
492
|
+
</pre>
|
493
|
+
</div>
|
494
|
+
</div>
|
495
|
+
|
496
|
+
<div id="method-M000023" class="method-detail">
|
497
|
+
<a name="M000023"></a>
|
498
|
+
|
499
|
+
<div class="method-heading">
|
500
|
+
<a href="QueueManager.src/M000023.html" target="Code" class="method-signature"
|
501
|
+
onclick="popupCode('QueueManager.src/M000023.html');return false;">
|
502
|
+
<span class="method-name">backout</span><span class="method-args">()</span>
|
503
|
+
</a>
|
504
|
+
</div>
|
505
|
+
|
506
|
+
<div class="method-description">
|
507
|
+
<p>
|
508
|
+
Backout the current unit of work for this <a
|
509
|
+
href="QueueManager.html">QueueManager</a> instance
|
510
|
+
</p>
|
511
|
+
<p>
|
512
|
+
Since the last commit or rollback any messages put to a queue under
|
513
|
+
synchpoint will be removed and any messages retrieved under synchpoint from
|
514
|
+
any queues will be returned
|
515
|
+
</p>
|
516
|
+
<p>
|
517
|
+
Note:
|
518
|
+
</p>
|
519
|
+
<ul>
|
520
|
+
<li>backout will have no effect if all put and get operations were performed
|
521
|
+
without specifying :sync => true
|
522
|
+
|
523
|
+
</li>
|
524
|
+
</ul>
|
525
|
+
<p>
|
526
|
+
Returns:
|
527
|
+
</p>
|
528
|
+
<ul>
|
529
|
+
<li>true : On Success
|
530
|
+
|
531
|
+
</li>
|
532
|
+
<li>false: On Failure
|
533
|
+
|
534
|
+
<p>
|
535
|
+
<a href="QueueManager.html#M000025">comp_code</a> and <a
|
536
|
+
href="QueueManager.html#M000026">reason_code</a> are also updated. reason
|
537
|
+
will return a text description of the <a
|
538
|
+
href="QueueManager.html#M000026">reason_code</a>
|
539
|
+
</p>
|
540
|
+
</li>
|
541
|
+
</ul>
|
542
|
+
<p>
|
543
|
+
Throws:
|
544
|
+
</p>
|
545
|
+
<ul>
|
546
|
+
<li><a href="WMQException.html">WMQ::WMQException</a> if <a
|
547
|
+
href="QueueManager.html#M000025">comp_code</a> != MQCC_OK
|
548
|
+
|
549
|
+
</li>
|
550
|
+
<li>Except if :<a href="QueueManager.html#M000028">exception_on_error</a> =>
|
551
|
+
false was supplied as a parameter to <a
|
552
|
+
href="QueueManager.html#M000016">QueueManager.new</a>
|
553
|
+
|
554
|
+
</li>
|
555
|
+
</ul>
|
556
|
+
</div>
|
557
|
+
</div>
|
558
|
+
|
559
|
+
<div id="method-M000021" class="method-detail">
|
560
|
+
<a name="M000021"></a>
|
561
|
+
|
562
|
+
<div class="method-heading">
|
563
|
+
<a href="QueueManager.src/M000021.html" target="Code" class="method-signature"
|
564
|
+
onclick="popupCode('QueueManager.src/M000021.html');return false;">
|
565
|
+
<span class="method-name">begin</span><span class="method-args">()</span>
|
566
|
+
</a>
|
567
|
+
</div>
|
568
|
+
|
569
|
+
<div class="method-description">
|
570
|
+
<p>
|
571
|
+
Advanced WebSphere MQ Use:
|
572
|
+
</p>
|
573
|
+
<p>
|
574
|
+
Begin a unit of work between this <a
|
575
|
+
href="QueueManager.html">QueueManager</a> instance and another resource
|
576
|
+
such as a Database
|
577
|
+
</p>
|
578
|
+
<p>
|
579
|
+
Starts a new unit of work under which put and get can be called with with
|
580
|
+
the parameter :sync => true
|
581
|
+
</p>
|
582
|
+
<p>
|
583
|
+
Returns:
|
584
|
+
</p>
|
585
|
+
<ul>
|
586
|
+
<li>true : On Success
|
587
|
+
|
588
|
+
</li>
|
589
|
+
<li>false: On Failure
|
590
|
+
|
591
|
+
<p>
|
592
|
+
<a href="QueueManager.html#M000025">comp_code</a> and <a
|
593
|
+
href="QueueManager.html#M000026">reason_code</a> are also updated. reason
|
594
|
+
will return a text description of the <a
|
595
|
+
href="QueueManager.html#M000026">reason_code</a>
|
596
|
+
</p>
|
597
|
+
</li>
|
598
|
+
</ul>
|
599
|
+
<p>
|
600
|
+
Throws:
|
601
|
+
</p>
|
602
|
+
<ul>
|
603
|
+
<li><a href="WMQException.html">WMQ::WMQException</a> if <a
|
604
|
+
href="QueueManager.html#M000025">comp_code</a> != MQCC_OK
|
605
|
+
|
606
|
+
</li>
|
607
|
+
<li>Except if :<a href="QueueManager.html#M000028">exception_on_error</a> =>
|
608
|
+
false was supplied as a parameter to <a
|
609
|
+
href="QueueManager.html#M000016">QueueManager.new</a>
|
610
|
+
|
611
|
+
</li>
|
612
|
+
</ul>
|
613
|
+
</div>
|
614
|
+
</div>
|
615
|
+
|
616
|
+
<div id="method-M000022" class="method-detail">
|
617
|
+
<a name="M000022"></a>
|
618
|
+
|
619
|
+
<div class="method-heading">
|
620
|
+
<a href="QueueManager.src/M000022.html" target="Code" class="method-signature"
|
621
|
+
onclick="popupCode('QueueManager.src/M000022.html');return false;">
|
622
|
+
<span class="method-name">commit</span><span class="method-args">()</span>
|
623
|
+
</a>
|
624
|
+
</div>
|
625
|
+
|
626
|
+
<div class="method-description">
|
627
|
+
<p>
|
628
|
+
Commit the current unit of work for this <a
|
629
|
+
href="QueueManager.html">QueueManager</a> instance
|
630
|
+
</p>
|
631
|
+
<p>
|
632
|
+
Note:
|
633
|
+
</p>
|
634
|
+
<ul>
|
635
|
+
<li>commit will have no effect if all put and get operations were performed
|
636
|
+
without specifying :sync => true
|
637
|
+
|
638
|
+
</li>
|
639
|
+
</ul>
|
640
|
+
<p>
|
641
|
+
Returns:
|
642
|
+
</p>
|
643
|
+
<ul>
|
644
|
+
<li>true : On Success
|
645
|
+
|
646
|
+
</li>
|
647
|
+
<li>false: On Failure
|
648
|
+
|
649
|
+
<p>
|
650
|
+
<a href="QueueManager.html#M000025">comp_code</a> and <a
|
651
|
+
href="QueueManager.html#M000026">reason_code</a> are also updated. reason
|
652
|
+
will return a text description of the <a
|
653
|
+
href="QueueManager.html#M000026">reason_code</a>
|
654
|
+
</p>
|
655
|
+
</li>
|
656
|
+
</ul>
|
657
|
+
<p>
|
658
|
+
Throws:
|
659
|
+
</p>
|
660
|
+
<ul>
|
661
|
+
<li><a href="WMQException.html">WMQ::WMQException</a> if <a
|
662
|
+
href="QueueManager.html#M000025">comp_code</a> != MQCC_OK
|
663
|
+
|
664
|
+
</li>
|
665
|
+
<li>Except if :<a href="QueueManager.html#M000028">exception_on_error</a> =>
|
666
|
+
false was supplied as a parameter to <a
|
667
|
+
href="QueueManager.html#M000016">QueueManager.new</a>
|
668
|
+
|
669
|
+
</li>
|
670
|
+
</ul>
|
671
|
+
</div>
|
672
|
+
</div>
|
673
|
+
|
674
|
+
<div id="method-M000025" class="method-detail">
|
675
|
+
<a name="M000025"></a>
|
676
|
+
|
677
|
+
<div class="method-heading">
|
678
|
+
<a href="QueueManager.src/M000025.html" target="Code" class="method-signature"
|
679
|
+
onclick="popupCode('QueueManager.src/M000025.html');return false;">
|
680
|
+
<span class="method-name">comp_code</span><span class="method-args">()</span>
|
681
|
+
</a>
|
682
|
+
</div>
|
683
|
+
|
684
|
+
<div class="method-description">
|
685
|
+
<p>
|
686
|
+
Return the completion code for the last MQ operation
|
687
|
+
</p>
|
688
|
+
<p>
|
689
|
+
Returns => FixNum
|
690
|
+
</p>
|
691
|
+
<ul>
|
692
|
+
<li>WMQ::MQCC_OK 0
|
693
|
+
|
694
|
+
</li>
|
695
|
+
<li>WMQ::MQCC_WARNING 1
|
696
|
+
|
697
|
+
</li>
|
698
|
+
<li>WMQ::MQCC_FAILED 2
|
699
|
+
|
700
|
+
</li>
|
701
|
+
<li>WMQ::MQCC_UNKNOWN -1
|
702
|
+
|
703
|
+
</li>
|
704
|
+
</ul>
|
705
|
+
</div>
|
706
|
+
</div>
|
707
|
+
|
708
|
+
<div id="method-M000017" class="method-detail">
|
709
|
+
<a name="M000017"></a>
|
710
|
+
|
711
|
+
<div class="method-heading">
|
712
|
+
<a href="QueueManager.src/M000017.html" target="Code" class="method-signature"
|
713
|
+
onclick="popupCode('QueueManager.src/M000017.html');return false;">
|
714
|
+
<span class="method-name">connect</span><span class="method-args">()</span>
|
715
|
+
</a>
|
716
|
+
</div>
|
717
|
+
|
718
|
+
<div class="method-description">
|
719
|
+
<p>
|
720
|
+
Before working with any queues, it is necessary to connect to the queue
|
721
|
+
manager.
|
722
|
+
</p>
|
723
|
+
<p>
|
724
|
+
Returns:
|
725
|
+
</p>
|
726
|
+
<ul>
|
727
|
+
<li>true : On Success
|
728
|
+
|
729
|
+
</li>
|
730
|
+
<li>false: On Failure
|
731
|
+
|
732
|
+
<p>
|
733
|
+
<a href="QueueManager.html#M000025">comp_code</a> and <a
|
734
|
+
href="QueueManager.html#M000026">reason_code</a> are also updated. reason
|
735
|
+
will return a text description of the <a
|
736
|
+
href="QueueManager.html#M000026">reason_code</a>
|
737
|
+
</p>
|
738
|
+
</li>
|
739
|
+
</ul>
|
740
|
+
<p>
|
741
|
+
Throws:
|
742
|
+
</p>
|
743
|
+
<ul>
|
744
|
+
<li><a href="WMQException.html">WMQ::WMQException</a> if <a
|
745
|
+
href="QueueManager.html#M000025">comp_code</a> != MQCC_OK
|
746
|
+
|
747
|
+
</li>
|
748
|
+
<li>Except if :<a href="QueueManager.html#M000028">exception_on_error</a> =>
|
749
|
+
false was supplied as a parameter to <a
|
750
|
+
href="QueueManager.html#M000016">QueueManager.new</a>
|
751
|
+
|
752
|
+
</li>
|
753
|
+
</ul>
|
754
|
+
</div>
|
755
|
+
</div>
|
756
|
+
|
757
|
+
<div id="method-M000029" class="method-detail">
|
758
|
+
<a name="M000029"></a>
|
759
|
+
|
760
|
+
<div class="method-heading">
|
761
|
+
<a href="QueueManager.src/M000029.html" target="Code" class="method-signature"
|
762
|
+
onclick="popupCode('QueueManager.src/M000029.html');return false;">
|
763
|
+
<span class="method-name">connected?</span><span class="method-args">()</span>
|
764
|
+
</a>
|
765
|
+
</div>
|
766
|
+
|
767
|
+
<div class="method-description">
|
768
|
+
<p>
|
769
|
+
Returns whether this <a href="QueueManager.html">QueueManager</a> instance
|
770
|
+
is currently connected to a WebSphere MQ queue manager
|
771
|
+
</p>
|
772
|
+
<p>
|
773
|
+
Returns:
|
774
|
+
</p>
|
775
|
+
<ul>
|
776
|
+
<li>true : This <a href="QueueManager.html">QueueManager</a> instance is
|
777
|
+
connected to a local or remote queue manager
|
778
|
+
|
779
|
+
</li>
|
780
|
+
<li>false: This <a href="QueueManager.html">QueueManager</a> instance is not
|
781
|
+
currently connected to a local or remote queue manager
|
782
|
+
|
783
|
+
</li>
|
784
|
+
</ul>
|
785
|
+
</div>
|
786
|
+
</div>
|
787
|
+
|
788
|
+
<div id="method-M000018" class="method-detail">
|
789
|
+
<a name="M000018"></a>
|
790
|
+
|
791
|
+
<div class="method-heading">
|
792
|
+
<a href="QueueManager.src/M000018.html" target="Code" class="method-signature"
|
793
|
+
onclick="popupCode('QueueManager.src/M000018.html');return false;">
|
794
|
+
<span class="method-name">disconnect</span><span class="method-args">()</span>
|
795
|
+
</a>
|
796
|
+
</div>
|
797
|
+
|
798
|
+
<div class="method-description">
|
799
|
+
<p>
|
800
|
+
Disconnect from this <a href="QueueManager.html">QueueManager</a> instance
|
801
|
+
</p>
|
802
|
+
<p>
|
803
|
+
Returns:
|
804
|
+
</p>
|
805
|
+
<ul>
|
806
|
+
<li>true : On Success
|
807
|
+
|
808
|
+
</li>
|
809
|
+
<li>false: On Failure
|
810
|
+
|
811
|
+
<p>
|
812
|
+
<a href="QueueManager.html#M000025">comp_code</a> and <a
|
813
|
+
href="QueueManager.html#M000026">reason_code</a> are also updated. reason
|
814
|
+
will return a text description of the <a
|
815
|
+
href="QueueManager.html#M000026">reason_code</a>
|
816
|
+
</p>
|
817
|
+
</li>
|
818
|
+
</ul>
|
819
|
+
<p>
|
820
|
+
Throws:
|
821
|
+
</p>
|
822
|
+
<ul>
|
823
|
+
<li><a href="WMQException.html">WMQ::WMQException</a> if <a
|
824
|
+
href="QueueManager.html#M000025">comp_code</a> != MQCC_OK
|
825
|
+
|
826
|
+
</li>
|
827
|
+
<li>Except if :<a href="QueueManager.html#M000028">exception_on_error</a> =>
|
828
|
+
false was supplied as a parameter to <a
|
829
|
+
href="QueueManager.html#M000016">QueueManager.new</a>
|
830
|
+
|
831
|
+
</li>
|
832
|
+
</ul>
|
833
|
+
</div>
|
834
|
+
</div>
|
835
|
+
|
836
|
+
<div id="method-M000028" class="method-detail">
|
837
|
+
<a name="M000028"></a>
|
838
|
+
|
839
|
+
<div class="method-heading">
|
840
|
+
<a href="QueueManager.src/M000028.html" target="Code" class="method-signature"
|
841
|
+
onclick="popupCode('QueueManager.src/M000028.html');return false;">
|
842
|
+
<span class="method-name">exception_on_error</span><span class="method-args">()</span>
|
843
|
+
</a>
|
844
|
+
</div>
|
845
|
+
|
846
|
+
<div class="method-description">
|
847
|
+
<p>
|
848
|
+
Returns whether this <a href="QueueManager.html">QueueManager</a> instance
|
849
|
+
is set to throw a <a href="WMQException.html">WMQ::WMQException</a>
|
850
|
+
whenever an MQ operation fails
|
851
|
+
</p>
|
852
|
+
<p>
|
853
|
+
Returns:
|
854
|
+
</p>
|
855
|
+
<ul>
|
856
|
+
<li>true : This <a href="QueueManager.html">QueueManager</a> instance will
|
857
|
+
throw a <a href="WMQException.html">WMQ::WMQException</a> whenever an MQ
|
858
|
+
operation fails. I.e. if <a href="QueueManager.html#M000025">comp_code</a>
|
859
|
+
!= WMQ::OK.
|
860
|
+
|
861
|
+
</li>
|
862
|
+
<li>false: <a href="WMQException.html">WMQ::WMQException</a> will not be thrown
|
863
|
+
|
864
|
+
</li>
|
865
|
+
</ul>
|
866
|
+
<p>
|
867
|
+
Note:
|
868
|
+
</p>
|
869
|
+
<ul>
|
870
|
+
<li>RuntimeError and ArgumentError exceptions are always thrown regardless of
|
871
|
+
the value of <a href="QueueManager.html#M000028">exception_on_error</a>
|
872
|
+
|
873
|
+
</li>
|
874
|
+
</ul>
|
875
|
+
</div>
|
876
|
+
</div>
|
877
|
+
|
878
|
+
<div id="method-M000031" class="method-detail">
|
879
|
+
<a name="M000031"></a>
|
880
|
+
|
881
|
+
<div class="method-heading">
|
882
|
+
<a href="QueueManager.src/M000031.html" target="Code" class="method-signature"
|
883
|
+
onclick="popupCode('QueueManager.src/M000031.html');return false;">
|
884
|
+
<span class="method-name">execute(...)<br />
|
885
|
+
</span>
|
886
|
+
</a>
|
887
|
+
</div>
|
888
|
+
|
889
|
+
<div class="method-description">
|
890
|
+
<p>
|
891
|
+
Execute an Administration command against the local queue manager
|
892
|
+
</p>
|
893
|
+
<p>
|
894
|
+
Parameters:
|
895
|
+
</p>
|
896
|
+
<ul>
|
897
|
+
<li>Since the number of parameters can vary dramatically, all parameters are
|
898
|
+
passed by name in a hash
|
899
|
+
|
900
|
+
</li>
|
901
|
+
<li>The entire MQ Administration interface has been implemented. Rather than
|
902
|
+
re-documentation the hundreds of options, a standard convention has been
|
903
|
+
used to map the MQ constants to Symbols in Ruby.
|
904
|
+
|
905
|
+
</li>
|
906
|
+
</ul>
|
907
|
+
<p>
|
908
|
+
For all MQ Admin commands, just drop the MQAI_ off the front and convert
|
909
|
+
the command name to lower case.
|
910
|
+
</p>
|
911
|
+
<ul>
|
912
|
+
<li>E.g. MQAI_INQUIRE_Q becomes inquire_q
|
913
|
+
|
914
|
+
</li>
|
915
|
+
</ul>
|
916
|
+
<p>
|
917
|
+
For the hundreds of parameters, a similiar technique is followed. Remove
|
918
|
+
the prefixes: MQCA_, MQIA_, etc.. and convert to lowercase
|
919
|
+
</p>
|
920
|
+
<ul>
|
921
|
+
<li>E.g. MQCA_Q_NAME becomes :q_name
|
922
|
+
|
923
|
+
</li>
|
924
|
+
</ul>
|
925
|
+
<p>
|
926
|
+
Example
|
927
|
+
</p>
|
928
|
+
<pre>
|
929
|
+
WMQ::QueueManager.connect do |qmgr|
|
930
|
+
result = qmgr.execute(
|
931
|
+
:command => :inquire_q,
|
932
|
+
:q_name => 'MY.LOCAL.QUEUE',
|
933
|
+
:q_type => WMQ::MQQT_LOCAL,
|
934
|
+
:current_q_depth => nil
|
935
|
+
)
|
936
|
+
# OR, we can replace the method name execute with the MQAI command:
|
937
|
+
result = qmgr.inquire_q(
|
938
|
+
:q_name => 'MY.LOCAL.QUEUE',
|
939
|
+
:q_type => WMQ::MQQT_LOCAL,
|
940
|
+
:current_q_depth => nil
|
941
|
+
)
|
942
|
+
</pre>
|
943
|
+
<p>
|
944
|
+
Complete Example:
|
945
|
+
</p>
|
946
|
+
<pre>
|
947
|
+
require 'wmq/wmq'
|
948
|
+
require 'wmq/wmq_const_admin'
|
949
|
+
WMQ::QueueManager.connect(:q_mgr_name=>'REID', :connection_name=>'localhost(1414)') do |qmgr|
|
950
|
+
qmgr.reset_q_stats(:q_name=>'*').each {|item| p item }
|
951
|
+
end
|
952
|
+
</pre>
|
953
|
+
<p>
|
954
|
+
Some one line examples
|
955
|
+
</p>
|
956
|
+
<pre>
|
957
|
+
qmgr.inquire_q(:q_name=>'TEST*').each {|item| p item }
|
958
|
+
|
959
|
+
qmgr.inquire_q(:q_name=>'TEST*', :q_type=>WMQ::MQQT_LOCAL, :current_q_depth=>nil).each {|item| p item }
|
960
|
+
|
961
|
+
qmgr.inquire_process(:process_name=>'*').each {|item| p item }
|
962
|
+
|
963
|
+
qmgr.ping_q_mgr.each {|item| p item }
|
964
|
+
|
965
|
+
qmgr.refresh_security.each {|item| p item }
|
966
|
+
|
967
|
+
qmgr.inquire_q_status(:q_name=>'TEST*', :q_status_type=>:q_status, :q_status_attrs=>:process_id).each {|item| p item }
|
968
|
+
|
969
|
+
qmgr.start_channel_listener.each {|item| p item }
|
970
|
+
|
971
|
+
qmgr.inquire_channel_status(:channel_name=>'*').each {|item| p item }
|
972
|
+
</pre>
|
973
|
+
</div>
|
974
|
+
</div>
|
975
|
+
|
976
|
+
<div id="method-M000032" class="method-detail">
|
977
|
+
<a name="M000032"></a>
|
978
|
+
|
979
|
+
<div class="method-heading">
|
980
|
+
<a href="QueueManager.src/M000032.html" target="Code" class="method-signature"
|
981
|
+
onclick="popupCode('QueueManager.src/M000032.html');return false;">
|
982
|
+
<span class="method-name">method_missing</span><span class="method-args">(name, *args)</span>
|
983
|
+
</a>
|
984
|
+
</div>
|
985
|
+
|
986
|
+
<div class="method-description">
|
987
|
+
</div>
|
988
|
+
</div>
|
989
|
+
|
990
|
+
<div id="method-M000033" class="method-detail">
|
991
|
+
<a name="M000033"></a>
|
992
|
+
|
993
|
+
<div class="method-heading">
|
994
|
+
<a href="QueueManager.src/M000033.html" target="Code" class="method-signature"
|
995
|
+
onclick="popupCode('QueueManager.src/M000033.html');return false;">
|
996
|
+
<span class="method-name">mqsc</span><span class="method-args">(mqsc_text)</span>
|
997
|
+
</a>
|
998
|
+
</div>
|
999
|
+
|
1000
|
+
<div class="method-description">
|
1001
|
+
<p>
|
1002
|
+
Execute any MQSC command against the queue manager
|
1003
|
+
</p>
|
1004
|
+
<p>
|
1005
|
+
Example
|
1006
|
+
</p>
|
1007
|
+
<pre>
|
1008
|
+
require 'wmq/wmq'
|
1009
|
+
require 'wmq/wmq_const_admin'
|
1010
|
+
WMQ::QueueManager.connect(:q_mgr_name=>'REID', :connection_name=>'localhost(1414)') do |qmgr|
|
1011
|
+
qmgr.mqsc('dis ql(*)').each {|item| p item }
|
1012
|
+
end
|
1013
|
+
</pre>
|
1014
|
+
</div>
|
1015
|
+
</div>
|
1016
|
+
|
1017
|
+
<div id="method-M000030" class="method-detail">
|
1018
|
+
<a name="M000030"></a>
|
1019
|
+
|
1020
|
+
<div class="method-heading">
|
1021
|
+
<a href="QueueManager.src/M000030.html" target="Code" class="method-signature"
|
1022
|
+
onclick="popupCode('QueueManager.src/M000030.html');return false;">
|
1023
|
+
<span class="method-name">name</span><span class="method-args">()</span>
|
1024
|
+
</a>
|
1025
|
+
</div>
|
1026
|
+
|
1027
|
+
<div class="method-description">
|
1028
|
+
<p>
|
1029
|
+
Returns the <a href="QueueManager.html">QueueManager</a> name => String
|
1030
|
+
</p>
|
1031
|
+
</div>
|
1032
|
+
</div>
|
1033
|
+
|
1034
|
+
<div id="method-M000019" class="method-detail">
|
1035
|
+
<a name="M000019"></a>
|
1036
|
+
|
1037
|
+
<div class="method-heading">
|
1038
|
+
<a href="QueueManager.src/M000019.html" target="Code" class="method-signature"
|
1039
|
+
onclick="popupCode('QueueManager.src/M000019.html');return false;">
|
1040
|
+
<span class="method-name">open_queue(...)<br />
|
1041
|
+
access_queue(...)<br />
|
1042
|
+
</span>
|
1043
|
+
</a>
|
1044
|
+
</div>
|
1045
|
+
|
1046
|
+
<div class="method-description">
|
1047
|
+
<p>
|
1048
|
+
Open the specified queue, then close it once the supplied code block has
|
1049
|
+
completed
|
1050
|
+
</p>
|
1051
|
+
<p>
|
1052
|
+
Parameters:
|
1053
|
+
</p>
|
1054
|
+
<ul>
|
1055
|
+
<li>Since the number of parameters can vary dramatically, all parameters are
|
1056
|
+
passed by name in a hash
|
1057
|
+
|
1058
|
+
</li>
|
1059
|
+
<li>See <a href="Queue.html#M000003">Queue.open</a> for the complete list of
|
1060
|
+
parameters, except that :queue_manager is <b>not</b> required since it is
|
1061
|
+
supplied automatically by this method
|
1062
|
+
|
1063
|
+
</li>
|
1064
|
+
</ul>
|
1065
|
+
<p>
|
1066
|
+
Example:
|
1067
|
+
</p>
|
1068
|
+
<pre>
|
1069
|
+
require 'wmq/wmq_client'
|
1070
|
+
|
1071
|
+
WMQ::QueueManager.connect(:q_mgr_name=>'REID', :connection_name=>'localhost(1414)') do |qmgr|
|
1072
|
+
qmgr.open_queue(:q_name=>'TEST.QUEUE', :mode=>:output) do |queue|
|
1073
|
+
queue.put(:data => 'Hello World')
|
1074
|
+
end
|
1075
|
+
end
|
1076
|
+
</pre>
|
1077
|
+
</div>
|
1078
|
+
</div>
|
1079
|
+
|
1080
|
+
<div id="method-M000024" class="method-detail">
|
1081
|
+
<a name="M000024"></a>
|
1082
|
+
|
1083
|
+
<div class="method-heading">
|
1084
|
+
<a href="QueueManager.src/M000024.html" target="Code" class="method-signature"
|
1085
|
+
onclick="popupCode('QueueManager.src/M000024.html');return false;">
|
1086
|
+
<span class="method-name">put(parameters)<br />
|
1087
|
+
</span>
|
1088
|
+
</a>
|
1089
|
+
</div>
|
1090
|
+
|
1091
|
+
<div class="method-description">
|
1092
|
+
<p>
|
1093
|
+
Put a message to the queue without having to first open the queue
|
1094
|
+
Recommended for reply queues that change frequently
|
1095
|
+
</p>
|
1096
|
+
<ul>
|
1097
|
+
<li>parameters: a Hash consisting of one or more of the following parameters
|
1098
|
+
|
1099
|
+
</li>
|
1100
|
+
</ul>
|
1101
|
+
<p>
|
1102
|
+
Summary of parameters and their WebSphere MQ equivalents
|
1103
|
+
</p>
|
1104
|
+
<pre>
|
1105
|
+
queue.get( # WebSphere MQ Equivalents:
|
1106
|
+
:q_name => 'Queue Name', # MQOD.ObjectName
|
1107
|
+
:q_name => { queue_manager=>'QMGR_name', # MQOD.ObjectQMgrName
|
1108
|
+
q_name =>'q_name'}
|
1109
|
+
:message => my_message, # n/a : Instance of Message
|
1110
|
+
:data => "Hello World", # n/a : Data to send
|
1111
|
+
:sync => false, # MQGMO_SYNCPOINT
|
1112
|
+
:new_id => true, # MQPMO_NEW_MSG_ID & MQPMO_NEW_CORREL_ID
|
1113
|
+
:new_msg_id => true, # MQPMO_NEW_MSG_ID
|
1114
|
+
:new_correl_id => true, # MQPMO_NEW_CORREL_ID
|
1115
|
+
:fail_if_quiescing => true, # MQOO_FAIL_IF_QUIESCING
|
1116
|
+
:options => WMQ::MQPMO_FAIL_IF_QUIESCING # MQPMO_*
|
1117
|
+
)
|
1118
|
+
</pre>
|
1119
|
+
<p>
|
1120
|
+
Mandatory Parameters
|
1121
|
+
</p>
|
1122
|
+
<ul>
|
1123
|
+
<li>:q_name => String
|
1124
|
+
|
1125
|
+
<ul>
|
1126
|
+
<li>Name of the existing WebSphere MQ local queue, model queue or remote queue
|
1127
|
+
to open
|
1128
|
+
|
1129
|
+
</li>
|
1130
|
+
<li>To open remote queues for which a local remote queue definition is not
|
1131
|
+
available pass a Hash as q_name (see q_name => Hash)
|
1132
|
+
|
1133
|
+
<pre>
|
1134
|
+
OR
|
1135
|
+
</pre>
|
1136
|
+
</li>
|
1137
|
+
</ul>
|
1138
|
+
</li>
|
1139
|
+
<li>:q_name => Hash
|
1140
|
+
|
1141
|
+
<ul>
|
1142
|
+
<li>q_name => String
|
1143
|
+
|
1144
|
+
<ul>
|
1145
|
+
<li>Name of the existing WebSphere MQ local queue, model queue or remote queue
|
1146
|
+
to open
|
1147
|
+
|
1148
|
+
</li>
|
1149
|
+
</ul>
|
1150
|
+
</li>
|
1151
|
+
<li>:q_mgr_name => String
|
1152
|
+
|
1153
|
+
<ul>
|
1154
|
+
<li>Name of the remote WebSphere MQ queue manager to send the message to.
|
1155
|
+
|
1156
|
+
</li>
|
1157
|
+
<li>This allows a message to be written to a queue on a remote queue manager
|
1158
|
+
where a remote queue definition is not defined locally
|
1159
|
+
|
1160
|
+
</li>
|
1161
|
+
<li>Commonly used to reply to messages from remote systems
|
1162
|
+
|
1163
|
+
</li>
|
1164
|
+
<li>If q_mgr_name is the same as the local queue manager name then the message
|
1165
|
+
is merely written to the local queue.
|
1166
|
+
|
1167
|
+
</li>
|
1168
|
+
<li>Note: q_mgr_name should only be supplied when putting messages to the
|
1169
|
+
queue.
|
1170
|
+
|
1171
|
+
<pre>
|
1172
|
+
It is not possible to get messages from a queue on a queue manager other
|
1173
|
+
than the currently connected queue manager
|
1174
|
+
</pre>
|
1175
|
+
</li>
|
1176
|
+
</ul>
|
1177
|
+
</li>
|
1178
|
+
</ul>
|
1179
|
+
</li>
|
1180
|
+
<li>Either :message or :data must be supplied
|
1181
|
+
|
1182
|
+
<ul>
|
1183
|
+
<li>If both are supplied, then :data will be written to the queue. The data in
|
1184
|
+
:message will be ignored
|
1185
|
+
|
1186
|
+
</li>
|
1187
|
+
</ul>
|
1188
|
+
</li>
|
1189
|
+
</ul>
|
1190
|
+
<p>
|
1191
|
+
Optional Parameters
|
1192
|
+
</p>
|
1193
|
+
<ul>
|
1194
|
+
<li>:data => String
|
1195
|
+
|
1196
|
+
<ul>
|
1197
|
+
<li>Data to be written to the queue. Can be binary or text data
|
1198
|
+
|
1199
|
+
</li>
|
1200
|
+
</ul>
|
1201
|
+
</li>
|
1202
|
+
<li>:message => <a href="Message.html">Message</a>
|
1203
|
+
|
1204
|
+
<ul>
|
1205
|
+
<li>An instance of the <a href="Message.html">WMQ::Message</a>
|
1206
|
+
|
1207
|
+
</li>
|
1208
|
+
<li>The <a href="Message.html">Message</a> descriptor, headers and data is
|
1209
|
+
retrieved from :message
|
1210
|
+
|
1211
|
+
<ul>
|
1212
|
+
<li>message.data is ignored if :data is supplied
|
1213
|
+
|
1214
|
+
</li>
|
1215
|
+
</ul>
|
1216
|
+
</li>
|
1217
|
+
</ul>
|
1218
|
+
</li>
|
1219
|
+
<li>:sync => true or false
|
1220
|
+
|
1221
|
+
<ul>
|
1222
|
+
<li>Determines whether the get is performed under synchpoint. I.e. Under the
|
1223
|
+
current unit of work
|
1224
|
+
|
1225
|
+
<pre>
|
1226
|
+
Default: false
|
1227
|
+
</pre>
|
1228
|
+
</li>
|
1229
|
+
</ul>
|
1230
|
+
</li>
|
1231
|
+
<li>:new_id => true or false
|
1232
|
+
|
1233
|
+
<ul>
|
1234
|
+
<li>Generate a new message id and correlation id for this message. :new_msg_id
|
1235
|
+
and :new_correl_id will be ignored if this parameter is true
|
1236
|
+
|
1237
|
+
<pre>
|
1238
|
+
Default: false
|
1239
|
+
</pre>
|
1240
|
+
</li>
|
1241
|
+
</ul>
|
1242
|
+
</li>
|
1243
|
+
<li>:new_msg_id => true or false
|
1244
|
+
|
1245
|
+
<ul>
|
1246
|
+
<li>Generate a new message id for this message
|
1247
|
+
|
1248
|
+
</li>
|
1249
|
+
<li>Note: A blank message id will result in a new message id anyway. However,
|
1250
|
+
for subsequent puts using the same message descriptor, the same message id
|
1251
|
+
will be used.
|
1252
|
+
|
1253
|
+
<pre>
|
1254
|
+
Default: false
|
1255
|
+
</pre>
|
1256
|
+
</li>
|
1257
|
+
</ul>
|
1258
|
+
</li>
|
1259
|
+
<li>:new_correl_id => true or false
|
1260
|
+
|
1261
|
+
<ul>
|
1262
|
+
<li>Generate a new correlation id for this message
|
1263
|
+
|
1264
|
+
<pre>
|
1265
|
+
Default: false
|
1266
|
+
</pre>
|
1267
|
+
</li>
|
1268
|
+
</ul>
|
1269
|
+
</li>
|
1270
|
+
<li>:fail_if_quiescing => true or false
|
1271
|
+
|
1272
|
+
<ul>
|
1273
|
+
<li>Determines whether the <a href="Queue.html#M000007">WMQ::Queue#put</a> call
|
1274
|
+
will fail if the queue manager is in the process of being quiesced.
|
1275
|
+
|
1276
|
+
</li>
|
1277
|
+
<li>Note: This interface differs from other WebSphere MQ interfaces, they do
|
1278
|
+
not default to true.
|
1279
|
+
|
1280
|
+
<pre>
|
1281
|
+
Default: true
|
1282
|
+
Equivalent to: MQGMO_FAIL_IF_QUIESCING
|
1283
|
+
</pre>
|
1284
|
+
</li>
|
1285
|
+
<li>Note: As part of the application design, carefull consideration should be
|
1286
|
+
given as to when to allow a transaction or unit of work to complete or fail
|
1287
|
+
under this condition. As such it is important to include this option where
|
1288
|
+
appropriate so that MQ Administrators can shutdown the queue managers
|
1289
|
+
without having to resort to the ‘immediate’ shutdown option.
|
1290
|
+
|
1291
|
+
</li>
|
1292
|
+
</ul>
|
1293
|
+
</li>
|
1294
|
+
<li>:options => Fixnum (Advanced MQ Use only)
|
1295
|
+
|
1296
|
+
<ul>
|
1297
|
+
<li>Numeric field containing any of the MQ Put message options or’d
|
1298
|
+
together
|
1299
|
+
|
1300
|
+
<ul>
|
1301
|
+
<li>E.g. :options => WMQ::MQPMO_PASS_IDENTITY_CONTEXT |
|
1302
|
+
WMQ::MQPMO_ALTERNATE_USER_AUTHORITY
|
1303
|
+
|
1304
|
+
</li>
|
1305
|
+
</ul>
|
1306
|
+
</li>
|
1307
|
+
<li>Note: If :options is supplied, it is applied first, then the above
|
1308
|
+
parameters are applied afterwards.
|
1309
|
+
|
1310
|
+
</li>
|
1311
|
+
<li>One or more of the following values:
|
1312
|
+
|
1313
|
+
<pre>
|
1314
|
+
WMQ::MQPMO_NO_SYNCPOINT
|
1315
|
+
WMQ::MQPMO_LOGICAL_ORDER
|
1316
|
+
WMQ::MQPMO_NO_CONTEXT
|
1317
|
+
WMQ::MQPMO_DEFAULT_CONTEXT
|
1318
|
+
WMQ::MQPMO_PASS_IDENTITY_CONTEXT
|
1319
|
+
WMQ::MQPMO_PASS_ALL_CONTEXT
|
1320
|
+
WMQ::MQPMO_SET_IDENTITY_CONTEXT
|
1321
|
+
WMQ::MQPMO_SET_ALL_CONTEXT
|
1322
|
+
WMQ::MQPMO_ALTERNATE_USER_AUTHORITY
|
1323
|
+
WMQ::MQPMO_RESOLVE_LOCAL_Q
|
1324
|
+
WMQ::MQPMO_NONE
|
1325
|
+
</pre>
|
1326
|
+
</li>
|
1327
|
+
<li>Please see the WebSphere MQ documentation for more details on the above
|
1328
|
+
options
|
1329
|
+
|
1330
|
+
<pre>
|
1331
|
+
Default: WMQ::MQPMO_NONE
|
1332
|
+
</pre>
|
1333
|
+
</li>
|
1334
|
+
</ul>
|
1335
|
+
</li>
|
1336
|
+
</ul>
|
1337
|
+
<p>
|
1338
|
+
Returns:
|
1339
|
+
</p>
|
1340
|
+
<ul>
|
1341
|
+
<li>true : On Success
|
1342
|
+
|
1343
|
+
</li>
|
1344
|
+
<li>false: On Failure
|
1345
|
+
|
1346
|
+
<p>
|
1347
|
+
<a href="QueueManager.html#M000025">comp_code</a> and <a
|
1348
|
+
href="QueueManager.html#M000026">reason_code</a> are also updated. reason
|
1349
|
+
will return a text description of the <a
|
1350
|
+
href="QueueManager.html#M000026">reason_code</a>
|
1351
|
+
</p>
|
1352
|
+
</li>
|
1353
|
+
</ul>
|
1354
|
+
<p>
|
1355
|
+
Throws:
|
1356
|
+
</p>
|
1357
|
+
<ul>
|
1358
|
+
<li><a href="WMQException.html">WMQ::WMQException</a> if <a
|
1359
|
+
href="QueueManager.html#M000025">comp_code</a> == MQCC_FAILED
|
1360
|
+
|
1361
|
+
</li>
|
1362
|
+
<li>Except if :<a href="QueueManager.html#M000028">exception_on_error</a> =>
|
1363
|
+
false was supplied as a parameter to <a
|
1364
|
+
href="QueueManager.html#M000016">QueueManager.new</a>
|
1365
|
+
|
1366
|
+
</li>
|
1367
|
+
</ul>
|
1368
|
+
</div>
|
1369
|
+
</div>
|
1370
|
+
|
1371
|
+
<div id="method-M000035" class="method-detail">
|
1372
|
+
<a name="M000035"></a>
|
1373
|
+
|
1374
|
+
<div class="method-heading">
|
1375
|
+
<a href="QueueManager.src/M000035.html" target="Code" class="method-signature"
|
1376
|
+
onclick="popupCode('QueueManager.src/M000035.html');return false;">
|
1377
|
+
<span class="method-name">put_to_dead_letter_q</span><span class="method-args">(parms)</span>
|
1378
|
+
</a>
|
1379
|
+
</div>
|
1380
|
+
|
1381
|
+
<div class="method-description">
|
1382
|
+
<p>
|
1383
|
+
Put a message to the Dead Letter <a href="Queue.html">Queue</a>
|
1384
|
+
</p>
|
1385
|
+
<pre>
|
1386
|
+
If an error occurs when processing a datagram message
|
1387
|
+
it is necessary to move the message to the dead letter queue.
|
1388
|
+
I.e. An error message cannot be sent back to the sender because
|
1389
|
+
the original message was not a request message.
|
1390
|
+
I.e. msg_type != WMQ::MQMT_REQUEST
|
1391
|
+
|
1392
|
+
All existing message data, message descriptor and message headers
|
1393
|
+
are retained.
|
1394
|
+
</pre>
|
1395
|
+
</div>
|
1396
|
+
</div>
|
1397
|
+
|
1398
|
+
<div id="method-M000034" class="method-detail">
|
1399
|
+
<a name="M000034"></a>
|
1400
|
+
|
1401
|
+
<div class="method-heading">
|
1402
|
+
<a href="QueueManager.src/M000034.html" target="Code" class="method-signature"
|
1403
|
+
onclick="popupCode('QueueManager.src/M000034.html');return false;">
|
1404
|
+
<span class="method-name">put_to_reply_q</span><span class="method-args">(parms)</span>
|
1405
|
+
</a>
|
1406
|
+
</div>
|
1407
|
+
|
1408
|
+
<div class="method-description">
|
1409
|
+
<p>
|
1410
|
+
Put a reply message back to the sender
|
1411
|
+
</p>
|
1412
|
+
<pre>
|
1413
|
+
The :message is sent to the queue and queue manager specified in the
|
1414
|
+
:reply_to_q and :reply_to_q_mgr propoerties of the :request_message.
|
1415
|
+
|
1416
|
+
The following rules are followed before sending the reply:
|
1417
|
+
- Only send replies to Request messages. No reply for Datagrams
|
1418
|
+
- Set the message type to Reply when replying to a request message
|
1419
|
+
- Reply with:
|
1420
|
+
- Remaining Expiry (Ideally deduct any processing time since get)
|
1421
|
+
- Same priority as received message
|
1422
|
+
- Same persistence as received message
|
1423
|
+
- Adhere to the Report options supplied for message and correlation id's
|
1424
|
+
in reply message
|
1425
|
+
- All headers must be returned on reply messages
|
1426
|
+
- This allows the calling application to store state information
|
1427
|
+
in these headers
|
1428
|
+
- Unless of course if the relevant header is input only and used
|
1429
|
+
for completing the request
|
1430
|
+
- In this case any remaining headers should be returned
|
1431
|
+
to the caller
|
1432
|
+
</pre>
|
1433
|
+
<p>
|
1434
|
+
Parameters:
|
1435
|
+
</p>
|
1436
|
+
<pre>
|
1437
|
+
* :request_message The message originally received
|
1438
|
+
* All the other parameters are the same as QueueManager#put
|
1439
|
+
</pre>
|
1440
|
+
</div>
|
1441
|
+
</div>
|
1442
|
+
|
1443
|
+
<div id="method-M000027" class="method-detail">
|
1444
|
+
<a name="M000027"></a>
|
1445
|
+
|
1446
|
+
<div class="method-heading">
|
1447
|
+
<a href="QueueManager.src/M000027.html" target="Code" class="method-signature"
|
1448
|
+
onclick="popupCode('QueueManager.src/M000027.html');return false;">
|
1449
|
+
<span class="method-name">reason</span><span class="method-args">()</span>
|
1450
|
+
</a>
|
1451
|
+
</div>
|
1452
|
+
|
1453
|
+
<div class="method-description">
|
1454
|
+
<p>
|
1455
|
+
Returns a textual representation of the <a
|
1456
|
+
href="QueueManager.html#M000026">reason_code</a> for the last MQ operation
|
1457
|
+
</p>
|
1458
|
+
<p>
|
1459
|
+
Returns => String
|
1460
|
+
</p>
|
1461
|
+
<ul>
|
1462
|
+
<li>For a complete list of reasons, please see <a href="../WMQ.html">WMQ</a>
|
1463
|
+
Constants or the WebSphere MQ documentation for Reason Codes
|
1464
|
+
|
1465
|
+
</li>
|
1466
|
+
</ul>
|
1467
|
+
<p>
|
1468
|
+
Note
|
1469
|
+
</p>
|
1470
|
+
<ul>
|
1471
|
+
<li>The list of Reason Codes varies depending on the version of WebSphere MQ
|
1472
|
+
and the operating system on which Ruby <a href="../WMQ.html">WMQ</a> was
|
1473
|
+
compiled
|
1474
|
+
|
1475
|
+
</li>
|
1476
|
+
</ul>
|
1477
|
+
</div>
|
1478
|
+
</div>
|
1479
|
+
|
1480
|
+
<div id="method-M000026" class="method-detail">
|
1481
|
+
<a name="M000026"></a>
|
1482
|
+
|
1483
|
+
<div class="method-heading">
|
1484
|
+
<a href="QueueManager.src/M000026.html" target="Code" class="method-signature"
|
1485
|
+
onclick="popupCode('QueueManager.src/M000026.html');return false;">
|
1486
|
+
<span class="method-name">reason_code</span><span class="method-args">()</span>
|
1487
|
+
</a>
|
1488
|
+
</div>
|
1489
|
+
|
1490
|
+
<div class="method-description">
|
1491
|
+
<p>
|
1492
|
+
Return the reason code for the last MQ operation
|
1493
|
+
</p>
|
1494
|
+
<p>
|
1495
|
+
Returns => FixNum
|
1496
|
+
</p>
|
1497
|
+
<ul>
|
1498
|
+
<li>For a complete list of reason codes, please see <a
|
1499
|
+
href="../WMQ.html">WMQ</a> Constants or the WebSphere MQ documentation for
|
1500
|
+
Reason Codes
|
1501
|
+
|
1502
|
+
</li>
|
1503
|
+
</ul>
|
1504
|
+
<p>
|
1505
|
+
Note
|
1506
|
+
</p>
|
1507
|
+
<ul>
|
1508
|
+
<li>The list of Reason Codes varies depending on the version of WebSphere MQ
|
1509
|
+
and the operating system on which Ruby <a href="../WMQ.html">WMQ</a> was
|
1510
|
+
compiled
|
1511
|
+
|
1512
|
+
</li>
|
1513
|
+
</ul>
|
1514
|
+
</div>
|
1515
|
+
</div>
|
1516
|
+
|
1517
|
+
|
1518
|
+
</div>
|
1519
|
+
|
1520
|
+
|
1521
|
+
</div>
|
1522
|
+
|
1523
|
+
|
1524
|
+
<div id="validator-badges">
|
1525
|
+
<p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
|
1526
|
+
</div>
|
1527
|
+
|
1528
|
+
</body>
|
1529
|
+
</html>
|