from collections import defaultdict
import re
import argparse 

def extract_log_lines(input_file, output_file, search_text):
    """
    Extracts lines containing a specific text from a log file and saves them to a new file.
    
    :param input_file: Path to the original log file.
    :param output_file: Path to save the extracted lines.
    :param search_text: Text to search for in each line.
    """
    pattern = re.compile(r".*action: (\d), value_target: (-?1)") # Regex to capture the search text, action and value
    action_value_count = defaultdict(int)
    
    with open(input_file, "r", encoding="utf-8") as infile, open(output_file, "w", encoding="utf-8") as outfile:
        count = 0
        for line in infile:
            if search_text in line:
                outfile.write(line)
                match = pattern.search(line)
                # Capture the action and value from the line
                if match:
                    action, value = match.group(1), match.group(2) # Note that match.group(0) is the entire match
                    action_value_count[(action, value)] += 1
                
        print("Extraction complete!")
        outfile.write("\nAction Value Counts:\n")
        print("Action Value Counts:")
        for (action, value), count in sorted(action_value_count.items(), key=lambda x: (x[0], x[1])):
            outfile.write(f"Action: {action}, Value: {value}, Count: {count}\n")
            print(f"Action: {action}, Value: {value}, Count: {count}")

if __name__ == "__main__":
    parser = argparse.ArgumentParser(description="Extract log lines containing specific text.")
    parser.add_argument("input_file", help="Path to the input log file")
    parser.add_argument("search_text", help="Text to search for in the log file")
    parser.add_argument("-o", "--output", default="filtered_logs.log", help="Output file name (default: filtered_logs.log)")

    args = parser.parse_args()

    # Call function with user inputs
    extract_log_lines(args.input_file, args.output, args.search_text)