|  |  | @ -14,39 +14,71 @@ from prometheus_client import Counter, Histogram, start_http_server | 
			
		
	
		
		
			
				
					
					|  |  |  | from pydantic import BaseModel, Field, validator |  |  |  | from pydantic import BaseModel, Field, validator | 
			
		
	
		
		
			
				
					
					|  |  |  | from tenacity import retry, stop_after_attempt, wait_exponential |  |  |  | from tenacity import retry, stop_after_attempt, wait_exponential | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | from swarms.prompts.finance_agent_sys_prompt import FINANCIAL_AGENT_SYS_PROMPT |  |  |  | from swarms.prompts.finance_agent_sys_prompt import ( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     FINANCIAL_AGENT_SYS_PROMPT, | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | ) | 
			
		
	
		
		
			
				
					
					|  |  |  | from swarms.structs.agent import Agent |  |  |  | from swarms.structs.agent import Agent | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | # Enhanced metrics |  |  |  | # Enhanced metrics | 
			
		
	
		
		
			
				
					
					|  |  |  | TASK_COUNTER = Counter('swarm_tasks_total', 'Total number of tasks processed') |  |  |  | TASK_COUNTER = Counter( | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | TASK_LATENCY = Histogram('swarm_task_duration_seconds', 'Task processing duration') |  |  |  |     "swarm_tasks_total", "Total number of tasks processed" | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | TASK_FAILURES = Counter('swarm_task_failures_total', 'Total number of task failures') |  |  |  | ) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | AGENT_ERRORS = Counter('swarm_agent_errors_total', 'Total number of agent errors') |  |  |  | TASK_LATENCY = Histogram( | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     "swarm_task_duration_seconds", "Task processing duration" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | TASK_FAILURES = Counter( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     "swarm_task_failures_total", "Total number of task failures" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | AGENT_ERRORS = Counter( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     "swarm_agent_errors_total", "Total number of agent errors" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | # Define types using Literal |  |  |  | # Define types using Literal | 
			
		
	
		
		
			
				
					
					|  |  |  | TaskStatus = Literal["pending", "processing", "completed", "failed"] |  |  |  | TaskStatus = Literal["pending", "processing", "completed", "failed"] | 
			
		
	
		
		
			
				
					
					|  |  |  | TaskPriority = Literal["low", "medium", "high", "critical"] |  |  |  | TaskPriority = Literal["low", "medium", "high", "critical"] | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | class SecurityConfig(BaseModel): |  |  |  | class SecurityConfig(BaseModel): | 
			
		
	
		
		
			
				
					
					|  |  |  |     """Security configuration for the swarm""" |  |  |  |     """Security configuration for the swarm""" | 
			
		
	
		
		
			
				
					
					|  |  |  |     encryption_key: str = Field(..., description="Encryption key for sensitive data") |  |  |  | 
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     tls_cert_path: Optional[str] = Field(None, description="Path to TLS certificate") |  |  |  |     encryption_key: str = Field( | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     tls_key_path: Optional[str] = Field(None, description="Path to TLS private key") |  |  |  |         ..., description="Encryption key for sensitive data" | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     auth_token: Optional[str] = Field(None, description="Authentication token") |  |  |  |     ) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     max_message_size: int = Field(default=1048576, description="Maximum message size in bytes") |  |  |  |     tls_cert_path: Optional[str] = Field( | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     rate_limit: int = Field(default=100, description="Maximum tasks per minute") |  |  |  |         None, description="Path to TLS certificate" | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |     ) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     @validator('encryption_key') |  |  |  |     tls_key_path: Optional[str] = Field( | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         None, description="Path to TLS private key" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     auth_token: Optional[str] = Field( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         None, description="Authentication token" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     max_message_size: int = Field( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         default=1048576, description="Maximum message size in bytes" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     rate_limit: int = Field( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         default=100, description="Maximum tasks per minute" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     @validator("encryption_key") | 
			
		
	
		
		
			
				
					
					|  |  |  |     def validate_encryption_key(cls, v): |  |  |  |     def validate_encryption_key(cls, v): | 
			
		
	
		
		
			
				
					
					|  |  |  |         if len(v) < 32: |  |  |  |         if len(v) < 32: | 
			
		
	
		
		
			
				
					
					|  |  |  |             raise ValueError("Encryption key must be at least 32 bytes long") |  |  |  |             raise ValueError( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 "Encryption key must be at least 32 bytes long" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             ) | 
			
		
	
		
		
			
				
					
					|  |  |  |         return v |  |  |  |         return v | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | class Task(BaseModel): |  |  |  | class Task(BaseModel): | 
			
		
	
		
		
			
				
					
					|  |  |  |     """Enhanced task model with additional metadata and validation""" |  |  |  |     """Enhanced task model with additional metadata and validation""" | 
			
		
	
		
		
			
				
					
					|  |  |  |     task_id: str = Field(..., description="Unique identifier for the task") |  |  |  | 
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     description: str = Field(..., description="Task description or instructions") |  |  |  |     task_id: str = Field( | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         ..., description="Unique identifier for the task" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     description: str = Field( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         ..., description="Task description or instructions" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |     output_type: Literal["string", "json", "file"] = Field("string") |  |  |  |     output_type: Literal["string", "json", "file"] = Field("string") | 
			
		
	
		
		
			
				
					
					|  |  |  |     status: TaskStatus = Field(default="pending") |  |  |  |     status: TaskStatus = Field(default="pending") | 
			
		
	
		
		
			
				
					
					|  |  |  |     priority: TaskPriority = Field(default="medium") |  |  |  |     priority: TaskPriority = Field(default="medium") | 
			
		
	
	
		
		
			
				
					|  |  | @ -56,20 +88,19 @@ class Task(BaseModel): | 
			
		
	
		
		
			
				
					
					|  |  |  |     retry_count: int = Field(default=0) |  |  |  |     retry_count: int = Field(default=0) | 
			
		
	
		
		
			
				
					
					|  |  |  |     metadata: Dict[str, Any] = Field(default_factory=dict) |  |  |  |     metadata: Dict[str, Any] = Field(default_factory=dict) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     @validator('task_id') |  |  |  |     @validator("task_id") | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     def validate_task_id(cls, v): |  |  |  |     def validate_task_id(cls, v): | 
			
		
	
		
		
			
				
					
					|  |  |  |         if not v.strip(): |  |  |  |         if not v.strip(): | 
			
		
	
		
		
			
				
					
					|  |  |  |             raise ValueError("task_id cannot be empty") |  |  |  |             raise ValueError("task_id cannot be empty") | 
			
		
	
		
		
			
				
					
					|  |  |  |         return v |  |  |  |         return v | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     class Config: |  |  |  |     class Config: | 
			
		
	
		
		
			
				
					
					|  |  |  |         json_encoders = { |  |  |  |         json_encoders = {datetime: lambda v: v.isoformat()} | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             datetime: lambda v: v.isoformat() |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |         } |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | class TaskResult(BaseModel): |  |  |  | class TaskResult(BaseModel): | 
			
		
	
		
		
			
				
					
					|  |  |  |     """Model for task execution results""" |  |  |  |     """Model for task execution results""" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     task_id: str |  |  |  |     task_id: str | 
			
		
	
		
		
			
				
					
					|  |  |  |     status: TaskStatus |  |  |  |     status: TaskStatus | 
			
		
	
		
		
			
				
					
					|  |  |  |     result: Any |  |  |  |     result: Any | 
			
		
	
	
		
		
			
				
					|  |  | @ -121,14 +152,22 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.task_timeout = task_timeout |  |  |  |         self.task_timeout = task_timeout | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         # Initialize encryption |  |  |  |         # Initialize encryption | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.cipher_suite = Fernet(security_config.encryption_key.encode()) |  |  |  |         self.cipher_suite = Fernet( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             security_config.encryption_key.encode() | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         # Setup metrics server |  |  |  |         # Setup metrics server | 
			
		
	
		
		
			
				
					
					|  |  |  |         start_http_server(metrics_port) |  |  |  |         start_http_server(metrics_port) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         # Initialize Pulsar client with security settings |  |  |  |         # Initialize Pulsar client with security settings | 
			
		
	
		
		
			
				
					
					|  |  |  |         client_config = { |  |  |  |         client_config = { | 
			
		
	
		
		
			
				
					
					|  |  |  |             "authentication": None if not security_config.auth_token else pulsar.AuthenticationToken(security_config.auth_token), |  |  |  |             "authentication": ( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 None | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 if not security_config.auth_token | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 else pulsar.AuthenticationToken( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     security_config.auth_token | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             ), | 
			
		
	
		
		
			
				
					
					|  |  |  |             "operation_timeout_seconds": 30, |  |  |  |             "operation_timeout_seconds": 30, | 
			
		
	
		
		
			
				
					
					|  |  |  |             "connection_timeout_seconds": 30, |  |  |  |             "connection_timeout_seconds": 30, | 
			
		
	
		
		
			
				
					
					|  |  |  |             "use_tls": bool(security_config.tls_cert_path), |  |  |  |             "use_tls": bool(security_config.tls_cert_path), | 
			
		
	
	
		
		
			
				
					|  |  | @ -145,7 +184,9 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.last_execution_time = time.time() |  |  |  |         self.last_execution_time = time.time() | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.execution_count = 0 |  |  |  |         self.execution_count = 0 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         logger.info(f"Secure Pulsar Swarm '{self.name}' initialized with enhanced security features") |  |  |  |         logger.info( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             f"Secure Pulsar Swarm '{self.name}' initialized with enhanced security features" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     def _create_producer(self): |  |  |  |     def _create_producer(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |         """Create a secure producer with retry logic""" |  |  |  |         """Create a secure producer with retry logic""" | 
			
		
	
	
		
		
			
				
					|  |  | @ -155,7 +196,7 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |             compression_type=pulsar.CompressionType.LZ4, |  |  |  |             compression_type=pulsar.CompressionType.LZ4, | 
			
		
	
		
		
			
				
					
					|  |  |  |             block_if_queue_full=True, |  |  |  |             block_if_queue_full=True, | 
			
		
	
		
		
			
				
					
					|  |  |  |             batching_enabled=True, |  |  |  |             batching_enabled=True, | 
			
		
	
		
		
			
				
					
					|  |  |  |             batching_max_publish_delay_ms=10 |  |  |  |             batching_max_publish_delay_ms=10, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         ) |  |  |  |         ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     def _create_consumer(self): |  |  |  |     def _create_consumer(self): | 
			
		
	
	
		
		
			
				
					|  |  | @ -166,7 +207,7 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |             consumer_type=pulsar.ConsumerType.Shared, |  |  |  |             consumer_type=pulsar.ConsumerType.Shared, | 
			
		
	
		
		
			
				
					
					|  |  |  |             message_listener=None, |  |  |  |             message_listener=None, | 
			
		
	
		
		
			
				
					
					|  |  |  |             receiver_queue_size=1000, |  |  |  |             receiver_queue_size=1000, | 
			
		
	
		
		
			
				
					
					|  |  |  |             max_total_receiver_queue_size_across_partitions=50000 |  |  |  |             max_total_receiver_queue_size_across_partitions=50000, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         ) |  |  |  |         ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     def _encrypt_message(self, data: str) -> bytes: |  |  |  |     def _encrypt_message(self, data: str) -> bytes: | 
			
		
	
	
		
		
			
				
					|  |  | @ -177,14 +218,19 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |         """Decrypt message data""" |  |  |  |         """Decrypt message data""" | 
			
		
	
		
		
			
				
					
					|  |  |  |         return self.cipher_suite.decrypt(data).decode() |  |  |  |         return self.cipher_suite.decrypt(data).decode() | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     @retry(stop=stop_after_attempt(3), wait=wait_exponential(multiplier=1, min=4, max=10)) |  |  |  |     @retry( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         stop=stop_after_attempt(3), | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         wait=wait_exponential(multiplier=1, min=4, max=10), | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |     def publish_task(self, task: Task) -> None: |  |  |  |     def publish_task(self, task: Task) -> None: | 
			
		
	
		
		
			
				
					
					|  |  |  |         """Publish a task with enhanced security and reliability""" |  |  |  |         """Publish a task with enhanced security and reliability""" | 
			
		
	
		
		
			
				
					
					|  |  |  |         try: |  |  |  |         try: | 
			
		
	
		
		
			
				
					
					|  |  |  |             # Validate message size |  |  |  |             # Validate message size | 
			
		
	
		
		
			
				
					
					|  |  |  |             task_data = task.json() |  |  |  |             task_data = task.json() | 
			
		
	
		
		
			
				
					
					|  |  |  |             if len(task_data) > self.security_config.max_message_size: |  |  |  |             if len(task_data) > self.security_config.max_message_size: | 
			
		
	
		
		
			
				
					
					|  |  |  |                 raise ValueError("Task data exceeds maximum message size") |  |  |  |                 raise ValueError( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     "Task data exceeds maximum message size" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |             # Rate limiting |  |  |  |             # Rate limiting | 
			
		
	
		
		
			
				
					
					|  |  |  |             current_time = time.time() |  |  |  |             current_time = time.time() | 
			
		
	
	
		
		
			
				
					|  |  | @ -192,7 +238,10 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |                 self.execution_count = 0 |  |  |  |                 self.execution_count = 0 | 
			
		
	
		
		
			
				
					
					|  |  |  |                 self.last_execution_time = current_time |  |  |  |                 self.last_execution_time = current_time | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |             if self.execution_count >= self.security_config.rate_limit: |  |  |  |             if ( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 self.execution_count | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 >= self.security_config.rate_limit | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             ): | 
			
		
	
		
		
			
				
					
					|  |  |  |                 raise ValueError("Rate limit exceeded") |  |  |  |                 raise ValueError("Rate limit exceeded") | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |             # Encrypt and publish |  |  |  |             # Encrypt and publish | 
			
		
	
	
		
		
			
				
					|  |  | @ -200,11 +249,15 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |             message_id = self.producer.send(encrypted_data) |  |  |  |             message_id = self.producer.send(encrypted_data) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |             self.execution_count += 1 |  |  |  |             self.execution_count += 1 | 
			
		
	
		
		
			
				
					
					|  |  |  |             logger.info(f"Task {task.task_id} published successfully with message ID {message_id}") |  |  |  |             logger.info( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 f"Task {task.task_id} published successfully with message ID {message_id}" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         except Exception as e: |  |  |  |         except Exception as e: | 
			
		
	
		
		
			
				
					
					|  |  |  |             TASK_FAILURES.inc() |  |  |  |             TASK_FAILURES.inc() | 
			
		
	
		
		
			
				
					
					|  |  |  |             logger.error(f"Error publishing task {task.task_id}: {str(e)}") |  |  |  |             logger.error( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 f"Error publishing task {task.task_id}: {str(e)}" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             ) | 
			
		
	
		
		
			
				
					
					|  |  |  |             raise |  |  |  |             raise | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     async def _process_task(self, task: Task) -> TaskResult: |  |  |  |     async def _process_task(self, task: Task) -> TaskResult: | 
			
		
	
	
		
		
			
				
					|  |  | @ -219,7 +272,9 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |                 self.agents.append(agent) |  |  |  |                 self.agents.append(agent) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |                 # Execute task with timeout |  |  |  |                 # Execute task with timeout | 
			
		
	
		
		
			
				
					
					|  |  |  |                 future = self.executor.submit(agent.run, task.description) |  |  |  |                 future = self.executor.submit( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     agent.run, task.description | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 ) | 
			
		
	
		
		
			
				
					
					|  |  |  |                 result = future.result(timeout=self.task_timeout) |  |  |  |                 result = future.result(timeout=self.task_timeout) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |                 # Handle different output types |  |  |  |                 # Handle different output types | 
			
		
	
	
		
		
			
				
					|  |  | @ -239,8 +294,9 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |                     task_id=task.task_id, |  |  |  |                     task_id=task.task_id, | 
			
		
	
		
		
			
				
					
					|  |  |  |                     status="completed", |  |  |  |                     status="completed", | 
			
		
	
		
		
			
				
					
					|  |  |  |                     result=result, |  |  |  |                     result=result, | 
			
		
	
		
		
			
				
					
					|  |  |  |                     execution_time=time.time() - task.started_at.timestamp(), |  |  |  |                     execution_time=time.time() | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                     agent_id=agent.agent_name |  |  |  |                     - task.started_at.timestamp(), | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     agent_id=agent.agent_name, | 
			
		
	
		
		
			
				
					
					|  |  |  |                 ) |  |  |  |                 ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |             except TimeoutError: |  |  |  |             except TimeoutError: | 
			
		
	
	
		
		
			
				
					|  |  | @ -253,14 +309,17 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |                     status="failed", |  |  |  |                     status="failed", | 
			
		
	
		
		
			
				
					
					|  |  |  |                     result=None, |  |  |  |                     result=None, | 
			
		
	
		
		
			
				
					
					|  |  |  |                     error_message=error_msg, |  |  |  |                     error_message=error_msg, | 
			
		
	
		
		
			
				
					
					|  |  |  |                     execution_time=time.time() - task.started_at.timestamp(), |  |  |  |                     execution_time=time.time() | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                     agent_id=agent.agent_name |  |  |  |                     - task.started_at.timestamp(), | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     agent_id=agent.agent_name, | 
			
		
	
		
		
			
				
					
					|  |  |  |                 ) |  |  |  |                 ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |             except Exception as e: |  |  |  |             except Exception as e: | 
			
		
	
		
		
			
				
					
					|  |  |  |                 TASK_FAILURES.inc() |  |  |  |                 TASK_FAILURES.inc() | 
			
		
	
		
		
			
				
					
					|  |  |  |                 AGENT_ERRORS.inc() |  |  |  |                 AGENT_ERRORS.inc() | 
			
		
	
		
		
			
				
					
					|  |  |  |                 error_msg = f"Error processing task {task.task_id}: {str(e)}" |  |  |  |                 error_msg = ( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     f"Error processing task {task.task_id}: {str(e)}" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 ) | 
			
		
	
		
		
			
				
					
					|  |  |  |                 logger.error(error_msg) |  |  |  |                 logger.error(error_msg) | 
			
		
	
		
		
			
				
					
					|  |  |  |                 task.status = "failed" |  |  |  |                 task.status = "failed" | 
			
		
	
		
		
			
				
					
					|  |  |  |                 return TaskResult( |  |  |  |                 return TaskResult( | 
			
		
	
	
		
		
			
				
					|  |  | @ -268,8 +327,9 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |                     status="failed", |  |  |  |                     status="failed", | 
			
		
	
		
		
			
				
					
					|  |  |  |                     result=None, |  |  |  |                     result=None, | 
			
		
	
		
		
			
				
					
					|  |  |  |                     error_message=error_msg, |  |  |  |                     error_message=error_msg, | 
			
		
	
		
		
			
				
					
					|  |  |  |                     execution_time=time.time() - task.started_at.timestamp(), |  |  |  |                     execution_time=time.time() | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                     agent_id=agent.agent_name |  |  |  |                     - task.started_at.timestamp(), | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     agent_id=agent.agent_name, | 
			
		
	
		
		
			
				
					
					|  |  |  |                 ) |  |  |  |                 ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     async def consume_tasks(self): |  |  |  |     async def consume_tasks(self): | 
			
		
	
	
		
		
			
				
					|  |  | @ -281,7 +341,9 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |             try: |  |  |  |             try: | 
			
		
	
		
		
			
				
					
					|  |  |  |                 # Circuit breaker pattern |  |  |  |                 # Circuit breaker pattern | 
			
		
	
		
		
			
				
					
					|  |  |  |                 if consecutive_failures >= 5: |  |  |  |                 if consecutive_failures >= 5: | 
			
		
	
		
		
			
				
					
					|  |  |  |                     logger.warning(f"Circuit breaker triggered. Waiting {backoff_time} seconds") |  |  |  |                     logger.warning( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                         f"Circuit breaker triggered. Waiting {backoff_time} seconds" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     await asyncio.sleep(backoff_time) |  |  |  |                     await asyncio.sleep(backoff_time) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     backoff_time = min(backoff_time * 2, 60) |  |  |  |                     backoff_time = min(backoff_time * 2, 60) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     continue |  |  |  |                     continue | 
			
		
	
	
		
		
			
				
					|  |  | @ -291,7 +353,9 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |                 try: |  |  |  |                 try: | 
			
		
	
		
		
			
				
					
					|  |  |  |                     # Decrypt and process message |  |  |  |                     # Decrypt and process message | 
			
		
	
		
		
			
				
					
					|  |  |  |                     decrypted_data = self._decrypt_message(message.data()) |  |  |  |                     decrypted_data = self._decrypt_message( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                         message.data() | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     task_data = json.loads(decrypted_data) |  |  |  |                     task_data = json.loads(decrypted_data) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     task = Task(**task_data) |  |  |  |                     task = Task(**task_data) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -306,13 +370,21 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |                     else: |  |  |  |                     else: | 
			
		
	
		
		
			
				
					
					|  |  |  |                         if task.retry_count < self.retry_attempts: |  |  |  |                         if task.retry_count < self.retry_attempts: | 
			
		
	
		
		
			
				
					
					|  |  |  |                             task.retry_count += 1 |  |  |  |                             task.retry_count += 1 | 
			
		
	
		
		
			
				
					
					|  |  |  |                             await self.consumer.negative_acknowledge(message) |  |  |  |                             await self.consumer.negative_acknowledge( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                                 message | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                             ) | 
			
		
	
		
		
			
				
					
					|  |  |  |                         else: |  |  |  |                         else: | 
			
		
	
		
		
			
				
					
					|  |  |  |                             await self.consumer.acknowledge_async(message) |  |  |  |                             await self.consumer.acknowledge_async( | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                             logger.error(f"Task {task.task_id} failed after {self.retry_attempts} attempts") |  |  |  |                                 message | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                             ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                             logger.error( | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                                 f"Task {task.task_id} failed after {self.retry_attempts} attempts" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                             ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |                 except Exception as e: |  |  |  |                 except Exception as e: | 
			
		
	
		
		
			
				
					
					|  |  |  |                     logger.error(f"Error processing message: {str(e)}") |  |  |  |                     logger.error( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                         f"Error processing message: {str(e)}" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                     ) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     await self.consumer.negative_acknowledge(message) |  |  |  |                     await self.consumer.negative_acknowledge(message) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     consecutive_failures += 1 |  |  |  |                     consecutive_failures += 1 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -336,6 +408,7 @@ class SecurePulsarSwarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |         except Exception as e: |  |  |  |         except Exception as e: | 
			
		
	
		
		
			
				
					
					|  |  |  |             logger.error(f"Error during cleanup: {str(e)}") |  |  |  |             logger.error(f"Error during cleanup: {str(e)}") | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | if __name__ == "__main__": |  |  |  | if __name__ == "__main__": | 
			
		
	
		
		
			
				
					
					|  |  |  |     # Example usage with security configuration |  |  |  |     # Example usage with security configuration | 
			
		
	
		
		
			
				
					
					|  |  |  |     security_config = SecurityConfig( |  |  |  |     security_config = SecurityConfig( | 
			
		
	
	
		
		
			
				
					|  |  | @ -344,7 +417,7 @@ if __name__ == "__main__": | 
			
		
	
		
		
			
				
					
					|  |  |  |         tls_key_path="/path/to/key.pem", |  |  |  |         tls_key_path="/path/to/key.pem", | 
			
		
	
		
		
			
				
					
					|  |  |  |         auth_token="your-auth-token", |  |  |  |         auth_token="your-auth-token", | 
			
		
	
		
		
			
				
					
					|  |  |  |         max_message_size=1048576, |  |  |  |         max_message_size=1048576, | 
			
		
	
		
		
			
				
					
					|  |  |  |         rate_limit=100 |  |  |  |         rate_limit=100, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     ) |  |  |  |     ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     # Agent factory function |  |  |  |     # Agent factory function | 
			
		
	
	
		
		
			
				
					|  |  | @ -383,7 +456,7 @@ if __name__ == "__main__": | 
			
		
	
		
		
			
				
					
					|  |  |  |         max_workers=5, |  |  |  |         max_workers=5, | 
			
		
	
		
		
			
				
					
					|  |  |  |         retry_attempts=3, |  |  |  |         retry_attempts=3, | 
			
		
	
		
		
			
				
					
					|  |  |  |         task_timeout=300, |  |  |  |         task_timeout=300, | 
			
		
	
		
		
			
				
					
					|  |  |  |         metrics_port=8000 |  |  |  |         metrics_port=8000, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     ) as swarm: |  |  |  |     ) as swarm: | 
			
		
	
		
		
			
				
					
					|  |  |  |         # Example task |  |  |  |         # Example task | 
			
		
	
		
		
			
				
					
					|  |  |  |         task = Task( |  |  |  |         task = Task( | 
			
		
	
	
		
		
			
				
					|  |  | @ -391,7 +464,10 @@ if __name__ == "__main__": | 
			
		
	
		
		
			
				
					
					|  |  |  |             description="Analyze Q4 financial reports", |  |  |  |             description="Analyze Q4 financial reports", | 
			
		
	
		
		
			
				
					
					|  |  |  |             output_type="json", |  |  |  |             output_type="json", | 
			
		
	
		
		
			
				
					
					|  |  |  |             priority="high", |  |  |  |             priority="high", | 
			
		
	
		
		
			
				
					
					|  |  |  |             metadata={"department": "finance", "requester": "john.doe@company.com"} |  |  |  |             metadata={ | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 "department": "finance", | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 "requester": "john.doe@company.com", | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             }, | 
			
		
	
		
		
			
				
					
					|  |  |  |         ) |  |  |  |         ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         # Run the swarm |  |  |  |         # Run the swarm | 
			
		
	
	
		
		
			
				
					|  |  | 
 |