Add Oracle Aggregator and CCIP Integration
- Introduced Aggregator.sol for Chainlink-compatible oracle functionality, including round-based updates and access control. - Added OracleWithCCIP.sol to extend Aggregator with CCIP cross-chain messaging capabilities. - Created .gitmodules to include OpenZeppelin contracts as a submodule. - Developed a comprehensive deployment guide in NEXT_STEPS_COMPLETE_GUIDE.md for Phase 2 and smart contract deployment. - Implemented Vite configuration for the orchestration portal, supporting both Vue and React frameworks. - Added server-side logic for the Multi-Cloud Orchestration Portal, including API endpoints for environment management and monitoring. - Created scripts for resource import and usage validation across non-US regions. - Added tests for CCIP error handling and integration to ensure robust functionality. - Included various new files and directories for the orchestration portal and deployment scripts.
This commit is contained in:
77
scripts/security/verify-resource-limits.sh
Executable file
77
scripts/security/verify-resource-limits.sh
Executable file
@@ -0,0 +1,77 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -e
|
||||
|
||||
# Verify all containers have resource limits
|
||||
# This script checks all Kubernetes manifests for resource limits
|
||||
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
source "$SCRIPT_DIR/../lib/init.sh"
|
||||
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
||||
|
||||
|
||||
log_success "Verifying resource limits in all Kubernetes manifests..."
|
||||
|
||||
ERRORS=0
|
||||
WARNINGS=0
|
||||
|
||||
# Find all YAML files
|
||||
YAML_FILES=$(find "$PROJECT_ROOT/k8s" "$PROJECT_ROOT/helm" "$PROJECT_ROOT/monitoring/k8s" -name "*.yaml" -o -name "*.yml" 2>/dev/null)
|
||||
|
||||
for file in $YAML_FILES; do
|
||||
# Skip if file doesn't exist or is not a regular file
|
||||
[ ! -f "$file" ] && continue
|
||||
|
||||
# Check if file contains containers
|
||||
if grep -q "containers:" "$file" || grep -q "initContainers:" "$file"; then
|
||||
# Extract container names
|
||||
CONTAINERS=$(grep -A 5 "containers:" "$file" | grep "name:" | awk '{print $2}' | tr -d '"' || true)
|
||||
INIT_CONTAINERS=$(grep -A 5 "initContainers:" "$file" | grep "name:" | awk '{print $2}' | tr -d '"' || true)
|
||||
|
||||
ALL_CONTAINERS="$CONTAINERS $INIT_CONTAINERS"
|
||||
|
||||
for container in $ALL_CONTAINERS; do
|
||||
if [ -z "$container" ]; then
|
||||
continue
|
||||
fi
|
||||
|
||||
# Check if container has resources section
|
||||
if ! grep -A 20 "name:.*$container" "$file" | grep -q "resources:"; then
|
||||
log_error "✗ $file: Container '$container' missing resources"
|
||||
ERRORS=$((ERRORS + 1))
|
||||
else
|
||||
# Check for limits
|
||||
if ! grep -A 20 "name:.*$container" "$file" | grep -A 10 "resources:" | grep -q "limits:"; then
|
||||
log_warn "⚠ $file: Container '$container' missing limits"
|
||||
WARNINGS=$((WARNINGS + 1))
|
||||
else
|
||||
# Check for requests
|
||||
if ! grep -A 20 "name:.*$container" "$file" | grep -A 10 "resources:" | grep -q "requests:"; then
|
||||
log_warn "⚠ $file: Container '$container' missing requests"
|
||||
WARNINGS=$((WARNINGS + 1))
|
||||
else
|
||||
log_success "✓ $file: Container '$container' has resources"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
done
|
||||
fi
|
||||
done
|
||||
|
||||
log_success "Verification complete"
|
||||
echo -e "Errors: $ERRORS"
|
||||
echo -e "Warnings: $WARNINGS"
|
||||
|
||||
if [ $ERRORS -gt 0 ]; then
|
||||
log_error "Some containers are missing resource limits!"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ $WARNINGS -gt 0 ]; then
|
||||
log_warn "Some containers are missing resource requests"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
log_success "All containers have proper resource limits and requests!"
|
||||
exit 0
|
||||
|
||||
Reference in New Issue
Block a user