abs-utils 0.2.7__tar.gz → 0.3.0__tar.gz

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.
Files changed (21) hide show
  1. {abs_utils-0.2.7 → abs_utils-0.3.0}/PKG-INFO +1 -1
  2. abs_utils-0.3.0/abs_utils/azure_service_bus/azure_service_bus.py +79 -0
  3. {abs_utils-0.2.7 → abs_utils-0.3.0}/pyproject.toml +1 -1
  4. abs_utils-0.2.7/abs_utils/azure_service_bus/azure_service_bus.py +0 -21
  5. {abs_utils-0.2.7 → abs_utils-0.3.0}/README.md +0 -0
  6. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/azure_service_bus/__init__.py +0 -0
  7. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/azure_service_bus/event_decorator.py +0 -0
  8. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/constants/__init__.py +0 -0
  9. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/constants/endpoint_constants.py +0 -0
  10. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/constants/event_constants.py +0 -0
  11. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/logger/__init__.py +0 -0
  12. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/logger/logger.py +0 -0
  13. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/schemas/__init__.py +0 -0
  14. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/schemas/fields_schema/__init__.py +0 -0
  15. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/schemas/fields_schema/common_schema.py +0 -0
  16. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/schemas/fields_schema/field_schema.py +0 -0
  17. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/schemas/libs/__init__.py +0 -0
  18. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/schemas/libs/extend_enum.py +0 -0
  19. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/schemas/libs/make_optional.py +0 -0
  20. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/socket_io/__init__.py +0 -0
  21. {abs_utils-0.2.7 → abs_utils-0.3.0}/abs_utils/socket_io/server.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: abs-utils
3
- Version: 0.2.7
3
+ Version: 0.3.0
4
4
  Summary: AutoBridge Systems Utility Library
5
5
  Author: AutoBridgeSystems
6
6
  Author-email: info@autobridgesystems.com
@@ -0,0 +1,79 @@
1
+ from azure.servicebus.aio import ServiceBusClient
2
+ from azure.servicebus import ServiceBusMessage, ServiceBusReceiveMode
3
+ from azure.servicebus.exceptions import ServiceBusError
4
+ import json
5
+ from typing import Optional
6
+ from ..logger import setup_logger
7
+
8
+ logger = setup_logger(__name__)
9
+
10
+ class AzureServiceBus:
11
+ def __init__(self, connection_string: str, queue_name: str):
12
+ self.connection_string = connection_string
13
+ self.queue_name = queue_name
14
+ self.client = ServiceBusClient.from_connection_string(conn_str=connection_string)
15
+ self.sender = None
16
+ self.receiver = None
17
+
18
+ async def connect(self):
19
+ """Establish sender and receiver clients"""
20
+ try:
21
+ self.sender = self.client.get_queue_sender(queue_name=self.queue_name)
22
+ self.receiver = self.client.get_queue_receiver(
23
+ queue_name=self.queue_name,
24
+ receive_mode=ServiceBusReceiveMode.PEEK_LOCK
25
+ )
26
+ logger.info(f"Connected to queue: {self.queue_name}")
27
+ except ServiceBusError as e:
28
+ logger.error(f"Connection error: {e}")
29
+ raise
30
+
31
+ async def disconnect(self):
32
+ """Close connections"""
33
+ try:
34
+ if self.sender:
35
+ await self.sender.close()
36
+ if self.receiver:
37
+ await self.receiver.close()
38
+ await self.client.close()
39
+ logger.info("Disconnected from Service Bus")
40
+ except ServiceBusError as e:
41
+ logger.error(f"Disconnection error: {e}")
42
+ raise
43
+
44
+ async def send(self, event_payload: dict):
45
+ """Send a message to the queue"""
46
+ if not self.sender:
47
+ await self.connect()
48
+ try:
49
+ message = ServiceBusMessage(
50
+ body=json.dumps(event_payload),
51
+ content_type="application/json"
52
+ )
53
+ await self.sender.send_messages(message)
54
+ logger.info("Message sent")
55
+ except ServiceBusError as e:
56
+ logger.error(f"Send error: {e}")
57
+ raise
58
+
59
+ async def receive_messages(self, max_message_count: int = 1, timeout: int = 30):
60
+ """Receive messages from the queue"""
61
+ if not self.receiver:
62
+ await self.connect()
63
+ try:
64
+ return await self.receiver.receive_messages(
65
+ max_message_count=max_message_count,
66
+ max_wait_time=timeout
67
+ )
68
+ except ServiceBusError as e:
69
+ logger.error(f"Receive error: {e}")
70
+ raise
71
+
72
+ async def complete_message(self, message):
73
+ """Mark a received message as completed"""
74
+ try:
75
+ await self.receiver.complete_message(message)
76
+ logger.info("Message completed")
77
+ except ServiceBusError as e:
78
+ logger.error(f"Completion error: {e}")
79
+ raise
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "abs-utils"
3
- version = "0.2.7"
3
+ version = "0.3.0"
4
4
  description = "AutoBridge Systems Utility Library"
5
5
  authors = [
6
6
  {name = "AutoBridgeSystems", email = "info@autobridgesystems.com"}
@@ -1,21 +0,0 @@
1
- from azure.servicebus import ServiceBusClient, ServiceBusMessage
2
- import json
3
- from ..logger import setup_logger
4
-
5
- logger = setup_logger(__name__)
6
- class AzureServiceBus:
7
- def __init__(self, connection_string: str, queue_name: str):
8
- self.client = ServiceBusClient.from_connection_string(conn_str=connection_string)
9
- self.queue_name = queue_name
10
-
11
- async def send(self, event_payload: dict):
12
- """Send message to Azure Service Bus"""
13
- if not self.client or not self.queue_name:
14
- return
15
-
16
- try:
17
- sender = self.client.get_queue_sender(queue_name=self.queue_name)
18
- with sender:
19
- sender.send_messages(ServiceBusMessage(json.dumps(event_payload)))
20
- except Exception as e:
21
- logger.error(f"Failed to send message to Azure Service Bus: {e}")
File without changes