core_messages.sh 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520
  1. #!/bin/bash
  2. # LinuxGSM core_messages.sh function
  3. # Author: Daniel Gibbs
  4. # Contributor: s-eam
  5. # Website: https://linuxgsm.com
  6. # Description: Defines on-screen messages such as [ OK ] and how script logs look.
  7. functionselfname="$(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. }
  34. fn_sleep_time(){
  35. if [ "${sleeptime}" != "0" ]||[ "${travistest}" != "1" ]; then
  36. if [ -z "${sleeptime}" ]; then
  37. sleeptime=0.5
  38. fi
  39. sleep "${sleeptime}"
  40. fi
  41. }
  42. # Log display
  43. ########################
  44. ## Feb 28 14:56:58 ut99-server: Monitor:
  45. fn_script_log(){
  46. if [ -d "${lgsmlogdir}" ]; then
  47. if [ -n "${commandname}" ]; then
  48. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: ${1}" >> "${lgsmlog}"
  49. else
  50. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${1}" >> "${lgsmlog}"
  51. fi
  52. fi
  53. }
  54. ## Feb 28 14:56:58 ut99-server: Monitor: PASS:
  55. fn_script_log_pass(){
  56. if [ -d "${lgsmlogdir}" ]; then
  57. if [ -n "${commandname}" ]; then
  58. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: PASS: ${1}" >> "${lgsmlog}"
  59. else
  60. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: PASS: ${1}" >> "${lgsmlog}"
  61. fi
  62. fi
  63. exitcode=0
  64. }
  65. ## Feb 28 14:56:58 ut99-server: Monitor: FATAL:
  66. fn_script_log_fatal(){
  67. if [ -d "${lgsmlogdir}" ]; then
  68. if [ -n "${commandname}" ]; then
  69. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: FATAL: ${1}" >> "${lgsmlog}"
  70. else
  71. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: FATAL: ${1}" >> "${lgsmlog}"
  72. fi
  73. fi
  74. exitcode=1
  75. }
  76. ## Feb 28 14:56:58 ut99-server: Monitor: ERROR:
  77. fn_script_log_error(){
  78. if [ -d "${lgsmlogdir}" ]; then
  79. if [ -n "${commandname}" ]; then
  80. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: ERROR: ${1}" >> "${lgsmlog}"
  81. else
  82. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ERROR: ${1}" >> "${lgsmlog}"
  83. fi
  84. fi
  85. exitcode=2
  86. }
  87. ## Feb 28 14:56:58 ut99-server: Monitor: WARN:
  88. fn_script_log_warn(){
  89. if [ -d "${lgsmlogdir}" ]; then
  90. if [ -n "${commandname}" ]; then
  91. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: WARN: ${1}" >> "${lgsmlog}"
  92. else
  93. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: WARN: ${1}" >> "${lgsmlog}"
  94. fi
  95. fi
  96. exitcode=3
  97. }
  98. ## Feb 28 14:56:58 ut99-server: Monitor: INFO:
  99. fn_script_log_info(){
  100. if [ -d "${lgsmlogdir}" ]; then
  101. if [ -n "${commandname}" ]; then
  102. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: INFO: ${1}" >> "${lgsmlog}"
  103. else
  104. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: INFO: ${1}" >> "${lgsmlog}"
  105. fi
  106. fi
  107. }
  108. # On-Screen - Automated functions
  109. ##################################
  110. # [ .... ]
  111. fn_print_dots(){
  112. if [ "${commandaction}" ]; then
  113. echo -en "${creeol}[ .... ] ${commandaction} ${selfname}: $*"
  114. else
  115. echo -en "${creeol}[ .... ] $*"
  116. fi
  117. fn_sleep_time
  118. }
  119. fn_print_dots_nl(){
  120. if [ "${commandaction}" ]; then
  121. echo -e "${creeol}[ .... ] ${commandaction} ${selfname}: $*"
  122. else
  123. echo -e "${creeol}[ .... ] $*"
  124. fi
  125. fn_sleep_time
  126. echo -en "\n"
  127. }
  128. # [ OK ]
  129. fn_print_ok(){
  130. if [ "${commandaction}" ]; then
  131. echo -en "${creeol}[${green} OK ${default}] ${commandaction} ${selfname}: $*"
  132. else
  133. echo -en "${creeol}[${green} OK ${default}] $*"
  134. fi
  135. fn_sleep_time
  136. }
  137. fn_print_ok_nl(){
  138. if [ "${commandaction}" ]; then
  139. echo -en "${creeol}[${green} OK ${default}] ${commandaction} ${selfname}: $*"
  140. else
  141. echo -en "${creeol}[${green} OK ${default}] $*"
  142. fi
  143. fn_sleep_time
  144. echo -en "\n"
  145. }
  146. # [ FAIL ]
  147. fn_print_fail(){
  148. if [ "${commandaction}" ]; then
  149. echo -en "${creeol}[${red} FAIL ${default}] ${commandaction} ${selfname}: $*"
  150. else
  151. echo -en "${creeol}[${red} FAIL ${default}] $*"
  152. fi
  153. fn_sleep_time
  154. }
  155. fn_print_fail_nl(){
  156. if [ "${commandaction}" ]; then
  157. echo -en "${creeol}[${red} FAIL ${default}] ${commandaction} ${selfname}: $*"
  158. else
  159. echo -en "${creeol}[${red} FAIL ${default}] $*"
  160. fi
  161. fn_sleep_time
  162. echo -en "\n"
  163. }
  164. # [ ERROR ]
  165. fn_print_error(){
  166. if [ "${commandaction}" ]; then
  167. echo -en "${creeol}[${red} ERROR ${default}] ${commandaction} ${selfname}: $*"
  168. else
  169. echo -en "${creeol}[${red} ERROR ${default}] $*"
  170. fi
  171. fn_sleep_time
  172. }
  173. fn_print_error_nl(){
  174. if [ "${commandaction}" ]; then
  175. echo -en "${creeol}[${red} ERROR ${default}] ${commandaction} ${selfname}: $*"
  176. else
  177. echo -en "${creeol}[${red} ERROR ${default}] $*"
  178. fi
  179. fn_sleep_time
  180. echo -en "\n"
  181. }
  182. # [ WARN ]
  183. fn_print_warn(){
  184. if [ "${commandaction}" ]; then
  185. echo -en "${creeol}[${lightyellow} WARN ${default}] ${commandaction} ${selfname}: $*"
  186. else
  187. echo -en "${creeol}[${lightyellow} WARN ${default}] $*"
  188. fi
  189. fn_sleep_time
  190. }
  191. fn_print_warn_nl(){
  192. if [ "${commandaction}" ]; then
  193. echo -en "${creeol}[${lightyellow} WARN ${default}] ${commandaction} ${selfname}: $*"
  194. else
  195. echo -en "${creeol}[${lightyellow} WARN ${default}] $*"
  196. fi
  197. fn_sleep_time
  198. echo -en "\n"
  199. }
  200. # [ INFO ]
  201. fn_print_info(){
  202. if [ "${commandaction}" ]; then
  203. echo -en "${creeol}[${cyan} INFO ${default}] ${commandaction} ${selfname}: $*"
  204. else
  205. echo -en "${creeol}[${cyan} INFO ${default}] $*"
  206. fi
  207. fn_sleep_time
  208. }
  209. fn_print_info_nl(){
  210. if [ "${commandaction}" ]; then
  211. echo -en "${creeol}[${cyan} INFO ${default}] ${commandaction} ${selfname}: $*"
  212. else
  213. echo -en "${creeol}[${cyan} INFO ${default}] $*"
  214. fi
  215. fn_sleep_time
  216. echo -en "\n"
  217. }
  218. # [ START ]
  219. fn_print_start(){
  220. if [ "${commandaction}" ]; then
  221. echo -en "${creeol}[${lightgreen} START ${default}] ${commandaction} ${selfname}: $*"
  222. else
  223. echo -en "${creeol}[${lightgreen} START ${default}] $*"
  224. fi
  225. fn_sleep_time
  226. }
  227. fn_print_start_nl(){
  228. if [ "${commandaction}" ]; then
  229. echo -en "${creeol}[${lightgreen} START ${default}] ${commandaction} ${selfname}: $*"
  230. else
  231. echo -en "${creeol}[${lightgreen} START ${default}] $*"
  232. fi
  233. fn_sleep_time
  234. echo -en "\n"
  235. }
  236. # On-Screen - Interactive messages
  237. ##################################
  238. # No More Room in Hell Debug
  239. # =================================
  240. fn_print_header(){
  241. echo -e ""
  242. echo -e "${lightyellow}${gamename} ${commandaction}${default}"
  243. echo -e "=================================${default}"
  244. }
  245. # Complete!
  246. fn_print_complete(){
  247. echo -en "${green}Complete!${default} $*"
  248. fn_sleep_time
  249. }
  250. fn_print_complete_nl(){
  251. echo -e "${green}Complete!${default} $*"
  252. fn_sleep_time
  253. }
  254. # Failure!
  255. fn_print_failure(){
  256. echo -en "${red}Failure!${default} $*"
  257. fn_sleep_time
  258. }
  259. fn_print_failure_nl(){
  260. echo -e "${red}Failure!${default} $*"
  261. fn_sleep_time
  262. }
  263. # Error!
  264. fn_print_error2(){
  265. echo -en "${red}Error!${default} $*"
  266. fn_sleep_time
  267. }
  268. fn_print_error2_nl(){
  269. echo -e "${red}Error!${default} $*"
  270. fn_sleep_time
  271. }
  272. # Warning!
  273. fn_print_warning(){
  274. echo -en "${lightyellow}Warning!${default} $*"
  275. fn_sleep_time
  276. }
  277. fn_print_warning_nl(){
  278. echo -e "${lightyellow}Warning!${default} $*"
  279. fn_sleep_time
  280. }
  281. # Information!
  282. fn_print_information(){
  283. echo -en "${cyan}Information!${default} $*"
  284. fn_sleep_time
  285. }
  286. fn_print_information_nl(){
  287. echo -e "${cyan}Information!${default} $*"
  288. fn_sleep_time
  289. }
  290. # Y/N Prompt
  291. fn_prompt_yn(){
  292. local prompt="$1"
  293. local initial="$2"
  294. if [ "${initial}" == "Y" ]; then
  295. prompt+=" [Y/n] "
  296. elif [ "${initial}" == "N" ]; then
  297. prompt+=" [y/N] "
  298. else
  299. prompt+=" [y/n] "
  300. fi
  301. while true; do
  302. read -e -i "${initial}" -p "${prompt}" -r yn
  303. case "${yn}" in
  304. [Yy]|[Yy][Ee][Ss]) return 0 ;;
  305. [Nn]|[Nn][Oo]) return 1 ;;
  306. *) echo -e "Please answer yes or no." ;;
  307. esac
  308. done
  309. }
  310. # On-Screen End of Line
  311. ##################################
  312. # OK
  313. fn_print_ok_eol(){
  314. echo -en "${green}OK${default}"
  315. fn_sleep_time
  316. }
  317. fn_print_ok_eol_nl(){
  318. echo -e "${green}OK${default}"
  319. fn_sleep_time
  320. }
  321. # FAIL
  322. fn_print_fail_eol(){
  323. echo -en "${red}FAIL${default}"
  324. fn_sleep_time
  325. }
  326. fn_print_fail_eol_nl(){
  327. echo -e "${red}FAIL${default}"
  328. fn_sleep_time
  329. }
  330. # ERROR
  331. fn_print_error_eol(){
  332. echo -en "${red}ERROR${default}"
  333. fn_sleep_time
  334. }
  335. fn_print_error_eol_nl(){
  336. echo -e "${red}ERROR${default}"
  337. fn_sleep_time
  338. }
  339. # WAIT
  340. fn_print_wait_eol(){
  341. echo -en "${cyan}WAIT${default}"
  342. fn_sleep_time
  343. }
  344. fn_print_wait_eol_nl(){
  345. echo -e "${cyan}WAIT${default}"
  346. fn_sleep_time
  347. }
  348. # WARN
  349. fn_print_warn_eol(){
  350. echo -en "${lightyellow}WARN${default}"
  351. fn_sleep_time
  352. }
  353. fn_print_warn_eol_nl(){
  354. echo -e "${lightyellow}WARN${default}"
  355. fn_sleep_time
  356. }
  357. # INFO
  358. fn_print_info_eol(){
  359. echo -en "${cyan}INFO${default}"
  360. fn_sleep_time
  361. }
  362. fn_print_info_eol_nl(){
  363. echo -e "${cyan}INFO${default}"
  364. fn_sleep_time
  365. }
  366. # QUERYING
  367. fn_print_querying_eol(){
  368. echo -en "${cyan}QUERYING${default}"
  369. fn_sleep_time
  370. }
  371. fn_print_querying_eol_nl(){
  372. echo -e "${cyan}QUERYING${default}"
  373. fn_sleep_time
  374. }
  375. # CHECKING
  376. fn_print_checking_eol(){
  377. echo -en "${cyan}CHECKING${default}"
  378. fn_sleep_time
  379. }
  380. fn_print_checking_eol_nl(){
  381. echo -e "${cyan}CHECKING${default}"
  382. fn_sleep_time
  383. }
  384. # DELAY
  385. fn_print_delay_eol(){
  386. echo -en "${green}DELAY${default}"
  387. fn_sleep_time
  388. }
  389. fn_print_delay_eol_nl(){
  390. echo -e "${green}DELAY${default}"
  391. fn_sleep_time
  392. }
  393. # CANCELED
  394. fn_print_canceled_eol(){
  395. echo -en "${lightyellow}CANCELED${default}"
  396. fn_sleep_time
  397. }
  398. fn_print_canceled_eol_nl(){
  399. echo -e "${lightyellow}CANCELED${default}"
  400. fn_sleep_time
  401. }
  402. # REMOVED
  403. fn_print_removed_eol(){
  404. echo -en "${red}REMOVED${default}"
  405. fn_sleep_time
  406. }
  407. fn_print_removed_eol_nl(){
  408. echo -e "${red}REMOVED${default}"
  409. fn_sleep_time
  410. }
  411. # UPDATE
  412. fn_print_update_eol(){
  413. echo -en "${cyan}UPDATE${default}"
  414. fn_sleep_time
  415. }
  416. fn_print_update_eol_nl(){
  417. echo -e "${cyan}UPDATE${default}"
  418. fn_sleep_time
  419. }
  420. fn_print_ascii_logo(){
  421. echo -e ""
  422. echo -e " mdMMMMbm"
  423. echo -e " mMMMMMMMMMMm"
  424. echo -e " mMMMMMMMMMMMMm"
  425. echo -e " mMMMMMMMMMMMMMMm"
  426. echo -e " hMMMV^VMMV^VMMMh"
  427. echo -e " MMMMM MM MMMMM"
  428. echo -e " hMMs vv sMMh"
  429. echo -e " hMMM: :MMMh"
  430. echo -e " .hMMMh hMMMh."
  431. echo -e " -dMMMh ${lightgrey}__${default} hMMMd-"
  432. echo -e " :mMMMs ${lightgrey}||${default} sMMMm:"
  433. echo -e " :MMMM+ ${lightgrey}||${default} ${red}_${default} +NMMN:"
  434. echo -e " .mMMM+ ${lightgrey}========${default} +MMMm."
  435. echo -e " yMMMy ${darkgrey}##############${default} yMMMy"
  436. echo -e " mMMM: ${darkgrey}##############${default} :MMMm"
  437. echo -e " mMM ${lightyellow}nn${default} ${lightyellow}nn${default} ${lightyellow}nn${default} ${lightyellow}nn${default} MMm"
  438. echo -e " o ${lightyellow}nNNNNNNNn${default} ${lightyellow}nNNNNNNNn${default} o"
  439. echo -e " ${lightyellow}nNNNNNNNNNn${default} ${lightyellow}nNNNNNNNNNn${default}"
  440. echo -e " ${lightyellow}nNNNNNNNNNNN${default} ${lightyellow}NNNNNNNNNNNn${default}"
  441. echo -e " ${lightyellow}+NNNNNNNNN:${default} ${lightyellow}:NNNNNNNNN+${default}"
  442. echo -e " ${lightyellow}nNNNNNNN${default} /\ ${lightyellow}NNNNNNNn${default}"
  443. echo -e " ${lightyellow}nnnnn${default} db ${lightyellow}nnnnn${default}"
  444. echo -e ""
  445. echo -e "${lightyellow}888${default} ${lightyellow}d8b${default} ${default}.d8888b. .d8888b. 888b d888"
  446. echo -e "${lightyellow}888 Y8P ${default}d88P Y88b d88P Y88b 8888b d8888"
  447. echo -e "${lightyellow}888${default} ${default}888${default} 888 Y88b. 88888b.d88888"
  448. 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"
  449. 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"
  450. 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"
  451. 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"
  452. 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"
  453. echo -e ""
  454. }