core_messages.sh 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577
  1. #!/bin/bash
  2. # LinuxGSM core_messages.sh module
  3. # Author: Daniel Gibbs
  4. # Contributors: https://linuxgsm.com/contrib
  5. # Website: https://linuxgsm.com
  6. # Description: Defines on-screen messages such as [ OK ] and how script logs look.
  7. moduleselfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")"
  8. # nl: new line: message is following by a new line.
  9. # eol: end of line: message is placed at the end of the current line.
  10. fn_ansi_loader() {
  11. # carriage return.
  12. creeol="\r"
  13. if [ "${ansi}" != "off" ]; then
  14. # echo colors
  15. default="\e[0m"
  16. black="\e[30m"
  17. red="\e[31m"
  18. lightred="\e[91m"
  19. green="\e[32m"
  20. lightgreen="\e[92m"
  21. yellow="\e[33m"
  22. lightyellow="\e[93m"
  23. blue="\e[34m"
  24. lightblue="\e[94m"
  25. magenta="\e[35m"
  26. lightmagenta="\e[95m"
  27. cyan="\e[36m"
  28. lightcyan="\e[96m"
  29. darkgrey="\e[90m"
  30. lightgrey="\e[37m"
  31. white="\e[97m"
  32. # erase to end of line.
  33. creeol+="\033[K"
  34. fi
  35. # carriage return & erase to end of line.
  36. creeol="\r\033[K"
  37. bold="\e[1m"
  38. dim="\e[2m"
  39. italic="\e[3m"
  40. underline="\e[4m"
  41. reverse="\e[7m"
  42. }
  43. fn_sleep_time() {
  44. sleep "0.1"
  45. }
  46. fn_sleep_time_05() {
  47. sleep "0.5"
  48. }
  49. fn_sleep_time_1() {
  50. sleep "1"
  51. }
  52. fn_sleep_time_5() {
  53. sleep "5"
  54. }
  55. fn_sleep_time_10() {
  56. sleep "10"
  57. }
  58. # Log display
  59. ########################
  60. ## Feb 28 14:56:58 ut99-server: Monitor:
  61. fn_script_log() {
  62. if [ -d "${lgsmlogdir}" ]; then
  63. if [ -n "${commandname}" ]; then
  64. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: ${1}" >> "${lgsmlog}"
  65. else
  66. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${1}" >> "${lgsmlog}"
  67. fi
  68. fi
  69. }
  70. ## Feb 28 14:56:58 ut99-server: Monitor: PASS:
  71. fn_script_log_pass() {
  72. fn_script_log "PASS: ${1}"
  73. exitcode=0
  74. }
  75. ## Feb 28 14:56:58 ut99-server: Monitor: FATAL:
  76. fn_script_log_fail() {
  77. fn_script_log "FAIL: ${1}"
  78. exitcode=1
  79. }
  80. ## Feb 28 14:56:58 ut99-server: Monitor: ERROR:
  81. fn_script_log_error() {
  82. fn_script_log "ERROR: ${1}"
  83. exitcode=2
  84. }
  85. ## Feb 28 14:56:58 ut99-server: Monitor: WARN:
  86. fn_script_log_warn() {
  87. fn_script_log "WARN: ${1}"
  88. exitcode=3
  89. }
  90. ## Feb 28 14:56:58 ut99-server: Monitor: INFO:
  91. fn_script_log_info() {
  92. fn_script_log "INFO: ${1}"
  93. }
  94. # On-Screen - Automated functions
  95. ##################################
  96. fn_print() {
  97. echo -en "$*${default}"
  98. }
  99. fn_print_nl() {
  100. echo -e "$*${default}"
  101. }
  102. # Helper function to print messages with a specific format and color
  103. fn_print_message() {
  104. local type="$1"
  105. local color="$2"
  106. local message="$3"
  107. if [ "${commandaction}" ]; then
  108. echo -en "${bold}${creeol}[${color} ${type} ${default}]${default} ${commandaction} ${selfname}: ${message}${default}"
  109. else
  110. echo -en "${bold}${cree}[${color} ${type} ${default}]${default} ${message}${default}"
  111. fi
  112. fn_sleep_time
  113. }
  114. fn_print_message_nl() {
  115. local type="$1"
  116. local color="$2"
  117. local message="$3"
  118. if [ "${commandaction}" ]; then
  119. echo -e "${bold}${creeol}[${color} ${type} ${default}]${default} ${commandaction} ${selfname}: ${message}${default}"
  120. else
  121. echo -e "${bold}${creeol}[${color} ${type} ${default}]${default} ${message}${default}"
  122. fi
  123. fn_sleep_time
  124. }
  125. # [ .... ]
  126. fn_print_dots() {
  127. fn_print_message "...." "${default}" "$*"
  128. fn_sleep_time_05
  129. }
  130. fn_print_dots_nl() {
  131. fn_print_message_nl "...." "${default}" "$*"
  132. fn_sleep_time_05
  133. }
  134. # [ OK ]
  135. fn_print_ok() {
  136. fn_print_message " OK " "${green}" "$*"
  137. }
  138. fn_print_ok_nl() {
  139. fn_print_message_nl " OK " "${green}" "$*"
  140. }
  141. # [ FAIL ]
  142. fn_print_fail() {
  143. fn_print_message "FAIL" "${red}" "$*"
  144. }
  145. fn_print_fail_nl() {
  146. fn_print_message_nl "FAIL" "${red}" "$*"
  147. }
  148. # [ ERROR ]
  149. fn_print_error() {
  150. fn_print_message "ERROR" "${red}" "$*"
  151. }
  152. fn_print_error_nl() {
  153. fn_print_message_nl "ERROR" "${red}" "$*"
  154. }
  155. # [ WARN ]
  156. fn_print_warn() {
  157. fn_print_message "WARN" "${lightyellow}" "$*"
  158. }
  159. fn_print_warn_nl() {
  160. fn_print_message_nl "WARN" "${lightyellow}" "$*"
  161. }
  162. # [ INFO ]
  163. fn_print_info() {
  164. fn_print_message "INFO" "${cyan}" "$*"
  165. }
  166. fn_print_info_nl() {
  167. fn_print_message_nl "INFO" "${cyan}" "$*"
  168. }
  169. # [ SKIP ]
  170. fn_print_skip() {
  171. fn_print_message "SKIP" "${cyan}" "$*"
  172. }
  173. fn_print_skip_nl() {
  174. fn_print_message_nl "SKIP" "${cyan}" "$*"
  175. }
  176. # [ START ]
  177. fn_print_start() {
  178. fn_print_message "START" "${lightgreen}" "$*"
  179. }
  180. fn_print_start_nl() {
  181. fn_print_message_nl "START" "${lightgreen}" "$*"
  182. }
  183. # On-Screen - Interactive messages
  184. ##################################
  185. # Separator is different for details.
  186. fn_messages_separator() {
  187. if [ "${commandname}" == "DETAILS" ]; then
  188. printf '%*s\n' "${COLUMNS:-$(tput cols)}" '' | tr ' ' =
  189. else
  190. echo -e "${bold}=================================${default}"
  191. fn_sleep_time
  192. fi
  193. }
  194. # No More Room in Hell Debug
  195. # =================================
  196. fn_print_header() {
  197. echo -e ""
  198. echo -e "${bold}${lightyellow}${gamename} ${commandaction}${default}"
  199. fn_messages_separator
  200. }
  201. # Success!
  202. fn_print_success() {
  203. echo -en "${green}Success!${default} $*${default}"
  204. fn_sleep_time
  205. }
  206. fn_print_success_nl() {
  207. echo -e "${green}Success!${default} $*${default}"
  208. fn_sleep_time
  209. }
  210. # Failure!
  211. fn_print_failure() {
  212. echo -en "${red}Failure!${default} $*${default}"
  213. fn_sleep_time
  214. }
  215. fn_print_failure_nl() {
  216. echo -e "${red}Failure!${default} $*${default}"
  217. fn_sleep_time
  218. }
  219. # Error!
  220. fn_print_error2() {
  221. echo -en "${red}Error!${default} $*${default}"
  222. fn_sleep_time
  223. }
  224. fn_print_error2_nl() {
  225. echo -e "${red}Error!${default} $*${default}"
  226. fn_sleep_time
  227. }
  228. # Warning!
  229. fn_print_warning() {
  230. echo -en "${lightyellow}Warning!${default} $*${default}"
  231. fn_sleep_time
  232. }
  233. fn_print_warning_nl() {
  234. echo -e "${lightyellow}Warning!${default} $*${default}"
  235. fn_sleep_time
  236. }
  237. # Information!
  238. fn_print_information() {
  239. echo -en "${cyan}Information!${default} $*${default}"
  240. fn_sleep_time
  241. }
  242. fn_print_information_nl() {
  243. echo -e "${cyan}Information!${default} $*${default}"
  244. fn_sleep_time
  245. }
  246. # Skip!
  247. fn_print_skip2() {
  248. echo -en "${cyan}Skip!${default} $*${default}"
  249. fn_sleep_time
  250. }
  251. fn_print_skip2_nl() {
  252. echo -e "${cyan}Skip!${default} $*${default}"
  253. fn_sleep_time
  254. }
  255. # Y/N Prompt
  256. fn_prompt_yn() {
  257. echo -e ""
  258. local prompt="$1"
  259. local initial="$2"
  260. if [ "${initial}" == "Y" ]; then
  261. prompt+=" [Y/n] "
  262. elif [ "${initial}" == "N" ]; then
  263. prompt+=" [y/N] "
  264. else
  265. prompt+=" [y/n] "
  266. fi
  267. while true; do
  268. read -e -i "${initial}" -p "${prompt}" -r yn
  269. case "${yn}" in
  270. [Yy] | [Yy][Ee][Ss]) return 0 ;;
  271. [Nn] | [Nn][Oo]) return 1 ;;
  272. *) echo -e "Please answer yes or no." ;;
  273. esac
  274. done
  275. }
  276. # Prompt for message
  277. fn_prompt_message() {
  278. while true; do
  279. unset prompt
  280. local prompt="$1"
  281. read -e -p "${prompt}" -r answer
  282. if fn_prompt_yn "Continue" Y; then
  283. break
  284. fi
  285. done
  286. echo "${answer}"
  287. }
  288. # On-Screen End of Line
  289. ##################################
  290. # YES
  291. fn_print_yes_eol() {
  292. echo -en " ... ${cyan}YES${default}"
  293. fn_sleep_time
  294. }
  295. fn_print_yes_eol_nl() {
  296. echo -e " ... ${cyan}YES${default}"
  297. fn_sleep_time
  298. }
  299. # NO
  300. fn_print_no_eol() {
  301. echo -en " ... ${red}NO${default}"
  302. fn_sleep_time
  303. }
  304. fn_print_no_eol_nl() {
  305. echo -e " ... ${red}NO${default}"
  306. fn_sleep_time
  307. }
  308. # OK
  309. fn_print_ok_eol() {
  310. echo -en " ... ${green}OK${default}"
  311. fn_sleep_time
  312. }
  313. fn_print_ok_eol_nl() {
  314. echo -e " ... ${green}OK${default}"
  315. fn_sleep_time
  316. }
  317. # FAIL
  318. fn_print_fail_eol() {
  319. echo -en " ... ${red}FAIL${default}"
  320. fn_sleep_time
  321. }
  322. fn_print_fail_eol_nl() {
  323. echo -e " ... ${red}FAIL${default}"
  324. fn_sleep_time
  325. }
  326. # ERROR
  327. fn_print_error_eol() {
  328. echo -en " ... ${red}ERROR${default}"
  329. fn_sleep_time
  330. }
  331. fn_print_error_eol_nl() {
  332. echo -e " ... ${red}ERROR${default}"
  333. fn_sleep_time
  334. }
  335. # WAIT
  336. fn_print_wait_eol() {
  337. echo -en " ... ${cyan}WAIT${default}"
  338. fn_sleep_time
  339. }
  340. fn_print_wait_eol_nl() {
  341. echo -e " ... ${cyan}WAIT${default}"
  342. fn_sleep_time
  343. }
  344. # WARN
  345. fn_print_warn_eol() {
  346. echo -en " ... ${lightyellow}WARN${default}"
  347. fn_sleep_time
  348. }
  349. fn_print_warn_eol_nl() {
  350. echo -e " ... ${lightyellow}WARN${default}"
  351. fn_sleep_time
  352. }
  353. # INFO
  354. fn_print_info_eol() {
  355. echo -en " ... ${cyan}INFO${default}"
  356. fn_sleep_time
  357. }
  358. fn_print_info_eol_nl() {
  359. echo -e " ... ${cyan}INFO${default}"
  360. fn_sleep_time
  361. }
  362. # QUERYING
  363. fn_print_querying_eol() {
  364. echo -en " ... ${cyan}QUERYING${default}"
  365. fn_sleep_time_1
  366. }
  367. fn_print_querying_eol_nl() {
  368. echo -e " ... ${cyan}QUERYING${default}"
  369. fn_sleep_time_1
  370. }
  371. # CHECKING
  372. fn_print_checking_eol() {
  373. echo -en " ... ${cyan}CHECKING${default}"
  374. fn_sleep_time_1
  375. }
  376. fn_print_checking_eol_nl() {
  377. echo -e " ... ${cyan}CHECKING${default}"
  378. fn_sleep_time_1
  379. }
  380. # DELAY
  381. fn_print_delay_eol() {
  382. echo -en " ... ${green}DELAY${default}"
  383. fn_sleep_time_1
  384. }
  385. fn_print_delay_eol_nl() {
  386. echo -e " ... ${green}DELAY${default}"
  387. fn_sleep_time_1
  388. }
  389. # CANCELED
  390. fn_print_canceled_eol() {
  391. echo -en " ... ${lightyellow}CANCELED${default}"
  392. fn_sleep_time_1
  393. }
  394. fn_print_canceled_eol_nl() {
  395. echo -e " ... ${lightyellow}CANCELED${default}"
  396. fn_sleep_time_1
  397. }
  398. # REMOVED
  399. fn_print_removed_eol() {
  400. echo -en " ... ${red}REMOVED${default}"
  401. fn_sleep_time_1
  402. }
  403. fn_print_removed_eol_nl() {
  404. echo -e " ... ${red}REMOVED${default}"
  405. fn_sleep_time_1
  406. }
  407. # UPDATE
  408. fn_print_update_eol() {
  409. echo -en " ... ${lightblue}UPDATE${default}"
  410. fn_sleep_time
  411. }
  412. fn_print_update_eol_nl() {
  413. echo -e " ... ${lightblue}UPDATE${default}"
  414. fn_sleep_time
  415. }
  416. # SKIP
  417. fn_print_skip_eol() {
  418. echo -en " ... ${cyan}SKIP${default}"
  419. fn_sleep_time
  420. }
  421. fn_print_skip_eol_nl() {
  422. echo -e " ... ${cyan}SKIP${default}"
  423. fn_sleep_time
  424. }
  425. fn_print_ascii_logo() {
  426. echo -e ""
  427. echo -e " mdMMMMbm"
  428. echo -e " mMMMMMMMMMMm"
  429. echo -e " mMMMMMMMMMMMMm"
  430. echo -e " mMMMMMMMMMMMMMMm"
  431. echo -e " hMMMV^VMMV^VMMMh"
  432. echo -e " MMMMM MM MMMMM"
  433. echo -e " hMMs vv sMMh"
  434. echo -e " hMMM: :MMMh"
  435. echo -e " .hMMMh hMMMh."
  436. echo -e " -dMMMh ${lightgrey}__${default} hMMMd-"
  437. echo -e " :mMMMs ${lightgrey}||${default} sMMMm:"
  438. echo -e " :MMMM+ ${lightgrey}||${default} ${red}_${default} +NMMN:"
  439. echo -e " .mMMM+ ${lightgrey}========${default} +MMMm."
  440. echo -e " yMMMy ${darkgrey}##############${default} yMMMy"
  441. echo -e " mMMM: ${darkgrey}##############${default} :MMMm"
  442. echo -e " mMM ${lightyellow}nn${default} ${lightyellow}nn${default} ${lightyellow}nn${default} ${lightyellow}nn${default} MMm"
  443. echo -e " o ${lightyellow}nNNNNNNNn${default} ${lightyellow}nNNNNNNNn${default} o"
  444. echo -e " ${lightyellow}nNNNNNNNNNn${default} ${lightyellow}nNNNNNNNNNn${default}"
  445. echo -e " ${lightyellow}nNNNNNNNNNNN${default} ${lightyellow}NNNNNNNNNNNn${default}"
  446. echo -e " ${lightyellow}+NNNNNNNNN:${default} ${lightyellow}:NNNNNNNNN+${default}"
  447. echo -e " ${lightyellow}nNNNNNNN${default} /\ ${lightyellow}NNNNNNNn${default}"
  448. echo -e " ${lightyellow}nnnnn${default} db ${lightyellow}nnnnn${default}"
  449. echo -e ""
  450. echo -e "${lightyellow}888${default} ${lightyellow}d8b${default} ${default}.d8888b. .d8888b. 888b d888"
  451. echo -e "${lightyellow}888 Y8P ${default}d88P Y88b d88P Y88b 8888b d8888"
  452. echo -e "${lightyellow}888${default} ${default}888${default} 888 Y88b. 88888b.d88888"
  453. echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}88888b.${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} 888 Y888b. 888Y88888P888"
  454. echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}88b${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y8bd8P${default} 888 88888 Y88b. 888 Y888P 888"
  455. echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}X88K${default} 888 888 888 888 Y8P 888"
  456. echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y88b${default} ${lightyellow}88Y${default} ${lightyellow}.d8pq8b.${default} Y88b d88P Y88b d88P 888 * 888"
  457. echo -e "${lightyellow}LinuxGSM${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y8888Y${default} ${lightyellow}888${default} ${lightyellow}888${default} Y2012P88 Y8888P 888 888"
  458. echo -e ""
  459. }
  460. fn_print_restart_warning() {
  461. fn_print_warn "${selfname} will be restarted"
  462. fn_script_log_warn "${selfname} will be restarted"
  463. totalseconds=3
  464. for seconds in {3..1}; do
  465. fn_print_warn "${selfname} will be restarted: ${totalseconds}"
  466. totalseconds=$((totalseconds - 1))
  467. fn_sleep_time_1
  468. if [ "${seconds}" == "0" ]; then
  469. break
  470. fi
  471. done
  472. fn_print_warn_nl "${selfname} will be restarted"
  473. }
  474. # Functions below are used to ensure that logs and UI correctly reflect the command it is actually running.
  475. # Useful when a command has to call upon another command causing the other command to overwrite commandname variables
  476. # Used to remember the command that ran first.
  477. fn_firstcommand_set() {
  478. if [ -z "${firstcommandname}" ]; then
  479. firstcommandname="${commandname}"
  480. firstcommandaction="${commandaction}"
  481. fi
  482. }
  483. # Used to reset commandname variables to the command the script ran first.
  484. fn_firstcommand_reset() {
  485. commandname="${firstcommandname}"
  486. commandaction="${firstcommandaction}"
  487. }