Some checks failed
CLI Tests / test-cli (push) Failing after 4s
Deploy to Testnet / deploy-testnet (push) Successful in 1m40s
Documentation Validation / validate-docs (push) Failing after 12s
Documentation Validation / validate-policies-strict (push) Successful in 4s
Integration Tests / test-service-integration (push) Successful in 2m42s
Package Tests / Python package - aitbc-agent-sdk (push) Failing after 34s
Package Tests / Python package - aitbc-core (push) Successful in 27s
Package Tests / Python package - aitbc-crypto (push) Successful in 13s
Package Tests / Python package - aitbc-sdk (push) Successful in 16s
Package Tests / JavaScript package - aitbc-sdk-js (push) Successful in 8s
Package Tests / JavaScript package - aitbc-token (push) Successful in 18s
Python Tests / test-python (push) Failing after 50s
Security Scanning / security-scan (push) Failing after 43s
Multi-Node Stress Testing / stress-test (push) Successful in 12s
Cross-Node Transaction Testing / transaction-test (push) Successful in 9s
- Created aitbc/_version.py with centralized version definition - Updated aitbc/__init__.py to import __version__ from _version module - Updated constants.py to use __version__ for PACKAGE_VERSION - Replaced print() calls with logger in decorators.py, events.py, queue_manager.py, and state.py - Added logger initialization using get_logger(__name__) in config.py, decorators.py, events.py, queue_manager.py, and state.py - Added cli/commands
93 lines
3.3 KiB
Python
93 lines
3.3 KiB
Python
"""
|
|
Blockchain utility functions for AITBC CLI
|
|
"""
|
|
|
|
from typing import Optional, Dict
|
|
|
|
from aitbc import AITBCHTTPClient, NetworkError
|
|
|
|
|
|
def get_chain_info(rpc_url: str = "http://localhost:8006") -> Optional[Dict]:
|
|
"""Get blockchain information"""
|
|
try:
|
|
result = {}
|
|
# Get chain metadata from health endpoint
|
|
http_client = AITBCHTTPClient(base_url=rpc_url, timeout=30)
|
|
health = http_client.get("/health")
|
|
chains = health.get('supported_chains', [])
|
|
result['chain_id'] = chains[0] if chains else 'ait-mainnet'
|
|
result['supported_chains'] = ', '.join(chains) if chains else 'ait-mainnet'
|
|
result['proposer_id'] = health.get('proposer_id', '')
|
|
# Get head block for height
|
|
head = http_client.get("/rpc/head")
|
|
result['height'] = head.get('height', 0)
|
|
result['hash'] = head.get('hash', "")
|
|
result['timestamp'] = head.get('timestamp', 'N/A')
|
|
result['tx_count'] = head.get('tx_count', 0)
|
|
return result if result else None
|
|
except NetworkError as e:
|
|
print(f"Error: {e}")
|
|
return None
|
|
except Exception as e:
|
|
print(f"Error: {e}")
|
|
return None
|
|
|
|
|
|
def get_network_status(rpc_url: str = "http://localhost:8006") -> Optional[Dict]:
|
|
"""Get network status and health"""
|
|
try:
|
|
# Get head block
|
|
http_client = AITBCHTTPClient(base_url=rpc_url, timeout=30)
|
|
return http_client.get("/rpc/head")
|
|
except NetworkError as e:
|
|
print(f"Error getting network status: {e}")
|
|
return None
|
|
except Exception as e:
|
|
print(f"Error: {e}")
|
|
return None
|
|
|
|
|
|
def get_blockchain_analytics(analytics_type: str, limit: int = 10, rpc_url: str = "http://localhost:8006") -> Optional[Dict]:
|
|
"""Get blockchain analytics and statistics"""
|
|
try:
|
|
if analytics_type == "blocks":
|
|
# Get recent blocks analytics
|
|
http_client = AITBCHTTPClient(base_url=rpc_url, timeout=30)
|
|
head = http_client.get("/rpc/head")
|
|
return {
|
|
"type": "blocks",
|
|
"current_height": head.get("height", 0),
|
|
"latest_block": head.get("hash", ""),
|
|
"timestamp": head.get("timestamp", ""),
|
|
"tx_count": head.get("tx_count", 0),
|
|
"status": "Active"
|
|
}
|
|
|
|
elif analytics_type == "supply":
|
|
# Get total supply info
|
|
return {
|
|
"type": "supply",
|
|
"total_supply": "1000000000", # From genesis
|
|
"circulating_supply": "999997980", # After transactions
|
|
"genesis_minted": "1000000000",
|
|
"status": "Available"
|
|
}
|
|
|
|
elif analytics_type == "accounts":
|
|
# Account statistics
|
|
return {
|
|
"type": "accounts",
|
|
"total_accounts": 3, # Genesis + treasury + user
|
|
"active_accounts": 2, # Accounts with transactions
|
|
"genesis_accounts": 2, # Genesis and treasury
|
|
"user_accounts": 1,
|
|
"status": "Healthy"
|
|
}
|
|
|
|
else:
|
|
return {"type": analytics_type, "status": "Not implemented yet"}
|
|
|
|
except Exception as e:
|
|
print(f"Error getting analytics: {e}")
|
|
return None
|