Няма описание

send-wazuh-cisco-test-events.sh 4.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. #!/usr/bin/env bash
  2. set -euo pipefail
  3. SCENARIO="${1:-all}"
  4. COUNT="${2:-1}"
  5. DELAY="${3:-0.3}"
  6. FOREVER="false"
  7. for arg in "${@:4}"; do
  8. case "${arg}" in
  9. --forever)
  10. FOREVER="true"
  11. ;;
  12. *)
  13. echo "error: unexpected argument '${arg}'"
  14. echo "usage: scripts/send-wazuh-cisco-test-events.sh [scenario] [count] [delay_seconds] [--forever]"
  15. exit 1
  16. ;;
  17. esac
  18. done
  19. WAZUH_SYSLOG_HOST="${WAZUH_SYSLOG_HOST:-127.0.0.1}"
  20. WAZUH_SYSLOG_PORT="${WAZUH_SYSLOG_PORT:-514}"
  21. CISCO_DEVICE_HOST="${CISCO_DEVICE_HOST:-cisco-asa-01}"
  22. CISCO_SRC_IP="${CISCO_SRC_IP:-198.51.100.25}"
  23. CISCO_DST_IP="${CISCO_DST_IP:-10.10.10.20}"
  24. CISCO_VPN_USER="${CISCO_VPN_USER:-vpn.user}"
  25. CISCO_ADMIN_USER="${CISCO_ADMIN_USER:-admin}"
  26. if ! [[ "${COUNT}" =~ ^[0-9]+$ ]] || [[ "${COUNT}" -lt 1 ]]; then
  27. echo "error: count must be a positive integer"
  28. exit 1
  29. fi
  30. if ! [[ "${DELAY}" =~ ^[0-9]+([.][0-9]+)?$ ]]; then
  31. echo "error: delay must be numeric (example: 0.5)"
  32. exit 1
  33. fi
  34. emit_syslog() {
  35. local msg="$1"
  36. local sent="false"
  37. if command -v nc >/dev/null 2>&1; then
  38. if printf "%s\n" "${msg}" | nc -u -w1 "${WAZUH_SYSLOG_HOST}" "${WAZUH_SYSLOG_PORT}"; then
  39. sent="true"
  40. fi
  41. fi
  42. if [[ "${sent}" != "true" ]]; then
  43. if printf "%s\n" "${msg}" >"/dev/udp/${WAZUH_SYSLOG_HOST}/${WAZUH_SYSLOG_PORT}" 2>/dev/null; then
  44. sent="true"
  45. fi
  46. fi
  47. if [[ "${sent}" != "true" ]]; then
  48. echo "error: failed to send syslog event to ${WAZUH_SYSLOG_HOST}:${WAZUH_SYSLOG_PORT}/udp"
  49. echo "hint: install netcat or run with bash UDP support (/dev/udp)"
  50. return 1
  51. fi
  52. echo "[$(date -u +'%Y-%m-%dT%H:%M:%SZ')] sent: ${msg}"
  53. }
  54. random_id() {
  55. printf "%s" "cisco-evt-$(date +%s)-$RANDOM-$RANDOM"
  56. }
  57. send_asa_acl_deny() {
  58. local eid
  59. eid="$(random_id)"
  60. emit_syslog "<166>$(date '+%b %d %H:%M:%S') ${CISCO_DEVICE_HOST} %ASA-4-106023: Deny tcp src outside:${CISCO_SRC_IP}/51515 dst inside:${CISCO_DST_IP}/445 by access-group \"outside_access_in\" [0x0, 0x0] soc_mvp_test=true vendor=cisco product=asa event_id=${eid} event_type=cisco_asa_acl_deny severity=high"
  61. }
  62. send_asa_vpn_auth_fail() {
  63. local eid
  64. eid="$(random_id)"
  65. emit_syslog "<166>$(date '+%b %d %H:%M:%S') ${CISCO_DEVICE_HOST} %ASA-4-113019: Group = RA-VPN, Username = ${CISCO_VPN_USER}, IP = ${CISCO_SRC_IP}, Session disconnected. Session Type: SSL, Duration: 0h:00m:01s, Bytes xmt: 0, Bytes rcv: 0, Reason: User Requested. soc_mvp_test=true vendor=cisco product=asa event_id=${eid} event_type=cisco_vpn_auth_fail severity=medium"
  66. }
  67. send_ios_login_fail() {
  68. local eid
  69. eid="$(random_id)"
  70. emit_syslog "<165>$(date '+%b %d %H:%M:%S') ${CISCO_DEVICE_HOST} %SEC_LOGIN-4-LOGIN_FAILED: Login failed [user: ${CISCO_ADMIN_USER}] [Source: ${CISCO_SRC_IP}] [localport: 22] [Reason: Login Authentication Failed] at 19:30:00 UTC Tue Feb 17 2026 soc_mvp_test=true vendor=cisco product=ios event_id=${eid} event_type=cisco_ios_login_fail severity=medium"
  71. }
  72. send_ios_config_change() {
  73. local eid
  74. eid="$(random_id)"
  75. emit_syslog "<165>$(date '+%b %d %H:%M:%S') ${CISCO_DEVICE_HOST} %SYS-5-CONFIG_I: Configured from console by ${CISCO_ADMIN_USER} on vty0 ( ${CISCO_SRC_IP} ) soc_mvp_test=true vendor=cisco product=ios event_id=${eid} event_type=cisco_config_change severity=low"
  76. }
  77. send_once() {
  78. case "${SCENARIO}" in
  79. asa_acl_deny)
  80. send_asa_acl_deny
  81. ;;
  82. asa_vpn_auth_fail)
  83. send_asa_vpn_auth_fail
  84. ;;
  85. ios_login_fail)
  86. send_ios_login_fail
  87. ;;
  88. ios_config_change)
  89. send_ios_config_change
  90. ;;
  91. all)
  92. send_asa_acl_deny
  93. send_asa_vpn_auth_fail
  94. send_ios_login_fail
  95. send_ios_config_change
  96. ;;
  97. *)
  98. echo "error: unknown scenario '${SCENARIO}'"
  99. echo "valid: asa_acl_deny | asa_vpn_auth_fail | ios_login_fail | ios_config_change | all"
  100. exit 1
  101. ;;
  102. esac
  103. }
  104. if [[ "${FOREVER}" == "true" ]]; then
  105. echo "running forever with interval ${DELAY}s (Ctrl+C to stop)"
  106. trap 'echo; echo "stopped"; exit 0' INT TERM
  107. while true; do
  108. send_once
  109. sleep "${DELAY}"
  110. done
  111. else
  112. for ((i=1; i<=COUNT; i++)); do
  113. send_once
  114. if [[ "${i}" -lt "${COUNT}" ]]; then
  115. sleep "${DELAY}"
  116. fi
  117. done
  118. fi