diff --git a/includes/wireguard.php b/includes/wireguard.php index f6beb3dd..233dd33b 100755 --- a/includes/wireguard.php +++ b/includes/wireguard.php @@ -11,13 +11,14 @@ function DisplayWireGuardConfig() $parseFlag = true; if (!RASPI_MONITOR_ENABLED) { $optRules = isset($_POST['wgRules']) ? $_POST['wgRules'] : null; + $optInterface = isset($_POST['wgInterface']) ? $_POST['wgInterface'] : null; $optConf = isset($_POST['wgCnfOpt']) ? $_POST['wgCnfOpt'] : null; $optSrvEnable = isset($_POST['wgSrvEnable']) ? $_POST['wgSrvEnable'] : null; $optLogEnable = isset($_POST['wgLogEnable']) ? $_POST['wgLogEnable'] : null; if (isset($_POST['savewgsettings']) && $optConf == 'manual' && $optSrvEnable == 1 ) { SaveWireGuardConfig($status); } elseif (isset($_POST['savewgsettings']) && $optConf == 'upload' && is_uploaded_file($_FILES["wgFile"]["tmp_name"])) { - SaveWireGuardUpload($status, $_FILES['wgFile'], $optRules); + SaveWireGuardUpload($status, $_FILES['wgFile'], $optRules, $optInterface); } elseif (isset($_POST['savewgsettings']) && isset($_POST['wg_penabled']) ) { SaveWireGuardConfig($status); } elseif (isset($_POST['startwg'])) { @@ -77,12 +78,17 @@ function DisplayWireGuardConfig() } $peer_id = $peer_id ?? "1"; + // fetch available interfaces + exec("ip -o link show | awk -F': ' '{print $2}'", $interfaces); + sort($interfaces); + echo renderTemplate( "wireguard", compact( "status", "wg_state", "serviceStatus", "public_ip", + "interfaces", "optRules", "optLogEnable", "peer_id", @@ -110,9 +116,10 @@ function DisplayWireGuardConfig() * @param object $status * @param object $file * @param boolean $optRules + * @param string $optInterface * @return object $status */ -function SaveWireGuardUpload($status, $file, $optRules) +function SaveWireGuardUpload($status, $file, $optRules, $optInterface) { define('KB', 1024); $tmp_destdir = '/tmp/'; @@ -147,7 +154,7 @@ function SaveWireGuardUpload($status, $file, $optRules) $rules[] = 'PostDown = '.getDefaultNetValue('wireguard','server','PostDown'); $rules[] = ''; $rules = join(PHP_EOL, $rules); - $rules = preg_replace('/wlan0/m', $_SESSION['ap_interface'], $rules); + $rules = preg_replace('/wlan0/m', $optInterface, $rules); $tmp_contents = preg_replace('/^\s*$/ms', $rules, $tmp_contents, 1); file_put_contents($tmp_wgconfig, $tmp_contents); } diff --git a/locale/en_US/LC_MESSAGES/messages.mo b/locale/en_US/LC_MESSAGES/messages.mo index 799128f8..222464eb 100644 Binary files a/locale/en_US/LC_MESSAGES/messages.mo and b/locale/en_US/LC_MESSAGES/messages.mo differ diff --git a/locale/en_US/LC_MESSAGES/messages.po b/locale/en_US/LC_MESSAGES/messages.po index da8c34b3..208959ce 100644 --- a/locale/en_US/LC_MESSAGES/messages.po +++ b/locale/en_US/LC_MESSAGES/messages.po @@ -1355,14 +1355,14 @@ msgstr "Upload a WireGuard config" msgid "This option uploads and installs an existing WireGuard .conf file on this device." msgstr "This option uploads and installs an existing WireGuard .conf file on this device." -msgid "Apply iptables rules for AP interface" -msgstr "Apply iptables rules for AP interface" +msgid "Apply iptables rules to the selected interface" +msgstr "Apply iptables rules to the selected interface" -msgid "Recommended if you wish to forward network traffic from the wg0 interface to clients connected on the AP interface." -msgstr "Recommended if you wish to forward network traffic from the wg0 interface to clients connected on the AP interface." +msgid "Recommended if you wish to forward network traffic from the wg0 interface to clients connected on a desired interface. The active AP interface is the default." +msgstr "Recommended if you wish to forward network traffic from the wg0 interface to clients connected on a desired interface. The active AP interface is the default." -msgid "This option adds iptables Postup and PostDown rules for the configured AP interface (%s)." -msgstr "This option adds iptables Postup and PostDown rules for the configured AP interface (%s)." +msgid "This option adds iptables Postup and PostDown rules for the interface selected below." +msgstr "This option adds iptables Postup and PostDown rules for the interface selected below." msgid "Select WireGuard configuration file (.conf)" msgstr "Select WireGuard configuration file (.conf)" diff --git a/templates/wg/general.php b/templates/wg/general.php index bdc4d812..9b8b8246 100644 --- a/templates/wg/general.php +++ b/templates/wg/general.php @@ -35,17 +35,20 @@
/> - - "> + + ">

- iptables Postup and PostDown rules for the configured AP interface (%s)."), $_SESSION['ap_interface']) ?> + iptables Postup and PostDown rules for the interface selected below."); ?> +

+ +

-
+