Restructured project for V2 refactor: **Structure Changes:** - Moved all V1 code to orig/ folder (preserved with git mv) - Created docs/planning/ directory - Added orig/README_V1.md explaining V1 preservation **Planning Documents:** - 00_V2_MASTER_PLAN.md: Complete architecture overview - Executive summary of critical V1 issues - High-level component architecture diagrams - 5-phase implementation roadmap - Success metrics and risk mitigation - 07_TASK_BREAKDOWN.md: Atomic task breakdown - 99+ hours of detailed tasks - Every task < 2 hours (atomic) - Clear dependencies and success criteria - Organized by implementation phase **V2 Key Improvements:** - Per-exchange parsers (factory pattern) - Multi-layer strict validation - Multi-index pool cache - Background validation pipeline - Comprehensive observability **Critical Issues Addressed:** - Zero address tokens (strict validation + cache enrichment) - Parsing accuracy (protocol-specific parsers) - No audit trail (background validation channel) - Inefficient lookups (multi-index cache) - Stats disconnection (event-driven metrics) Next Steps: 1. Review planning documents 2. Begin Phase 1: Foundation (P1-001 through P1-010) 3. Implement parsers in Phase 2 4. Build cache system in Phase 3 5. Add validation pipeline in Phase 4 6. Migrate and test in Phase 5 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
54 lines
1.7 KiB
Bash
Executable File
54 lines
1.7 KiB
Bash
Executable File
#!/bin/bash
|
|
# Simple webhook receiver for GitHub/GitLab push events
|
|
# This creates a lightweight HTTP server that triggers updates on push
|
|
|
|
PORT="${WEBHOOK_PORT:-9000}"
|
|
SECRET="${WEBHOOK_SECRET:-change-me-in-production}"
|
|
PROJECT_DIR="${PROJECT_DIR:-$(cd "$(dirname "$0")/.." && pwd)}"
|
|
LOG_FILE="${PROJECT_DIR}/logs/webhook.log"
|
|
|
|
mkdir -p "${PROJECT_DIR}/logs"
|
|
|
|
echo "========================================="
|
|
echo "MEV Bot Webhook Receiver"
|
|
echo "========================================="
|
|
echo "Listening on port: $PORT"
|
|
echo "Project: $PROJECT_DIR"
|
|
echo "Log file: $LOG_FILE"
|
|
echo ""
|
|
echo "Configure your GitHub/GitLab webhook to:"
|
|
echo " URL: http://your-server:$PORT/webhook"
|
|
echo " Secret: $SECRET"
|
|
echo " Events: Push events on master branch"
|
|
echo ""
|
|
echo "Press Ctrl+C to stop"
|
|
echo "========================================="
|
|
echo ""
|
|
|
|
# Simple HTTP server using netcat and bash
|
|
while true; do
|
|
# Listen for incoming requests
|
|
RESPONSE=$(echo -e "HTTP/1.1 200 OK\r\nContent-Type: text/plain\r\n\r\nWebhook received" | nc -l -p "$PORT" -q 1)
|
|
|
|
# Log the request
|
|
echo "[$(date)] Webhook received" | tee -a "$LOG_FILE"
|
|
|
|
# Check if it's a valid webhook request (basic check)
|
|
if echo "$RESPONSE" | grep -q "POST /webhook"; then
|
|
echo "[$(date)] Valid webhook request detected" | tee -a "$LOG_FILE"
|
|
|
|
# Trigger auto-update in background
|
|
(
|
|
cd "$PROJECT_DIR"
|
|
./scripts/auto-update.sh >> "$LOG_FILE" 2>&1
|
|
) &
|
|
|
|
echo "[$(date)] Auto-update triggered" | tee -a "$LOG_FILE"
|
|
else
|
|
echo "[$(date)] Invalid request ignored" | tee -a "$LOG_FILE"
|
|
fi
|
|
|
|
# Small delay before listening again
|
|
sleep 1
|
|
done
|