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.
69 lines
2.5 KiB
Python
69 lines
2.5 KiB
Python
#!/usr/bin/env python3
|
|
"""
|
|
Production launcher for AITBC blockchain node.
|
|
Sets up environment, initializes genesis if needed, and starts the node.
|
|
"""
|
|
|
|
from __future__ import annotations
|
|
|
|
import os
|
|
import sys
|
|
import subprocess
|
|
from pathlib import Path
|
|
|
|
# Configuration
|
|
CHAIN_ID = "ait-mainnet"
|
|
DATA_DIR = Path("/var/lib/aitbc/data/ait-mainnet")
|
|
DB_PATH = DATA_DIR / "chain.db"
|
|
KEYS_DIR = Path("/var/lib/aitbc/keystore")
|
|
|
|
# Check for proposer key in keystore
|
|
PROPOSER_KEY_FILE = KEYS_DIR / "aitbc1genesis.json"
|
|
if not PROPOSER_KEY_FILE.exists():
|
|
print(f"[!] Proposer keystore not found at {PROPOSER_KEY_FILE}")
|
|
print(" Run scripts/keystore.py to generate it first.")
|
|
sys.exit(1)
|
|
|
|
# Set environment variables
|
|
os.environ["CHAIN_ID"] = CHAIN_ID
|
|
os.environ["SUPPORTED_CHAINS"] = CHAIN_ID
|
|
os.environ["DB_PATH"] = str(DB_PATH)
|
|
os.environ["PROPOSER_ID"] = "aitbc1genesis"
|
|
# PROPOSER_KEY will be read from keystore by the node? Currently .env expects hex directly.
|
|
# We can read the keystore, decrypt, and set PROPOSER_KEY, but the node doesn't support that out of box.
|
|
# So we require that PROPOSER_KEY is set in .env file manually after key generation.
|
|
# This script will check for PROPOSER_KEY env var or fail with instructions.
|
|
if not os.getenv("PROPOSER_KEY"):
|
|
print("[!] PROPOSER_KEY environment variable not set.")
|
|
print(" Please edit /opt/aitbc/apps/blockchain-node/.env and set PROPOSER_KEY to the hex private key of aitbc1genesis.")
|
|
sys.exit(1)
|
|
|
|
# Ensure data directory
|
|
DATA_DIR.mkdir(parents=True, exist_ok=True)
|
|
|
|
# Optionally initialize genesis if DB doesn't exist
|
|
if not DB_PATH.exists():
|
|
print("[*] Database not found. Initializing production genesis...")
|
|
result = subprocess.run([
|
|
sys.executable,
|
|
"/opt/aitbc/scripts/init_production_genesis.py",
|
|
"--chain-id", CHAIN_ID,
|
|
"--db-path", str(DB_PATH)
|
|
], check=False)
|
|
if result.returncode != 0:
|
|
print("[!] Genesis initialization failed. Aborting.")
|
|
sys.exit(1)
|
|
|
|
# Start the node
|
|
print(f"[*] Starting blockchain node for chain {CHAIN_ID}...")
|
|
# Change to the blockchain-node directory (since .env and uvicorn expect relative paths)
|
|
os.chdir("/opt/aitbc/apps/blockchain-node")
|
|
# Use the virtualenv Python
|
|
venv_python = Path("/opt/aitbc/apps/blockchain-node/.venv/bin/python")
|
|
if not venv_python.exists():
|
|
print(f"[!] Virtualenv not found at {venv_python}")
|
|
sys.exit(1)
|
|
|
|
# Exec uvicorn
|
|
os.execv(str(venv_python), [str(venv_python), "-m", "uvicorn", "aitbc_chain.app:app", "--host", "127.0.0.1", "--port", "8006"])
|