diff options
author | Christian Breunig <christian@breunig.cc> | 2024-06-10 19:35:21 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-06-10 19:35:21 +0200 |
commit | f118452e4e14628cfacec147ae2192a5de9cb970 (patch) | |
tree | 8f3ada65a4c565374e17c252d08a3394a2eecdb5 | |
parent | 50a5a29ae128795d718a3ed6878887d49544f54d (diff) | |
parent | d6108d6e0a14f32d7ee28df01b5a4fcd678acada (diff) | |
download | vyos-1x-f118452e4e14628cfacec147ae2192a5de9cb970.tar.gz vyos-1x-f118452e4e14628cfacec147ae2192a5de9cb970.zip |
Merge pull request #3621 from sever-sever/T6442
T6442: CGNAT add log for address allocation
-rw-r--r-- | interface-definitions/nat_cgnat.xml.in | 6 | ||||
-rwxr-xr-x | src/conf_mode/nat_cgnat.py | 30 |
2 files changed, 36 insertions, 0 deletions
diff --git a/interface-definitions/nat_cgnat.xml.in b/interface-definitions/nat_cgnat.xml.in index fce5e655d..71f4d67b0 100644 --- a/interface-definitions/nat_cgnat.xml.in +++ b/interface-definitions/nat_cgnat.xml.in @@ -8,6 +8,12 @@ <priority>221</priority> </properties> <children> + <leafNode name="log-allocation"> + <properties> + <help>Log IP address and port allocation</help> + <valueless/> + </properties> + </leafNode> <node name="pool"> <properties> <help>External and internal pool parameters</help> diff --git a/src/conf_mode/nat_cgnat.py b/src/conf_mode/nat_cgnat.py index d429f6e21..cb336a35c 100755 --- a/src/conf_mode/nat_cgnat.py +++ b/src/conf_mode/nat_cgnat.py @@ -16,9 +16,11 @@ import ipaddress import jmespath +import logging import os from sys import exit +from logging.handlers import SysLogHandler from vyos.config import Config from vyos.template import render @@ -32,6 +34,18 @@ airbag.enable() nftables_cgnat_config = '/run/nftables-cgnat.nft' +# Logging +logger = logging.getLogger('cgnat') +logger.setLevel(logging.DEBUG) + +syslog_handler = SysLogHandler(address="/dev/log") +syslog_handler.setLevel(logging.INFO) + +formatter = logging.Formatter('%(name)s: %(message)s') +syslog_handler.setFormatter(formatter) + +logger.addHandler(syslog_handler) + class IPOperations: def __init__(self, ip_prefix: str): @@ -356,6 +370,22 @@ def apply(config): return None cmd(f'nft --file {nftables_cgnat_config}') + # Logging allocations + if 'log_allocation' in config: + allocations = config['proto_map_elements'] + allocations = allocations.split(',') + for allocation in allocations: + try: + # Split based on the delimiters used in the nft data format + internal_host, rest = allocation.split(' : ') + external_host, port_range = rest.split(' . ') + # Log the parsed data + logger.info( + f"Internal host: {internal_host.lstrip()}, external host: {external_host}, Port range: {port_range}") + except ValueError as e: + # Log error message + logger.error(f"Error processing line '{allocation}': {e}") + if __name__ == '__main__': try: |