-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtransactions.php
95 lines (84 loc) · 2.44 KB
/
transactions.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php
require __DIR__ . '/../vendor/autoload.php';
/**
*
* Copyright (C) 2009 Progress Software, Inc. All rights reserved.
* http://fusesource.com
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
use Stomp\Client;
use Stomp\Network\Connection;
use Stomp\StatefulStomp;
use Stomp\Transport\Message;
// make a connection
$connection = new Connection('tcp://localhost:61613');
$connection->setReadTimeout(1);
$stomp = new StatefulStomp(new Client($connection));
// subscribe to the queue
$stomp->subscribe('/queue/transactions', null, 'client');
// try to send some messages
$stomp->begin();
for ($i = 1; $i < 3; $i++) {
$stomp->send('/queue/transactions', new Message($i));
}
// if we abort transaction, messages will not be sent
$stomp->abort();
// now send some messages for real
$stomp->begin();
echo "Sent messages {\n";
for ($i = 1; $i < 5; $i++) {
echo "\t$i\n";
$stomp->send('/queue/transactions', new Message($i));
}
echo "}\n";
// they will be available for consumers after commit
$stomp->commit();
// try to receive some messages
$stomp->begin();
$messages = array();
for ($i = 1; $i < 3; $i++) {
$msg = $stomp->read();
array_push($messages, $msg);
$stomp->ack($msg);
}
// of we abort transaction, we will "rollback" out acks
$stomp->abort();
$stomp->begin();
// so we need to ack received messages again
// before we can receive more (prefetch = 1)
if (count($messages) != 0) {
foreach ($messages as $msg) {
$stomp->ack($msg);
}
}
// now receive more messages
for ($i = 1; $i < 3; $i++) {
$msg = $stomp->read();
$stomp->ack($msg);
array_push($messages, $msg);
}
// commit all acks
$stomp->commit();
echo "Processed messages {\n";
foreach ($messages as $msg) {
echo "\t$msg->body\n";
}
echo "}\n";
//ensure there are no more messages in the queue
$frame = $stomp->read();
if ($frame === false) {
echo "No more messages in the queue\n";
} else {
echo "Warning: some messages still in the queue: $frame\n";
}