All checks were successful
AITBC CLI Level 1 Commands Test / test-cli-level1 (push) Successful in 16s
api-endpoint-tests / test-api-endpoints (push) Successful in 35s
integration-tests / test-service-integration (push) Successful in 1m25s
package-tests / test-python-packages (map[name:aitbc-agent-sdk path:packages/py/aitbc-agent-sdk python_version:3.13]) (push) Successful in 16s
package-tests / test-python-packages (map[name:aitbc-cli path:. python_version:3.13]) (push) Successful in 14s
package-tests / test-python-packages (map[name:aitbc-core path:packages/py/aitbc-core python_version:3.13]) (push) Successful in 13s
package-tests / test-python-packages (map[name:aitbc-crypto path:packages/py/aitbc-crypto python_version:3.13]) (push) Successful in 10s
package-tests / test-python-packages (map[name:aitbc-sdk path:packages/py/aitbc-sdk python_version:3.13]) (push) Successful in 12s
package-tests / test-javascript-packages (map[name:aitbc-sdk node_version:24 path:packages/js/aitbc-sdk]) (push) Successful in 18s
python-tests / test-specific (push) Has been skipped
security-scanning / audit (push) Successful in 14s
systemd-sync / sync-systemd (push) Successful in 4s
package-tests / cross-language-compatibility (push) Successful in 2s
package-tests / package-integration-tests (push) Successful in 3s
Documentation Validation / validate-docs (push) Successful in 6m13s
python-tests / test (push) Successful in 14s
## 🚀 Central Virtual Environment Implementation - Created central venv at /opt/aitbc/venv for all services - Updated 34+ systemd services to use central python interpreter - Fixed PYTHONPATH configurations for proper module imports - Created aitbc-env wrapper script for environment management ## 📦 Requirements Management Overhaul - Consolidated 8 separate requirements.txt files into central requirements.txt - Added web3>=6.11.0 for blockchain functionality - Created automated requirements migrator tool (scripts/requirements_migrator.py) - Established modular requirements structure (requirements-modules/) - Generated comprehensive migration reports and documentation ## 🔧 Service Configuration Fixes - Fixed Adaptive Learning service domain imports (AgentStatus) - Resolved logging conflicts in zk_proofs and adaptive_learning_health - Created missing data modules (consumer_gpu_profiles.py) - Updated CLI to version 0.2.2 with proper import handling - Fixed infinite loop in CLI alias configuration ## 📡 Port Mapping and Service Updates - Updated blockchain node port from 8545 to 8005 - Added Adaptive Learning service on port 8010 - Consolidated P2P/sync into blockchain-node service - All 5 core services now operational and responding ## 📚 Documentation Enhancements - Updated SYSTEMD_SERVICES.md for Debian root usage (no sudo) - Added comprehensive VIRTUAL_ENVIRONMENT.md guide - Created REQUIREMENTS_MERGE_SUMMARY.md with migration details - Updated RUNTIME_DIRECTORIES.md for standard Linux paths - Fixed service port mappings and dependencies ## 🛠️ CLI Improvements - Fixed import errors and version display (0.2.2) - Resolved infinite loop in bashrc alias - Added proper error handling for missing command modules - Created aitbc-cli wrapper for clean execution ## ✅ Operational Status - 5/5 AITBC services running successfully - All health checks passing - Central virtual environment fully functional - Requirements management streamlined - Documentation accurate and up-to-date ## 🎯 Technical Achievements - Eliminated 7 redundant requirements.txt files - Reduced service startup failures from 34+ to 0 - Established modular dependency management - Created reusable migration tooling - Standardized Debian root deployment practices This represents a complete infrastructure modernization with improved reliability, maintainability, and operational efficiency.
114 lines
3.6 KiB
Python
114 lines
3.6 KiB
Python
"""
|
|
Message Protocol for AITBC Agents
|
|
Handles message creation, routing, and delivery between agents
|
|
"""
|
|
|
|
import json
|
|
import uuid
|
|
from datetime import datetime
|
|
from typing import Dict, Any, Optional, List
|
|
from enum import Enum
|
|
|
|
class MessageTypes(Enum):
|
|
"""Message type enumeration"""
|
|
TASK_REQUEST = "task_request"
|
|
TASK_RESPONSE = "task_response"
|
|
HEARTBEAT = "heartbeat"
|
|
STATUS_UPDATE = "status_update"
|
|
ERROR = "error"
|
|
DATA = "data"
|
|
|
|
class MessageProtocol:
|
|
"""Message protocol handler for agent communication"""
|
|
|
|
def __init__(self):
|
|
self.messages = []
|
|
self.message_handlers = {}
|
|
|
|
def create_message(
|
|
self,
|
|
sender_id: str,
|
|
receiver_id: str,
|
|
message_type: MessageTypes,
|
|
content: Dict[str, Any],
|
|
message_id: Optional[str] = None
|
|
) -> Dict[str, Any]:
|
|
"""Create a new message"""
|
|
if message_id is None:
|
|
message_id = str(uuid.uuid4())
|
|
|
|
message = {
|
|
"message_id": message_id,
|
|
"sender_id": sender_id,
|
|
"receiver_id": receiver_id,
|
|
"message_type": message_type.value,
|
|
"content": content,
|
|
"timestamp": datetime.utcnow().isoformat(),
|
|
"status": "pending"
|
|
}
|
|
|
|
self.messages.append(message)
|
|
return message
|
|
|
|
def send_message(self, message: Dict[str, Any]) -> bool:
|
|
"""Send a message to the receiver"""
|
|
try:
|
|
message["status"] = "sent"
|
|
message["sent_timestamp"] = datetime.utcnow().isoformat()
|
|
return True
|
|
except Exception:
|
|
message["status"] = "failed"
|
|
return False
|
|
|
|
def receive_message(self, message_id: str) -> Optional[Dict[str, Any]]:
|
|
"""Receive and process a message"""
|
|
for message in self.messages:
|
|
if message["message_id"] == message_id:
|
|
message["status"] = "received"
|
|
message["received_timestamp"] = datetime.utcnow().isoformat()
|
|
return message
|
|
return None
|
|
|
|
def get_messages_by_agent(self, agent_id: str) -> List[Dict[str, Any]]:
|
|
"""Get all messages for a specific agent"""
|
|
return [
|
|
msg for msg in self.messages
|
|
if msg["sender_id"] == agent_id or msg["receiver_id"] == agent_id
|
|
]
|
|
|
|
class AgentMessageClient:
|
|
"""Client for agent message communication"""
|
|
|
|
def __init__(self, agent_id: str, protocol: MessageProtocol):
|
|
self.agent_id = agent_id
|
|
self.protocol = protocol
|
|
self.received_messages = []
|
|
|
|
def send_message(
|
|
self,
|
|
receiver_id: str,
|
|
message_type: MessageTypes,
|
|
content: Dict[str, Any]
|
|
) -> Dict[str, Any]:
|
|
"""Send a message to another agent"""
|
|
message = self.protocol.create_message(
|
|
sender_id=self.agent_id,
|
|
receiver_id=receiver_id,
|
|
message_type=message_type,
|
|
content=content
|
|
)
|
|
self.protocol.send_message(message)
|
|
return message
|
|
|
|
def receive_messages(self) -> List[Dict[str, Any]]:
|
|
"""Receive all pending messages for this agent"""
|
|
messages = []
|
|
for message in self.protocol.messages:
|
|
if (message["receiver_id"] == self.agent_id and
|
|
message["status"] == "sent" and
|
|
message not in self.received_messages):
|
|
self.protocol.receive_message(message["message_id"])
|
|
self.received_messages.append(message)
|
|
messages.append(message)
|
|
return messages
|