Get sort working in saub tables
This commit is contained in:
parent
1adf1b83db
commit
6e81bf1600
@ -432,16 +432,12 @@ def split_timestamp_and_data(log_entry: str) -> list:
|
|||||||
return [timestamp, rest_of_data]
|
return [timestamp, rest_of_data]
|
||||||
|
|
||||||
def render_sub_table(table_title,table_headers,found_values):
|
def render_sub_table(table_title,table_headers,found_values):
|
||||||
# NeedNOTE: also need to compute the percentages here.
|
|
||||||
# and sort it.
|
|
||||||
# Get the total
|
# Get the total
|
||||||
total_sum = sum(found_values.values())
|
total_sum = sum(found_values.values())
|
||||||
# and add in list with second element the percentage
|
# and add in list with second element the percentage
|
||||||
# Create a list of tuples with each tuple containing (key, value, percentage)
|
# Create a list of tuples with each tuple containing (key, value, percentage)
|
||||||
sub_result = [(key, value, f"{round(value / total_sum * 100, 2)}%") for key, value in found_values.items()]
|
sub_result = [(key, value, f"{round(value / total_sum * 100, 2)}") for key, value in found_values.items()]
|
||||||
sub_result.sort(key=lambda x: x[2], reverse=True) # Sort by percentage in descending order
|
sub_result.sort(key=lambda x: float(x[2]), reverse=True) # Sort by percentage in descending order
|
||||||
|
|
||||||
|
|
||||||
sub_template_path = template_dir+'mailstats-sub-table.html.pt'
|
sub_template_path = template_dir+'mailstats-sub-table.html.pt'
|
||||||
# Load the template
|
# Load the template
|
||||||
with open(sub_template_path, 'r') as template_file:
|
with open(sub_template_path, 'r') as template_file:
|
||||||
@ -459,41 +455,6 @@ def render_sub_table(table_title,table_headers,found_values):
|
|||||||
return rendered_html
|
return rendered_html
|
||||||
|
|
||||||
|
|
||||||
# def get_spamassassin_version():
|
|
||||||
# """
|
|
||||||
# Get the installed SpamAssassin version.
|
|
||||||
|
|
||||||
# Returns:
|
|
||||||
# str: Version number of SpamAssassin if installed, otherwise an error message.
|
|
||||||
# """
|
|
||||||
# try:
|
|
||||||
# result = subprocess.run(['spamassassin', '--version'], capture_output=True, text=True)
|
|
||||||
# if result.returncode == 0:
|
|
||||||
# version_line = result.stdout.split('\n')[0]
|
|
||||||
# version = version_line.split()[1]
|
|
||||||
# return version
|
|
||||||
# else:
|
|
||||||
# return "SpamAssassin is not installed or an error occurred."
|
|
||||||
# except Exception as e:
|
|
||||||
# return f"Error: {e}"
|
|
||||||
|
|
||||||
# def get_clamav_version():
|
|
||||||
# """
|
|
||||||
# Get the installed ClamAV version.
|
|
||||||
|
|
||||||
# Returns:
|
|
||||||
# str: Version number of ClamAV if installed, otherwise an error message.
|
|
||||||
# """
|
|
||||||
# try:
|
|
||||||
# result = subprocess.run(['clamscan', '--version'], capture_output=True, text=True)
|
|
||||||
# if result.returncode == 0:
|
|
||||||
# version_line = result.stdout.split('\n')[0]
|
|
||||||
# version = version_line.split()[1]
|
|
||||||
# return version
|
|
||||||
# else:
|
|
||||||
# return "ClamAV is not installed or an error occurred."
|
|
||||||
# except Exception as e:
|
|
||||||
# return f"Error: {e}"
|
|
||||||
|
|
||||||
def read_html_from_file(filepath):
|
def read_html_from_file(filepath):
|
||||||
"""
|
"""
|
||||||
@ -705,9 +666,6 @@ if __name__ == "__main__":
|
|||||||
EMailSMTPUser = get_value(ConfigDB,"mailstats","EmailUser") #None = default => no authenticatioon needed
|
EMailSMTPUser = get_value(ConfigDB,"mailstats","EmailUser") #None = default => no authenticatioon needed
|
||||||
EMailSMTPPassword = get_value(ConfigDB,"mailstats","EmailPassword")
|
EMailSMTPPassword = get_value(ConfigDB,"mailstats","EmailPassword")
|
||||||
|
|
||||||
#spamassassin_version = get_spamassassin_version()
|
|
||||||
#clamav_version = get_clamav_version()
|
|
||||||
|
|
||||||
FetchmailIP = '127.0.0.200'; #Apparent Ip address of fetchmail deliveries
|
FetchmailIP = '127.0.0.200'; #Apparent Ip address of fetchmail deliveries
|
||||||
WebmailIP = '127.0.0.1'; #Apparent Ip of Webmail sender
|
WebmailIP = '127.0.0.1'; #Apparent Ip of Webmail sender
|
||||||
localhost = 'localhost'; #Apparent sender for webmail
|
localhost = 'localhost'; #Apparent sender for webmail
|
||||||
@ -783,17 +741,12 @@ if __name__ == "__main__":
|
|||||||
totalexamined += 1
|
totalexamined += 1
|
||||||
if isThonny:
|
if isThonny:
|
||||||
print_progress_bar(i, sorted_len, prefix='Scanning for main table:', suffix='Complete', length=50)
|
print_progress_bar(i, sorted_len, prefix='Scanning for main table:', suffix='Complete', length=50)
|
||||||
#print(f"{i*100/len}%")
|
|
||||||
# Count of in which hour it falls
|
# Count of in which hour it falls
|
||||||
#hour = datetime.datetime.strptime(timestamp, '%Y-%m-%d %H:%M:%S').strftime('%Y-%m-%d %H')
|
|
||||||
# Parse the timestamp string into a datetime object
|
# Parse the timestamp string into a datetime object
|
||||||
dt = timestamp
|
dt = timestamp
|
||||||
hour = dt.hour
|
hour = dt.hour
|
||||||
# parse the data
|
# parse the data
|
||||||
#print(data)
|
|
||||||
parsed_data = parse_data(data)
|
parsed_data = parse_data(data)
|
||||||
#print(f"parsed_data['action']:{parsed_data['action']}\n")
|
|
||||||
|
|
||||||
# Increment Count in which headings it falls
|
# Increment Count in which headings it falls
|
||||||
#Hourly count and column total
|
#Hourly count and column total
|
||||||
columnCounts_2d[hour][Hour] += 1
|
columnCounts_2d[hour][Hour] += 1
|
||||||
|
Loading…
Reference in New Issue
Block a user