config.py 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. #!/usr/bin/env python3
  2. from logging import basicConfig, DEBUG, INFO, WARN, ERROR, CRITICAL, getLogger
  3. from logging.handlers import TimedRotatingFileHandler
  4. from os.path import exists, join, dirname, abspath
  5. from json import loads, dumps
  6. from json.decoder import JSONDecodeError
  7. import pendulum
  8. # Get the full path for this file
  9. currentdir = dirname(abspath(__file__))
  10. # Target log file
  11. TARGET = join("bbs", join("logs", "enigma-bbs.log"))
  12. # Setup logging
  13. # DEBUG, INFO, WARN, ERROR, CRITICAL
  14. basicConfig(
  15. level=DEBUG,
  16. format="%(asctime)s - %(filename)s (%(lineno)d) - %(name)s - %(levelname)s - %(message)s",
  17. handlers=[
  18. TimedRotatingFileHandler(
  19. filename=join(currentdir, "failUser.log"),
  20. when="midnight",
  21. backupCount=1,
  22. ),
  23. #logging.StreamHandler(stream=sys.stdout),
  24. ],
  25. )
  26. log = getLogger("failUser")
  27. # Config JSON
  28. def save_config(con):
  29. with open("failUser.cfg", "w") as f:
  30. f.write(dumps(con, indent=4, sort_keys=False))
  31. def load_config():
  32. if not exists("failUser.cfg"):
  33. now = pendulum.now().to_datetime_string()
  34. defaults = {
  35. # Target enigma logs
  36. "target": "bbs/logs/enigma-bbs.log",
  37. # block_time in hours
  38. "block_time": 4,
  39. # Last unblock
  40. "last_unblock": now,
  41. # List of bad users to detect and block
  42. "bad_users": [
  43. "root",
  44. "postgres",
  45. "mysql",
  46. "apache",
  47. "nginx",
  48. ],
  49. }
  50. save_config(defaults)
  51. return defaults
  52. else:
  53. with open("failUser.cfg", "r") as f:
  54. config = loads(f.read())
  55. return config
  56. # blocks in json
  57. def add_block(ip, time):
  58. # first load in all blocks
  59. try:
  60. with open("blocks.json", "r") as f:
  61. blocks = loads(f.read())
  62. except FileNotFoundError:
  63. blocks = {}
  64. pass
  65. # add ip and time
  66. #log.debug("Added {0} in blocks.json".format(ip))
  67. blocks[ip] = time
  68. # update blocks
  69. with open("blocks.json", "w") as f:
  70. f.write(dumps(blocks))
  71. def rm_block(ip):
  72. # first load all blocks
  73. try:
  74. with open("blocks.json", "r") as f:
  75. blocks = loads(f.read())
  76. except FileNotFoundError:
  77. return
  78. try:
  79. if blocks[ip]:
  80. #log.debug("Removed {0} in blocks.json".format(ip))
  81. del blocks[ip]
  82. # update blocks
  83. with open("blocks.json", "w") as f:
  84. f.write(dumps(blocks))
  85. except KeyError:
  86. log.debug("Unable to unblock '{0}'".format(ip))
  87. def check_blocks():
  88. # return a list of ips exceeding block_time in config
  89. result = []
  90. conf = load_config()
  91. # load in blocks
  92. try:
  93. with open("blocks.json", "r") as f:
  94. blocks = loads(f.read())
  95. except FileNotFoundError:
  96. return
  97. now = pendulum.now()
  98. for ip in blocks:
  99. dt = pendulum.parse(blocks[ip])
  100. #log.debug("IP={0} TIME_LEFT={1}".format(ip, abs(now.diff(dt, False).in_hours())))
  101. if now.diff(dt).in_hours() > conf["block_time"]:
  102. # Oops, this ip needs to be unblocked
  103. result.append(ip)
  104. if result:
  105. return result