|
|
|
#!/usr/bin/env python3
|
|
|
|
import funct
|
|
|
|
import sql
|
|
|
|
from jinja2 import Environment, FileSystemLoader
|
|
|
|
env = Environment(loader=FileSystemLoader('templates/'), autoescape=True)
|
|
|
|
template = env.get_template('waf.html')
|
|
|
|
|
|
|
|
form = funct.form
|
|
|
|
manage_rules = form.getvalue('manage_rules')
|
|
|
|
waf_rule_id = form.getvalue('waf_rule_id')
|
|
|
|
waf_rule_file = ''
|
|
|
|
servers_waf = ''
|
|
|
|
autorefresh = 0
|
|
|
|
config_read = ''
|
|
|
|
serv = ''
|
|
|
|
rules = ''
|
|
|
|
cfg = ''
|
|
|
|
|
|
|
|
print('Content-type: text/html\n')
|
|
|
|
funct.check_login(service=1)
|
|
|
|
funct.page_for_admin(level=2)
|
|
|
|
|
|
|
|
try:
|
|
|
|
user, user_id, role, token, servers, user_services = funct.get_users_params()
|
|
|
|
except Exception:
|
|
|
|
pass
|
|
|
|
|
|
|
|
if manage_rules == '1':
|
|
|
|
serv = funct.is_ip_or_dns(form.getvalue('serv'))
|
|
|
|
funct.check_is_server_in_group(serv)
|
|
|
|
title = "Manage rules - Web application firewall"
|
|
|
|
rules = sql.select_waf_rules(serv)
|
|
|
|
elif waf_rule_id:
|
|
|
|
serv = funct.is_ip_or_dns(form.getvalue('serv'))
|
|
|
|
funct.check_is_server_in_group(serv)
|
|
|
|
title = 'Edit a WAF rule'
|
|
|
|
waf_rule_file = sql.select_waf_rule_by_id(waf_rule_id)
|
|
|
|
configs_dir = sql.get_setting('tmp_config_path')
|
|
|
|
cfg = configs_dir + serv + "-" + funct.get_data('config') + "-" + waf_rule_file
|
|
|
|
error = funct.get_config(serv, cfg, waf=1, waf_rule_file=waf_rule_file)
|
|
|
|
|
|
|
|
try:
|
|
|
|
conf = open(cfg, "r")
|
|
|
|
config_read = conf.read()
|
|
|
|
conf.close()
|
|
|
|
except IOError:
|
|
|
|
print('Cannot read imported config file')
|
|
|
|
else:
|
|
|
|
title = "Web application firewall"
|
|
|
|
servers_waf = sql.select_waf_servers_metrics(user_id.value)
|
|
|
|
autorefresh = 1
|
|
|
|
|
|
|
|
template = template.render(h2=1, title=title,
|
|
|
|
autorefresh=autorefresh,
|
|
|
|
role=role,
|
|
|
|
user=user,
|
|
|
|
serv=serv,
|
|
|
|
servers=servers_waf,
|
|
|
|
servers_all=servers,
|
|
|
|
manage_rules=manage_rules,
|
|
|
|
rules=rules,
|
|
|
|
user_services=user_services,
|
|
|
|
waf_rule_file=waf_rule_file,
|
|
|
|
waf_rule_id=waf_rule_id,
|
|
|
|
config=config_read,
|
|
|
|
cfg=cfg,
|
|
|
|
token=token)
|
|
|
|
print(template)
|