fn_logs 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #!/bin/bash
  2. # LGSM fn_logs function
  3. # Author: Daniel Gibbs
  4. # Website: http://danielgibbs.co.uk
  5. # Version: 080214
  6. # Description: Acts as a log rotater, removing old logs.
  7. local modulename="Log Manager"
  8. if [ -n "${consolelog}" ]; then
  9. if [ ! -e "${consolelog}" ]; then
  10. touch "${consolelog}"
  11. fi
  12. fi
  13. # log manager will active if finds logs older than ${logdays}
  14. if [ $(find "${scriptlogdir}"/* -mtime +${logdays}|wc -l) -ne "0" ]; then
  15. fn_printdots "Starting"
  16. sleep 1
  17. fn_printok "Starting"
  18. fn_scriptlog "Starting"
  19. sleep 1
  20. echo -en "\n"
  21. fn_printinfo "Removing logs older than ${logdays} days"
  22. fn_scriptlog "Removing logs older than ${logdays} days"
  23. sleep 1
  24. echo -en "\n"
  25. if [ "${engine}" == "unreal2" ]; then
  26. find "${gamelogdir}"/* -mtime +${logdays}|tee >> "${scriptlog}"
  27. fi
  28. find "${scriptlogdir}"/* -mtime +${logdays}|tee >> "${scriptlog}"
  29. if
  30. if [ -n "${consolelog}" ]; then
  31. find "${consolelogdir}"/* -mtime +${logdays}|tee >> "${scriptlog}"
  32. fi
  33. if [ "${engine}" == "unreal2" ]; then
  34. gamecount=$(find "${scriptlogdir}"/* -mtime +${logdays}|wc -l)
  35. fi
  36. scriptcount=$(find "${scriptlogdir}"/* -mtime +${logdays}|wc -l)
  37. if [ -n "${consolelog}" ]; then
  38. consolecount=$(find "${consolelogdir}"/* -mtime +${logdays}|wc -l)
  39. fi
  40. count=$((${scriptcount} + ${consolecount}))
  41. if [ "${engine}" == "unreal2" ]; then
  42. count=$((${scriptcount} + ${consolecount} + ${gamecount}))
  43. else
  44. count=$((${scriptcount} + ${consolecount}))
  45. fi
  46. if [ "${engine}" == "unreal2" ]; then
  47. find "${gamelogdir}"/* -mtime +${logdays} -exec rm {} \;
  48. fi
  49. find "${scriptlogdir}"/* -mtime +${logdays} -exec rm {} \;
  50. if [ -n "${consolelog}" ]; then
  51. find "${consolelogdir}"/* -mtime +${logdays} -exec rm {} \;
  52. fi
  53. fn_printok "Removed ${count} log files"
  54. fn_scriptlog "Removed ${count} log files"
  55. sleep 1
  56. echo -en "\n"
  57. fi