fn_logs 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  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 [ -n "${consolelog}" ]; then
  30. find "${consolelogdir}"/* -mtime +${logdays}|tee >> "${scriptlog}"
  31. fi
  32. if [ "${engine}" == "unreal2" ]; then
  33. gamecount=$(find "${scriptlogdir}"/* -mtime +${logdays}|wc -l)
  34. fi
  35. scriptcount=$(find "${scriptlogdir}"/* -mtime +${logdays}|wc -l)
  36. if [ -n "${consolelog}" ]; then
  37. consolecount=$(find "${consolelogdir}"/* -mtime +${logdays}|wc -l)
  38. fi
  39. count=$((${scriptcount} + ${consolecount}))
  40. if [ "${engine}" == "unreal2" ]; then
  41. count=$((${scriptcount} + ${consolecount} + ${gamecount}))
  42. else
  43. count=$((${scriptcount} + ${consolecount}))
  44. fi
  45. if [ "${engine}" == "unreal2" ]; then
  46. find "${gamelogdir}"/* -mtime +${logdays} -exec rm {} \;
  47. fi
  48. find "${scriptlogdir}"/* -mtime +${logdays} -exec rm {} \;
  49. if [ -n "${consolelog}" ]; then
  50. find "${consolelogdir}"/* -mtime +${logdays} -exec rm {} \;
  51. fi
  52. fn_printok "Removed ${count} log files"
  53. fn_scriptlog "Removed ${count} log files"
  54. sleep 1
  55. echo -en "\n"
  56. fi