1
0

remove_ccd.sh 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. #!/bin/bash
  2. set -o errexit
  3. set -o nounset
  4. set -o pipefail
  5. log() {
  6. logger -t "openvpn-ban" -p user.info "$1"
  7. echo "$1" # Также выводим в консоль для обратной связи
  8. }
  9. show_usage() {
  10. echo "Usage: $0 <ccd_file>"
  11. echo "Example: $0 /etc/openvpn/server/server/ccd/login"
  12. exit 1
  13. }
  14. # Проверка прав
  15. check_permissions() {
  16. if [[ $EUID -ne 0 ]]; then
  17. log "Error: This script must be run as root" >&2
  18. exit 1
  19. fi
  20. }
  21. # Проверка что CCD файл находится в правильном пути
  22. check_ccd_path() {
  23. local ccd_file=$1
  24. local expected_path="/etc/openvpn/server"
  25. # Проверяем что путь начинается с /etc/openvpn/server/
  26. if [[ ! "$ccd_file" =~ ^$expected_path/ ]]; then
  27. log "Error: CCD file must be located under $expected_path/"
  28. log "Provided path: $ccd_file"
  29. exit 1
  30. fi
  31. # Дополнительная проверка: файл должен существовать
  32. if [[ ! -f "$ccd_file" ]]; then
  33. log "Error: CCD file does not exist: $ccd_file"
  34. exit 0
  35. fi
  36. }
  37. main() {
  38. # Проверка прав
  39. check_permissions
  40. # Обработка аргументов
  41. [[ $# -lt 1 ]] && show_usage
  42. local ccd_file=$1
  43. # Проверка пути CCD файла
  44. check_ccd_path "$ccd_file"
  45. #remove file
  46. rm -f "${ccd_file}"
  47. }
  48. main "$@"