[
    {
        "file_name": "firewall_manager.py",
        "file_content": "import subprocess\nimport os\n\ndef add_inbound_rule(program_path, rule_name):\n    \"\"\"\n    Adds an inbound rule to the Windows Firewall to allow a specific program to pass through.\n\n    :param program_path: Path to the executable of the program.\n    :param rule_name: Name of the rule to be added.\n    \"\"\"\n    command = f'netsh advfirewall firewall add rule name=\"{rule_name}\" dir=in action=allow program=\"{program_path}\" enable=yes'\n    subprocess.run(command, shell=True, check=True)\n\ndef remove_inbound_rule(rule_name):\n    \"\"\"\n    Removes an inbound rule from the Windows Firewall.\n\n    :param rule_name: Name of the rule to be removed.\n    \"\"\"\n    command = f'netsh advfirewall firewall delete rule name=\"{rule_name}\"'\n    subprocess.run(command, shell=True, check=True)\n\ndef list_inbound_rules():\n    \"\"\"\n    Lists all inbound rules in the Windows Firewall.\n    \"\"\"\n    command = 'netsh advfirewall firewall show rule name=all dir=in'\n    result = subprocess.run(command, shell=True, capture_output=True, text=True, check=True)\n    print(result.stdout)"
    },
    {
        "file_name": "main.py",
        "file_content": "from firewall_manager import add_inbound_rule, remove_inbound_rule, list_inbound_rules\n\ndef main():\n    # Example usage\n    program_path = r\"C:\\Path\\To\\Your\\Program.exe\"\n    rule_name = \"AllowMyProgram\"\n\n    # Add a new inbound rule\n    add_inbound_rule(program_path, rule_name)\n\n    # List all inbound rules to verify\n    list_inbound_rules()\n\n    # Remove the inbound rule\n    remove_inbound_rule(rule_name)\n\nif __name__ == \"__main__\":\n    main()"
    },
    {
        "file_name": "README.md",
        "file_content": "# Windows Firewall Rule Manager\n\nThis Python script provides a simple way to manage inbound rules in the Windows Firewall. It allows you to add, remove, and list inbound rules for specific programs.\n\n## Files\n\n- `firewall_manager.py`: Contains functions to interact with the Windows Firewall.\n- `main.py`: Example usage of the `firewall_manager` functions.\n\n## Usage\n\n1. Ensure you have Python installed on your system.\n2. Place the `firewall_manager.py` and `main.py` files in the same directory.\n3. Run `main.py` to see the example usage.\n\n## Functions\n\n### `add_inbound_rule(program_path, rule_name)`\nAdds an inbound rule to allow a specific program to pass through the firewall.\n\n- `program_path`: Path to the executable of the program.\n- `rule_name`: Name of the rule to be added.\n\n### `remove_inbound_rule(rule_name)`\nRemoves an inbound rule from the Windows Firewall.\n\n- `rule_name`: Name of the rule to be removed.\n\n### `list_inbound_rules()`\nLists all inbound rules in the Windows Firewall."
    }
]