alert.sh 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. #!/bin/bash
  2. # LinuxGSM alert.sh function
  3. # Author: Daniel Gibbs
  4. # Website: https://gameservermanagers.com
  5. # Description: Overall function for managing alerts.
  6. local commandname="ALERT"
  7. local commandaction="Alert"
  8. fn_alert_log(){
  9. info_distro.sh
  10. info_config.sh
  11. info_glibc.sh
  12. info_messages.sh
  13. if [ -f "${alertlog}" ]; then
  14. rm "${alertlog}"
  15. fi
  16. {
  17. fn_info_message_head
  18. fn_info_message_distro
  19. fn_info_message_performance
  20. fn_info_message_disk
  21. fn_info_message_gameserver
  22. fn_info_logs
  23. } | sed -r "s/\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[m|K]//g"| tee -a "${alertlog}" > /dev/null 2>&1
  24. }
  25. fn_alert_test(){
  26. fn_script_log_info "Sending test alert"
  27. alertsubject="Alert - ${servicename} - Test"
  28. alertemoji="🚧"
  29. alertsound="1"
  30. alerturl="not enabled"
  31. alertbody="Testing LinuxGSM Alert. No action to be taken."
  32. }
  33. fn_alert_restart(){
  34. fn_script_log_info "Sending alert: Restarted: ${executable} not running"
  35. alertsubject="Alert - ${servicename} - Restarted"
  36. alertemoji="🚨"
  37. alertsound="2"
  38. alerturl="not enabled"
  39. alertbody="${servicename} ${executable} not running"
  40. }
  41. fn_alert_restart_query(){
  42. fn_script_log_info "Sending alert: Restarted: ${gsquerycmd}"
  43. alertsubject="Alert - ${servicename} - Restarted"
  44. alertemoji="🚨"
  45. alertsound="2"
  46. alerturl="not enabled"
  47. alertbody="gsquery.py failed to query: ${gsquerycmd}"
  48. }
  49. fn_alert_update(){
  50. fn_script_log_info "Sending alert: Updated"
  51. alertsubject="Alert - ${servicename} - Updated"
  52. alertemoji="🎮"
  53. alertsound="1"
  54. alerturl="not enabled"
  55. alertbody="${gamename} received update"
  56. }
  57. fn_alert_permissions(){
  58. fn_script_log_info "Sending alert: Permissions error"
  59. alertsubject="Alert - ${servicename}: Permissions error"
  60. alertemoji="❗"
  61. alertsound="2"
  62. alerturl="not enabled"
  63. alertbody="${servicename} has permissions issues"
  64. }
  65. if [ "${alert}" == "permissions" ]; then
  66. fn_alert_permissions
  67. elif [ "${alert}" == "restart" ]; then
  68. fn_alert_restart
  69. elif [ "${alert}" == "restartquery" ]; then
  70. fn_alert_restart_query
  71. elif [ "${alert}" == "test" ]; then
  72. fn_alert_test
  73. elif [ "${alert}" == "update" ]; then
  74. fn_alert_update
  75. fi
  76. # Generate alert log
  77. fn_alert_log
  78. # Generates the more info link
  79. if [ "${postalert}" == "on" ]&&[ -n "${postalert}" ]; then
  80. alertflag=1
  81. command_postdetails.sh
  82. elif [ "${postalert}" != "on" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  83. fn_print_warn_nl "More Info not enabled"
  84. fn_script_log_warn "More Info alerts not enabled"
  85. elif [ -z "${posttarget}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  86. fn_print_error_nl "posttarget not set"
  87. fn_script_error_warn "posttarget not set"
  88. elif [ -z "${postdays}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  89. fn_print_error_nl "postdays not set"
  90. fn_script_error_warn "postdays not set"
  91. fi
  92. if [ "${discordalert}" == "on" ]&&[ -n "${discordalert}" ]; then
  93. alert_discord.sh
  94. elif [ "${discordalert}" != "on" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  95. fn_print_warn_nl "Discord alerts not enabled"
  96. fn_script_log_warn "Discord alerts not enabled"
  97. elif [ -z "${discordtoken}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  98. fn_print_error_nl "Discord token not set"
  99. echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/Discord"
  100. fn_script_error_warn "Discord token not set"
  101. fi
  102. if [ "${emailalert}" == "on" ]&&[ -n "${email}" ]; then
  103. alert_email.sh
  104. elif [ "${emailalert}" != "on" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  105. fn_print_warn_nl "Email alerts not enabled"
  106. fn_script_log_warn "Email alerts not enabled"
  107. elif [ -z "${email}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  108. fn_print_error_nl "Email not set"
  109. fn_script_log_error "Email not set"
  110. fi
  111. if [ "${iftttalert}" == "on" ]&&[ -n "${iftttalert}" ]; then
  112. alert_ifttt.sh
  113. elif [ "${iftttalert}" != "on" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  114. fn_print_warn_nl "IFTTT alerts not enabled"
  115. fn_script_log_warn "IFTTT alerts not enabled"
  116. elif [ -z "${ifttttoken}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  117. fn_print_error_nl "IFTTT token not set"
  118. echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/IFTTT"
  119. fn_script_error_warn "IFTTT token not set"
  120. fi
  121. if [ "${mailgunalert}" == "on" ]&&[ -n "${mailgunalert}" ]; then
  122. alert_mailgun.sh
  123. elif [ "${mailgunalert}" != "on" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  124. fn_print_warn_nl "Mailgun alerts not enabled"
  125. fn_script_log_warn "Mailgun alerts not enabled"
  126. elif [ -z "${mailguntoken}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  127. fn_print_error_nl "Mailgun token not set"
  128. echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/Mailgun"
  129. fn_script_error_warn "Mailgun token not set"
  130. fi
  131. if [ "${pushbulletalert}" == "on" ]&&[ -n "${pushbullettoken}" ]; then
  132. alert_pushbullet.sh
  133. elif [ "${pushbulletalert}" != "on" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  134. fn_print_warn_nl "Pushbullet alerts not enabled"
  135. fn_script_log_warn "Pushbullet alerts not enabled"
  136. elif [ -z "${pushbullettoken}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  137. fn_print_error_nl "Pushbullet token not set"
  138. echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/Pushbullet"
  139. fn_script_error_warn "Pushbullet token not set"
  140. fi
  141. if [ "${pushoveralert}" == "on" ]&&[ -n "${pushoveralert}" ]; then
  142. alert_pushover.sh
  143. elif [ "${pushoveralert}" != "on" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  144. fn_print_warn_nl "Pushover alerts not enabled"
  145. fn_script_log_warn "Pushover alerts not enabled"
  146. elif [ -z "${pushovertoken}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  147. fn_print_error_nl "Pushover token not set"
  148. echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/Pushover"
  149. fn_script_error_warn "Pushover token not set"
  150. fi
  151. if [ "${telegramalert}" == "on" ]&&[ -n "${telegramtoken}" ]; then
  152. alert_telegram.sh
  153. elif [ "${telegramalert}" != "on" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  154. fn_print_warn_nl "Telegram Messages not enabled"
  155. fn_script_log_warn "Telegram Messages not enabled"
  156. elif [ -z "${telegramtoken}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  157. fn_print_error_nl "Telegram token not set."
  158. echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/Telegram"
  159. fn_script_error_warn "Telegram token not set."
  160. elif [ -z "${telegramchatid}" ]&&[ "${function_selfname}" == "command_test_alert.sh" ]; then
  161. fn_print_error_nl "Telegram chat id not set."
  162. echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/Telegram"
  163. fn_script_error_warn "Telegram chat id not set."
  164. fi