|
14 | 14 | BindingSpecification, |
15 | 15 | ExchangeSpecification, |
16 | 16 | QueueInfo, |
17 | | - QueueSpecification, |
18 | 17 | ) |
19 | 18 | from .exceptions import ValidationCodeException |
20 | 19 | from .options import ReceiverOption, SenderOption |
|
24 | 23 | BlockingReceiver, |
25 | 24 | BlockingSender, |
26 | 25 | ) |
| 26 | +from .queues import ( |
| 27 | + ClassicQueueSpecification, |
| 28 | + QuorumQueueSpecification, |
| 29 | + StreamSpecification, |
| 30 | +) |
27 | 31 |
|
28 | 32 | logger = logging.getLogger(__name__) |
29 | 33 |
|
@@ -125,9 +129,41 @@ def declare_exchange( |
125 | 129 | return exchange_specification |
126 | 130 |
|
127 | 131 | def declare_queue( |
128 | | - self, queue_specification: QueueSpecification |
129 | | - ) -> QueueSpecification: |
| 132 | + self, |
| 133 | + queue_specification: ( |
| 134 | + ClassicQueueSpecification | QuorumQueueSpecification | StreamSpecification |
| 135 | + ), |
| 136 | + ) -> ClassicQueueSpecification | QuorumQueueSpecification | StreamSpecification: |
130 | 137 | logger.debug("declare_queue operation called") |
| 138 | + |
| 139 | + if ( |
| 140 | + type(queue_specification) is ClassicQueueSpecification |
| 141 | + or type(queue_specification) is QuorumQueueSpecification |
| 142 | + ): |
| 143 | + body = self._declare_queue(queue_specification) |
| 144 | + |
| 145 | + elif type(queue_specification) is StreamSpecification: |
| 146 | + body = self._declare_stream(queue_specification) |
| 147 | + |
| 148 | + path = queue_address(queue_specification.name) |
| 149 | + |
| 150 | + self.request( |
| 151 | + body, |
| 152 | + path, |
| 153 | + CommonValues.command_put.value, |
| 154 | + [ |
| 155 | + CommonValues.response_code_200.value, |
| 156 | + CommonValues.response_code_201.value, |
| 157 | + CommonValues.response_code_409.value, |
| 158 | + ], |
| 159 | + ) |
| 160 | + |
| 161 | + return queue_specification |
| 162 | + |
| 163 | + def _declare_queue( |
| 164 | + self, queue_specification: ClassicQueueSpecification | QuorumQueueSpecification |
| 165 | + ) -> dict[str, Any]: |
| 166 | + |
131 | 167 | body = {} |
132 | 168 | args: dict[str, Any] = {} |
133 | 169 |
|
@@ -155,22 +191,63 @@ def declare_queue( |
155 | 191 | queue_specification.single_active_consumer |
156 | 192 | ) |
157 | 193 |
|
| 194 | + if type(queue_specification) is ClassicQueueSpecification: |
| 195 | + if queue_specification.maximum_priority is not None: |
| 196 | + args["x-maximum-priority"] = queue_specification.maximum_priority |
| 197 | + |
| 198 | + if type(queue_specification) is QuorumQueueSpecification: |
| 199 | + if queue_specification.deliver_limit is not None: |
| 200 | + args["x-deliver-limit"] = queue_specification.deliver_limit |
| 201 | + |
| 202 | + if queue_specification.dead_letter_strategy is not None: |
| 203 | + args["x-dead-letter-strategy"] = ( |
| 204 | + queue_specification.dead_letter_strategy |
| 205 | + ) |
| 206 | + |
| 207 | + if queue_specification.quorum_initial_group_size is not None: |
| 208 | + args["x-initial-quorum-group-size"] = ( |
| 209 | + queue_specification.quorum_initial_group_size |
| 210 | + ) |
| 211 | + |
| 212 | + if queue_specification.cluster_target_size is not None: |
| 213 | + args["cluster_target_size"] = queue_specification.cluster_target_size |
| 214 | + |
158 | 215 | body["arguments"] = args # type: ignore |
159 | 216 |
|
160 | | - path = queue_address(queue_specification.name) |
| 217 | + return body |
161 | 218 |
|
162 | | - self.request( |
163 | | - body, |
164 | | - path, |
165 | | - CommonValues.command_put.value, |
166 | | - [ |
167 | | - CommonValues.response_code_200.value, |
168 | | - CommonValues.response_code_201.value, |
169 | | - CommonValues.response_code_409.value, |
170 | | - ], |
171 | | - ) |
| 219 | + def _declare_stream( |
| 220 | + self, stream_specification: StreamSpecification |
| 221 | + ) -> dict[str, Any]: |
172 | 222 |
|
173 | | - return queue_specification |
| 223 | + body = {} |
| 224 | + args: dict[str, Any] = {} |
| 225 | + |
| 226 | + args["x-queue-type"] = stream_specification.queue_type.value |
| 227 | + |
| 228 | + if stream_specification.max_len_bytes is not None: |
| 229 | + args["x-max-length-bytes"] = stream_specification.max_len_bytes |
| 230 | + |
| 231 | + if stream_specification.max_time_retention is not None: |
| 232 | + args["x-max-time-retention"] = stream_specification.max_time_retention |
| 233 | + |
| 234 | + if stream_specification.max_segment_size_in_bytes is not None: |
| 235 | + args["x-max-segment-size-in-bytes"] = ( |
| 236 | + stream_specification.max_segment_size_in_bytes |
| 237 | + ) |
| 238 | + |
| 239 | + if stream_specification.filter_size is not None: |
| 240 | + args["x-filter-size"] = stream_specification.filter_size |
| 241 | + |
| 242 | + if stream_specification.initial_group_size is not None: |
| 243 | + args["x-initial-group-size"] = stream_specification.initial_group_size |
| 244 | + |
| 245 | + if stream_specification.leader_locator is not None: |
| 246 | + args["x-leader-locator"] = stream_specification.leader_locator |
| 247 | + |
| 248 | + body["arguments"] = args |
| 249 | + |
| 250 | + return body |
174 | 251 |
|
175 | 252 | def delete_exchange(self, exchange_name: str) -> None: |
176 | 253 | logger.debug("delete_exchange operation called") |
|
0 commit comments