core_messages.sh 16 KB

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