1 | <?php |
||
5 | abstract class AbstractQueueTransport implements QueueTransport { |
||
6 | /** |
||
7 | * @var iMessage[]|object[] |
||
8 | */ |
||
9 | protected $_pushed_for_save = []; |
||
10 | |||
11 | protected $_same_time_consumer_and_producer = 0; |
||
12 | |||
13 | /** |
||
14 | * @var callable|null |
||
15 | */ |
||
16 | protected $_callback_closure = null; |
||
17 | |||
18 | /** |
||
19 | * @var integer[] В keys список индексов полученных сообщений |
||
20 | */ |
||
21 | protected $_consumed_keys = []; |
||
22 | |||
23 | /** |
||
24 | * Удалить сообщение и сразу же записать это в БД |
||
25 | * |
||
26 | * @param iMessage|object $message |
||
27 | * |
||
28 | * @return boolean |
||
29 | */ |
||
30 | 312 | function delete_message($message) { |
|
33 | |||
34 | /** |
||
35 | * Загоняем сообщение в очередь и явно сохраняем |
||
36 | * |
||
37 | * @param mixed $data |
||
38 | * @param string|null $name Название сообщения. Если null, то можно дублировать |
||
39 | * @param integer $sort |
||
40 | * |
||
41 | * @throws QueueException |
||
42 | */ |
||
43 | 216 | function produce_message($data, $name = null, $sort = 5) { |
|
47 | |||
48 | /** |
||
49 | * Загоняем сообщение в очередь необходимых для сохранения сообщений |
||
50 | * |
||
51 | * @param iMessage[]|iMessage|object[]|object $stream |
||
52 | * |
||
53 | * @throws QueueException |
||
54 | */ |
||
55 | 3678 | function push($stream) { |
|
65 | |||
66 | /** |
||
67 | * @param integer $flag |
||
68 | * |
||
69 | * @throws QueueException |
||
70 | */ |
||
71 | 3720 | protected function set_same_time_flag($flag) { |
|
77 | |||
78 | /** |
||
79 | * @param callable $closure |
||
80 | */ |
||
81 | 3 | function set_callback_closure($closure) { |
|
84 | |||
85 | /** |
||
86 | * @param double|integer $wait_time |
||
87 | * |
||
88 | * @throws QueueException |
||
89 | */ |
||
90 | 3 | function listen($wait_time = -1) { |
|
105 | |||
106 | 3429 | function __clone() { |
|
111 | |||
112 | 9 | function clear_consumed_keys() { |
|
115 | |||
116 | /** |
||
117 | * @return boolean |
||
118 | */ |
||
119 | 231 | function is_producer() { |
|
122 | |||
123 | /** |
||
124 | * @return boolean |
||
125 | */ |
||
126 | 378 | function is_consumer() { |
|
129 | |||
130 | /** |
||
131 | * @param iMessage|object $message |
||
132 | * |
||
133 | * @return string |
||
134 | */ |
||
135 | 3672 | static function get_real_key_for_message($message) { |
|
138 | |||
139 | /** |
||
140 | * @param iMessage[] $messages |
||
141 | * @param iMessage $message |
||
142 | * @param string $message_key |
||
143 | * |
||
144 | * @return boolean |
||
145 | */ |
||
146 | 338 | protected function change_message_in_array(array &$messages, $message, $message_key) { |
|
162 | |||
163 | /** |
||
164 | * @param QueueTransport $queue |
||
165 | * |
||
166 | * @return boolean |
||
167 | */ |
||
168 | 1242 | function is_equal_to($queue) { |
|
171 | |||
172 | /** |
||
173 | * @return string |
||
174 | */ |
||
175 | static function generate_rnd_postfix() { |
||
178 | |||
179 | // @todo Удаление конкретных ключей из consumed. Причем туда передаётся кложур, в который передаётся название ключа |
||
180 | // @todo Удаление конкретных ключей из индекса и очереди, с указанием max_create_timestamp, |
||
181 | // чтобы не хранить в очереди те же сообщения, пришедшие ещё раз |
||
182 | } |
||
183 | |||
184 | ?> |
Adding explicit visibility (
private
,protected
, orpublic
) is generally recommend to communicate to other developers how, and from where this method is intended to be used.