diff --git a/applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js b/applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js
index 5de9932eb8..905b12f230 100644
--- a/applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js
+++ b/applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js
@@ -24,7 +24,7 @@ const tailscaleSettingsConf = [
[form.Flag, 'nosnat', _('Disable SNAT'), _('Disable Source NAT (SNAT) for traffic to advertised routes. Most users should leave this unchecked.'), { rmempty: false }],
[form.Flag, 'shields_up', _('Shields Up'), _('When enabled, blocks all inbound connections from the Tailscale network.'), { rmempty: false }],
[form.Flag, 'ssh', _('Enable Tailscale SSH'), _('Allow connecting to this device through the SSH function of Tailscale.'), { rmempty: false }],
- [form.Flag, 'disable_magic_dns', _('Disable MagicDNS'), _('Use system DNS instead of MagicDNS.'), { rmempty: false }],
+ [form.ListValue, 'dns_mode', _('DNS Mode'), _('Controls how Tailscale DNS is handled.')+'
'+_('Disabled: system DNS only.')+'
'+_('MagicDNS: Tailscale overrides resolv.conf.')+'
'+_('OpenWrt Forward: MagicDNS via dnsmasq forwarding.(Only support ts.net)'), { values: [['disabled', _('Disabled')], ['magicdns', 'MagicDNS'], ['openwrt_forward', _('OpenWrt Forward')]], rmempty: false }],
[form.Flag, 'enable_relay', _('Enable Peer Relay'), _('Enable this device as a Peer Relay server. Requires a public IP and an UDP port open on the router.'), { rmempty: false }]
];
@@ -322,12 +322,20 @@ return view.extend({
uci.set('tailscale', 'settings', 'shields_up', ((settings_from_rpc.shields_up || false) ? '1' : '0'));
uci.set('tailscale', 'settings', 'runwebclient', ((settings_from_rpc.runwebclient || false) ? '1' : '0'));
uci.set('tailscale', 'settings', 'nosnat', ((settings_from_rpc.nosnat || false) ? '1' : '0'));
- uci.set('tailscale', 'settings', 'disable_magic_dns', ((settings_from_rpc.disable_magic_dns || false) ? '1' : '0'));
+ uci.set('tailscale', 'settings', 'dns_mode', 'disabled');
uci.set('tailscale', 'settings', 'daemon_reduce_memory', '0');
uci.set('tailscale', 'settings', 'daemon_mtu', '');
return uci.save();
}
+ }).then(function() {
+ // Migrate from old disable_magic_dns to dns_mode if needed
+ if (uci.get('tailscale', 'settings', 'dns_mode') === null) {
+ var oldMagicDns = uci.get('tailscale', 'settings', 'disable_magic_dns');
+ uci.set('tailscale', 'settings', 'dns_mode', oldMagicDns === '1' ? 'disabled' : 'magicdns');
+ uci.unset('tailscale', 'settings', 'disable_magic_dns');
+ return uci.save();
+ }
}).then(function() {
return [status, settings_from_rpc, subroutes];
});
@@ -423,17 +431,17 @@ return view.extend({
+'
'+_('and enables Masquerading and MSS Clamping (MTU fix) to ensure stable connections.');
fwBtn.inputstyle = 'action';
fwBtn.onclick = function() {
- const btn = this;
- btn.disabled = true;
return callSetupFirewall().then(function(res) {
- const msg = res?.message || _('Firewall configuration applied.');
- ui.addNotification(null, E('p', {}, msg), 'info');
- }).catch(function(err) {
- ui.addNotification(null, E('p', {}, _('Failed to configure firewall: %s').format(err?.message || err || 'Unknown error')), 'error');
- }).finally(function() {
- btn.disabled = false;
+ const msg = res?.message || _('Firewall configuration applied.');
+ ui.addNotification(null, E('p', {}, msg), 'info');
+ }).catch(function(err) {
+ ui.addNotification(null, E('p', {}, _('Failed to configure firewall: %s').format(err?.message || err || 'Unknown error')), 'error');
+ }).then(function() {
+ return new Promise(function(resolve) {
+ window.setTimeout(resolve, 3000);
});
- };
+ });
+ };
const helpTitle = s.taboption('general', form.DummyValue, '_help_title');
helpTitle.title = _('How to enable Site-to-Site?');
@@ -492,7 +500,7 @@ return view.extend({
}
// Display a prompt message in the new window
const doc = loginWindow.document;
- doc.body.innerHTML =
+ doc.body.innerHTML =
'
' + _('Tailscale Login') + '
' +
'' + _('Requesting Tailscale login URL... Please wait.') + '
' +
'' + _('This can take up to 30 seconds.') + '
';
@@ -511,7 +519,7 @@ return view.extend({
loginWindow.location.href = res.url;
} else {
// If it fails, inform the user and they can close the new tab
- doc.body.innerHTML =
+ doc.body.innerHTML =
'' + _('Error') + '
' +
'' + _('Failed to get login URL. You may close this tab.') + '
';
ui.addTimeLimitedNotification(null, [ E('p', _('Failed to get login URL: Invalid response from server.')) ], 7000, 'error');
@@ -526,13 +534,13 @@ return view.extend({
const confirmationContent = E([
E('p', {}, _('Are you sure you want to log out?')
+'
'+_('This will disconnect this device from your Tailnet and require you to re-authenticate.')),
-
+
E('div', { 'style': 'text-align: right; margin-top: 1em;' }, [
E('button', {
'class': 'cbi-button',
'click': ui.hideModal
}, _('Cancel')),
- ' ',
+ ' ',
E('button', {
'class': 'cbi-button cbi-button-negative',
'click': function() {
diff --git a/applications/luci-app-tailscale-community/po/es/community.po b/applications/luci-app-tailscale-community/po/es/community.po
index 20597eecd9..9a64b4890b 100644
--- a/applications/luci-app-tailscale-community/po/es/community.po
+++ b/applications/luci-app-tailscale-community/po/es/community.po
@@ -15,17 +15,17 @@ msgstr ""
msgid "(Experimental) Reduce Memory Usage"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:444
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:452
msgid "1. Select \"Accept Routes\" (to access remote devices)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:445
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:453
msgid ""
"2. In \"Advertise Routes\", select your local subnet (to allow remote "
"devices to access this LAN)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:446
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:454
msgid "3. Click \"Auto Configure Firewall\" (to allow traffic forwarding)."
msgstr ""
@@ -33,7 +33,7 @@ msgstr ""
msgid "Accept Routes"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:453
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:461
msgid "Account Settings"
msgstr ""
@@ -41,11 +41,11 @@ msgstr ""
msgid "Advertise Exit Node"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:412
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
msgid "Advertise Routes"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:412
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
msgid ""
"Advertise subnet routes behind this device. Select from the detected subnets "
"below or enter custom routes (comma-separated)."
@@ -67,33 +67,33 @@ msgstr ""
msgid "Allow user access to tailscale"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:527
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:535
msgid "Are you sure you want to log out?"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:428
msgid "Auto Configure Firewall"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:534
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:542
msgid "Cancel"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:478
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:486
msgid "Click to Log out account on this device."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:457
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:465
msgid "Click to get a login URL for this device."
msgstr ""
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:167
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:244
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:367
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:375
msgid "Collecting data ..."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:553
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:561
msgid "Confirm Logout"
msgstr ""
@@ -101,32 +101,36 @@ msgstr ""
msgid "Connection Info"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:490
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "Controls how Tailscale DNS is handled."
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:498
msgid ""
"Could not open a new tab. Please check if your browser or an extension "
"blocked the pop-up."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:462
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:470
msgid "Custom Login Server"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:470
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:478
msgid "Custom Login Server Auth Key"
msgstr ""
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "DNS Mode"
+msgstr "Modo DNS"
+
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:21
msgid "Declare this device as an Exit Node."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:556
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:564
msgid "Devices List"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
-msgid "Disable MagicDNS"
-msgstr ""
-
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:24
msgid "Disable SNAT"
msgstr ""
@@ -137,11 +141,16 @@ msgid ""
"should leave this unchecked."
msgstr ""
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:227
msgid "Disabled"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:479
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "Disabled: system DNS only."
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:487
msgid "Disconnect from Tailscale and expire current node key."
msgstr ""
@@ -183,7 +192,7 @@ msgid ""
"performance (set GOGC=10)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:515
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:523
msgid "Error"
msgstr ""
@@ -199,14 +208,14 @@ msgstr ""
msgid "Error reading cached DERP region map: %s"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:421
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:429
msgid ""
"Essential configuration for Subnet Routing (Site-to-Site) and Exit Node "
"features."
msgstr ""
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:287
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:396
msgid "Exit Node"
msgstr ""
@@ -215,19 +224,19 @@ msgid ""
"Expose a web interface on port 5252 for managing this node over Tailscale."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:432
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:438
msgid "Failed to configure firewall: %s"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:516
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:524
msgid "Failed to get login URL. You may close this tab."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:521
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:529
msgid "Failed to get login URL: %s"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:517
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:525
msgid "Failed to get login URL: Invalid response from server."
msgstr ""
@@ -235,11 +244,11 @@ msgstr ""
msgid "Firewall Mode"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:429
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:435
msgid "Firewall configuration applied."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:376
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:384
msgid "General Settings"
msgstr ""
@@ -247,16 +256,16 @@ msgstr ""
msgid "Hostname"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:439
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:447
msgid "How to enable Site-to-Site?"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:458
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:466
msgid ""
"If the timeout is displayed, you can refresh the page and click Login again."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:472
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:480
msgid ""
"If you are using custom login server but not providing an Auth Key, will "
"redirect to the login page without pre-filling the key."
@@ -266,7 +275,7 @@ msgstr ""
msgid "Invalid Date"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:422
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:430
msgid ""
"It automatically creates the tailscale interface, sets up firewall zones for "
"LAN <-> Tailscale forwarding,"
@@ -284,27 +293,31 @@ msgstr ""
msgid "Last Seen"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:464
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:472
msgid "Leave blank for default Tailscale control plane."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:540
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:548
msgid "Logging out..."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:456
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:464
msgid "Login"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:477
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:550
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:485
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:558
msgid "Logout"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:547
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:555
msgid "Logout failed: %s"
msgstr ""
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "MagicDNS: Tailscale overrides resolv.conf."
+msgstr ""
+
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:88
msgid "N/A"
msgstr ""
@@ -317,7 +330,7 @@ msgstr ""
msgid "No peer devices found."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:389
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:397
msgid "None"
msgstr ""
@@ -337,19 +350,27 @@ msgstr ""
msgid "Online"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:463
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "OpenWrt Forward"
+msgstr "Reenvío OpenWrt"
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "OpenWrt Forward: MagicDNS via dnsmasq forwarding.(Only support ts.net)"
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:471
msgid ""
"Optional: Specify a custom control server URL (e.g., a Headscale instance, "
"%s)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:471
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:479
msgid ""
"Optional: Specify an authentication key for the custom control server. Leave "
"blank if not required."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:380
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
msgid "Peer Relay Port"
msgstr ""
@@ -357,9 +378,9 @@ msgstr ""
msgid "Please use the login button in the settings below to authenticate."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:500
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:540
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:508
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:514
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:548
msgid "Please wait."
msgstr ""
@@ -371,16 +392,16 @@ msgstr ""
msgid "RX"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:500
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:508
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:514
msgid "Requesting Login URL..."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:497
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:505
msgid "Requesting Tailscale login URL... Please wait."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:396
msgid ""
"Select an exit node from the list. If enabled, Allow LAN Access is enabled "
"implicitly."
@@ -407,7 +428,7 @@ msgstr ""
msgid "Status"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:544
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:552
msgid "Successfully logged out."
msgstr ""
@@ -427,7 +448,7 @@ msgstr ""
msgid "Tailnet Name"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:341
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:349
#: applications/luci-app-tailscale-community/root/usr/share/luci/menu.d/luci-app-tailscale-community.json:3
msgid "Tailscale"
msgstr ""
@@ -448,11 +469,11 @@ msgstr ""
msgid "Tailscale IPv6"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:496
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:504
msgid "Tailscale Login"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:341
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:349
msgid ""
"Tailscale is a mesh VPN solution that makes it easy to connect your devices "
"securely. This configuration page allows you to manage Tailscale settings on "
@@ -463,17 +484,17 @@ msgstr ""
msgid "Tailscale status error"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:498
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
msgid "This can take up to 30 seconds."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:528
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:536
msgid ""
"This will disconnect this device from your Tailnet and require you to re-"
"authenticate."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:381
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:389
msgid ""
"UDP port for the Peer Relay service. Open this port on your router firewall/"
"NAT."
@@ -482,15 +503,11 @@ msgstr ""
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:121
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:148
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:151
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:521
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:547
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:529
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:555
msgid "Unknown error"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
-msgid "Use system DNS instead of MagicDNS."
-msgstr ""
-
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:226
msgid "Version"
msgstr ""
@@ -504,7 +521,7 @@ msgstr ""
msgid "When using the exit node, access to the local LAN is allowed."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:447
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:455
msgid ""
"[Important] Log in to the Tailscale admin console and manually enable "
"\"Subnet Routes\" for this device."
@@ -514,7 +531,7 @@ msgstr ""
msgid "ago"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:423
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:431
msgid ""
"and enables Masquerading and MSS Clamping (MTU fix) to ensure stable "
"connections."
diff --git a/applications/luci-app-tailscale-community/po/templates/community.pot b/applications/luci-app-tailscale-community/po/templates/community.pot
index 1289c7dde3..6eafe92cd2 100644
--- a/applications/luci-app-tailscale-community/po/templates/community.pot
+++ b/applications/luci-app-tailscale-community/po/templates/community.pot
@@ -5,17 +5,17 @@ msgstr "Content-Type: text/plain; charset=UTF-8"
msgid "(Experimental) Reduce Memory Usage"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:444
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:452
msgid "1. Select \"Accept Routes\" (to access remote devices)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:445
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:453
msgid ""
"2. In \"Advertise Routes\", select your local subnet (to allow remote "
"devices to access this LAN)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:446
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:454
msgid "3. Click \"Auto Configure Firewall\" (to allow traffic forwarding)."
msgstr ""
@@ -23,7 +23,7 @@ msgstr ""
msgid "Accept Routes"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:453
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:461
msgid "Account Settings"
msgstr ""
@@ -31,11 +31,11 @@ msgstr ""
msgid "Advertise Exit Node"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:412
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
msgid "Advertise Routes"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:412
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
msgid ""
"Advertise subnet routes behind this device. Select from the detected subnets "
"below or enter custom routes (comma-separated)."
@@ -57,33 +57,33 @@ msgstr ""
msgid "Allow user access to tailscale"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:527
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:535
msgid "Are you sure you want to log out?"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:428
msgid "Auto Configure Firewall"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:534
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:542
msgid "Cancel"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:478
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:486
msgid "Click to Log out account on this device."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:457
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:465
msgid "Click to get a login URL for this device."
msgstr ""
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:167
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:244
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:367
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:375
msgid "Collecting data ..."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:553
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:561
msgid "Confirm Logout"
msgstr ""
@@ -91,32 +91,36 @@ msgstr ""
msgid "Connection Info"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:490
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "Controls how Tailscale DNS is handled."
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:498
msgid ""
"Could not open a new tab. Please check if your browser or an extension "
"blocked the pop-up."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:462
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:470
msgid "Custom Login Server"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:470
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:478
msgid "Custom Login Server Auth Key"
msgstr ""
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "DNS Mode"
+msgstr ""
+
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:21
msgid "Declare this device as an Exit Node."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:556
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:564
msgid "Devices List"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
-msgid "Disable MagicDNS"
-msgstr ""
-
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:24
msgid "Disable SNAT"
msgstr ""
@@ -127,11 +131,16 @@ msgid ""
"should leave this unchecked."
msgstr ""
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:227
msgid "Disabled"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:479
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "Disabled: system DNS only."
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:487
msgid "Disconnect from Tailscale and expire current node key."
msgstr ""
@@ -173,7 +182,7 @@ msgid ""
"performance (set GOGC=10)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:515
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:523
msgid "Error"
msgstr ""
@@ -189,14 +198,14 @@ msgstr ""
msgid "Error reading cached DERP region map: %s"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:421
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:429
msgid ""
"Essential configuration for Subnet Routing (Site-to-Site) and Exit Node "
"features."
msgstr ""
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:287
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:396
msgid "Exit Node"
msgstr ""
@@ -205,19 +214,19 @@ msgid ""
"Expose a web interface on port 5252 for managing this node over Tailscale."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:432
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:438
msgid "Failed to configure firewall: %s"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:516
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:524
msgid "Failed to get login URL. You may close this tab."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:521
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:529
msgid "Failed to get login URL: %s"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:517
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:525
msgid "Failed to get login URL: Invalid response from server."
msgstr ""
@@ -225,11 +234,11 @@ msgstr ""
msgid "Firewall Mode"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:429
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:435
msgid "Firewall configuration applied."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:376
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:384
msgid "General Settings"
msgstr ""
@@ -237,16 +246,16 @@ msgstr ""
msgid "Hostname"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:439
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:447
msgid "How to enable Site-to-Site?"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:458
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:466
msgid ""
"If the timeout is displayed, you can refresh the page and click Login again."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:472
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:480
msgid ""
"If you are using custom login server but not providing an Auth Key, will "
"redirect to the login page without pre-filling the key."
@@ -256,7 +265,7 @@ msgstr ""
msgid "Invalid Date"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:422
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:430
msgid ""
"It automatically creates the tailscale interface, sets up firewall zones for "
"LAN <-> Tailscale forwarding,"
@@ -274,27 +283,31 @@ msgstr ""
msgid "Last Seen"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:464
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:472
msgid "Leave blank for default Tailscale control plane."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:540
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:548
msgid "Logging out..."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:456
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:464
msgid "Login"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:477
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:550
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:485
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:558
msgid "Logout"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:547
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:555
msgid "Logout failed: %s"
msgstr ""
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "MagicDNS: Tailscale overrides resolv.conf."
+msgstr ""
+
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:88
msgid "N/A"
msgstr ""
@@ -307,7 +320,7 @@ msgstr ""
msgid "No peer devices found."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:389
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:397
msgid "None"
msgstr ""
@@ -327,19 +340,27 @@ msgstr ""
msgid "Online"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:463
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "OpenWrt Forward"
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "OpenWrt Forward: MagicDNS via dnsmasq forwarding.(Only support ts.net)"
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:471
msgid ""
"Optional: Specify a custom control server URL (e.g., a Headscale instance, "
"%s)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:471
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:479
msgid ""
"Optional: Specify an authentication key for the custom control server. Leave "
"blank if not required."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:380
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
msgid "Peer Relay Port"
msgstr ""
@@ -347,9 +368,9 @@ msgstr ""
msgid "Please use the login button in the settings below to authenticate."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:500
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:540
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:508
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:514
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:548
msgid "Please wait."
msgstr ""
@@ -361,16 +382,16 @@ msgstr ""
msgid "RX"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:500
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:508
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:514
msgid "Requesting Login URL..."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:497
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:505
msgid "Requesting Tailscale login URL... Please wait."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:396
msgid ""
"Select an exit node from the list. If enabled, Allow LAN Access is enabled "
"implicitly."
@@ -397,7 +418,7 @@ msgstr ""
msgid "Status"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:544
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:552
msgid "Successfully logged out."
msgstr ""
@@ -417,7 +438,7 @@ msgstr ""
msgid "Tailnet Name"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:341
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:349
#: applications/luci-app-tailscale-community/root/usr/share/luci/menu.d/luci-app-tailscale-community.json:3
msgid "Tailscale"
msgstr ""
@@ -438,11 +459,11 @@ msgstr ""
msgid "Tailscale IPv6"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:496
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:504
msgid "Tailscale Login"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:341
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:349
msgid ""
"Tailscale is a mesh VPN solution that makes it easy to connect your devices "
"securely. This configuration page allows you to manage Tailscale settings on "
@@ -453,17 +474,17 @@ msgstr ""
msgid "Tailscale status error"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:498
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
msgid "This can take up to 30 seconds."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:528
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:536
msgid ""
"This will disconnect this device from your Tailnet and require you to re-"
"authenticate."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:381
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:389
msgid ""
"UDP port for the Peer Relay service. Open this port on your router firewall/"
"NAT."
@@ -472,15 +493,11 @@ msgstr ""
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:121
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:148
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:151
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:521
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:547
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:529
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:555
msgid "Unknown error"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
-msgid "Use system DNS instead of MagicDNS."
-msgstr ""
-
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:226
msgid "Version"
msgstr ""
@@ -494,7 +511,7 @@ msgstr ""
msgid "When using the exit node, access to the local LAN is allowed."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:447
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:455
msgid ""
"[Important] Log in to the Tailscale admin console and manually enable "
"\"Subnet Routes\" for this device."
@@ -504,7 +521,7 @@ msgstr ""
msgid "ago"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:423
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:431
msgid ""
"and enables Masquerading and MSS Clamping (MTU fix) to ensure stable "
"connections."
diff --git a/applications/luci-app-tailscale-community/po/zh_Hans/community.po b/applications/luci-app-tailscale-community/po/zh_Hans/community.po
index 8863c90f64..9791c57d5b 100644
--- a/applications/luci-app-tailscale-community/po/zh_Hans/community.po
+++ b/applications/luci-app-tailscale-community/po/zh_Hans/community.po
@@ -5,17 +5,17 @@ msgstr "Content-Type: text/plain; charset=UTF-8\n"
msgid "(Experimental) Reduce Memory Usage"
msgstr "(实验性) 减少内存使用"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:444
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:452
msgid "1. Select \"Accept Routes\" (to access remote devices)."
msgstr "1. 勾选 接受路由 (接受远程设备访问)。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:445
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:453
msgid ""
"2. In \"Advertise Routes\", select your local subnet (to allow remote "
"devices to access this LAN)."
msgstr "2. 在 通告路由 选择本设备的局域网段 (让远程设备能访问你)。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:446
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:454
msgid "3. Click \"Auto Configure Firewall\" (to allow traffic forwarding)."
msgstr "3. 点击 自动配置防火墙 (打通防火墙转发)。"
@@ -23,7 +23,7 @@ msgstr "3. 点击 自动配置防火墙 (打通防火墙转发)。"
msgid "Accept Routes"
msgstr "接受路由"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:453
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:461
msgid "Account Settings"
msgstr "账户设置"
@@ -31,11 +31,11 @@ msgstr "账户设置"
msgid "Advertise Exit Node"
msgstr "通告出口节点"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:412
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
msgid "Advertise Routes"
msgstr "通告路由"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:412
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
msgid ""
"Advertise subnet routes behind this device. Select from the detected subnets "
"below or enter custom routes (comma-separated)."
@@ -58,33 +58,33 @@ msgstr "允许通过 Tailscale 的 SSH 功能连接到此设备。"
msgid "Allow user access to tailscale"
msgstr "允许用户访问 Tailscale"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:527
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:535
msgid "Are you sure you want to log out?"
msgstr "您确定要登出吗?"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:428
msgid "Auto Configure Firewall"
msgstr "自动配置防火墙"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:534
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:542
msgid "Cancel"
msgstr "取消"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:478
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:486
msgid "Click to Log out account on this device."
msgstr "点击以登出此设备上的账户。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:457
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:465
msgid "Click to get a login URL for this device."
msgstr "点击获取此设备的登录 URL。"
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:167
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:244
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:367
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:375
msgid "Collecting data ..."
msgstr "正在收集数据..."
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:553
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:561
msgid "Confirm Logout"
msgstr "确认登出"
@@ -92,32 +92,36 @@ msgstr "确认登出"
msgid "Connection Info"
msgstr "连接信息"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:490
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "Controls how Tailscale DNS is handled."
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:498
msgid ""
"Could not open a new tab. Please check if your browser or an extension "
"blocked the pop-up."
msgstr "无法打开新标签页。请检查您的浏览器或扩展程序是否阻止了弹出窗口。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:462
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:470
msgid "Custom Login Server"
msgstr "自定义登录服务器"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:470
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:478
msgid "Custom Login Server Auth Key"
msgstr "自定义登录服务器认证密钥"
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "DNS Mode"
+msgstr "DNS 模式"
+
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:21
msgid "Declare this device as an Exit Node."
msgstr "将此设备声明为出口节点。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:556
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:564
msgid "Devices List"
msgstr "设备列表"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
-msgid "Disable MagicDNS"
-msgstr "禁用 MagicDNS"
-
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:24
msgid "Disable SNAT"
msgstr "禁用 SNAT"
@@ -128,11 +132,16 @@ msgid ""
"should leave this unchecked."
msgstr "为通告路由的流量禁用源地址转换 (SNAT)。大多数用户应保持此项不勾选。"
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:227
msgid "Disabled"
msgstr "已禁用"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:479
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "Disabled: system DNS only."
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:487
msgid "Disconnect from Tailscale and expire current node key."
msgstr "从 Tailscale 断开连接并使当前节点密钥过期。"
@@ -176,7 +185,7 @@ msgid ""
"performance (set GOGC=10)."
msgstr "启用此选项可以减少内存使用,但可能会牺牲一些性能 (设置 GOGC=10)。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:515
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:523
msgid "Error"
msgstr "错误"
@@ -192,14 +201,14 @@ msgstr "获取 DERP 区域地图时出错: %s"
msgid "Error reading cached DERP region map: %s"
msgstr "读取缓存的 DERP 区域地图时出错: %s"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:421
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:429
msgid ""
"Essential configuration for Subnet Routing (Site-to-Site) and Exit Node "
"features."
msgstr "子网路由(局域网间互通)和出口节点的基本配置。"
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:287
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:396
msgid "Exit Node"
msgstr "出口节点"
@@ -208,19 +217,19 @@ msgid ""
"Expose a web interface on port 5252 for managing this node over Tailscale."
msgstr "在端口 5252 上暴露一个 Web 界面,用于通过 Tailscale 管理此节点。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:432
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:438
msgid "Failed to configure firewall: %s"
msgstr "获取防火墙设置失败: %s"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:516
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:524
msgid "Failed to get login URL. You may close this tab."
msgstr "获取登录 URL 失败。您可以关闭此标签页。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:521
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:529
msgid "Failed to get login URL: %s"
msgstr "获取登录 URL 失败: %s"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:517
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:525
msgid "Failed to get login URL: Invalid response from server."
msgstr "获取登录 URL 失败: 服务器响应无效。"
@@ -228,11 +237,11 @@ msgstr "获取登录 URL 失败: 服务器响应无效。"
msgid "Firewall Mode"
msgstr "防火墙模式"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:429
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:435
msgid "Firewall configuration applied."
msgstr "已应用防火墙配置"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:376
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:384
msgid "General Settings"
msgstr "常规设置"
@@ -240,16 +249,16 @@ msgstr "常规设置"
msgid "Hostname"
msgstr "主机名"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:439
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:447
msgid "How to enable Site-to-Site?"
msgstr "如何实现站点到站点(即多局域网互通)?"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:458
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:466
msgid ""
"If the timeout is displayed, you can refresh the page and click Login again."
msgstr "如果显示超时,您可以刷新页面并再次点击登录。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:472
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:480
msgid ""
"If you are using custom login server but not providing an Auth Key, will "
"redirect to the login page without pre-filling the key."
@@ -261,7 +270,7 @@ msgstr ""
msgid "Invalid Date"
msgstr "无效日期"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:422
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:430
msgid ""
"It automatically creates the tailscale interface, sets up firewall zones for "
"LAN <-> Tailscale forwarding,"
@@ -279,27 +288,31 @@ msgstr "已登出"
msgid "Last Seen"
msgstr "上次在线"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:464
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:472
msgid "Leave blank for default Tailscale control plane."
msgstr "留空以使用默认的 Tailscale 控制平面。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:540
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:548
msgid "Logging out..."
msgstr "正在登出..."
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:456
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:464
msgid "Login"
msgstr "登录"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:477
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:550
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:485
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:558
msgid "Logout"
msgstr "登出"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:547
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:555
msgid "Logout failed: %s"
msgstr "登出失败: %s"
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "MagicDNS: Tailscale overrides resolv.conf."
+msgstr ""
+
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:88
msgid "N/A"
msgstr "不可用"
@@ -312,7 +325,7 @@ msgstr "未运行"
msgid "No peer devices found."
msgstr "未找到节点设备。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:389
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:397
msgid "None"
msgstr "无"
@@ -332,19 +345,27 @@ msgstr "离线"
msgid "Online"
msgstr "在线"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:463
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "OpenWrt Forward"
+msgstr "OpenWrt 转发"
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "OpenWrt Forward: MagicDNS via dnsmasq forwarding.(Only support ts.net)"
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:471
msgid ""
"Optional: Specify a custom control server URL (e.g., a Headscale instance, "
"%s)."
msgstr "可选:指定一个自定义控制服务器 URL (例如,一个 Headscale 实例, %s)。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:471
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:479
msgid ""
"Optional: Specify an authentication key for the custom control server. Leave "
"blank if not required."
msgstr "可选:为自定义控制服务器指定一个认证密钥。如果不需要,请留空。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:380
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
msgid "Peer Relay Port"
msgstr "DERP端口"
@@ -352,9 +373,9 @@ msgstr "DERP端口"
msgid "Please use the login button in the settings below to authenticate."
msgstr "请使用下方设置中的登录按钮进行认证。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:500
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:540
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:508
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:514
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:548
msgid "Please wait."
msgstr "请稍候。"
@@ -366,16 +387,16 @@ msgstr "正在运行"
msgid "RX"
msgstr "接收"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:500
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:508
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:514
msgid "Requesting Login URL..."
msgstr "正在请求登录 URL..."
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:497
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:505
msgid "Requesting Tailscale login URL... Please wait."
msgstr "正在请求 Tailscale 登录 URL... 请稍候。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:396
msgid ""
"Select an exit node from the list. If enabled, Allow LAN Access is enabled "
"implicitly."
@@ -402,7 +423,7 @@ msgstr "开启防护 (Shields Up)"
msgid "Status"
msgstr "状态"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:544
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:552
msgid "Successfully logged out."
msgstr "登出成功。"
@@ -422,7 +443,7 @@ msgstr "发送"
msgid "Tailnet Name"
msgstr "Tailnet 名称"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:341
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:349
#: applications/luci-app-tailscale-community/root/usr/share/luci/menu.d/luci-app-tailscale-community.json:3
msgid "Tailscale"
msgstr "Tailscale"
@@ -443,11 +464,11 @@ msgstr "Tailscale IPv4"
msgid "Tailscale IPv6"
msgstr "Tailscale IPv6"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:496
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:504
msgid "Tailscale Login"
msgstr "Tailscale 登录"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:341
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:349
msgid ""
"Tailscale is a mesh VPN solution that makes it easy to connect your devices "
"securely. This configuration page allows you to manage Tailscale settings on "
@@ -460,17 +481,17 @@ msgstr ""
msgid "Tailscale status error"
msgstr "Tailscale 状态异常"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:498
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
msgid "This can take up to 30 seconds."
msgstr "此过程最多可能需要 30 秒。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:528
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:536
msgid ""
"This will disconnect this device from your Tailnet and require you to re-"
"authenticate."
msgstr "这将使此设备从您的 Tailnet 断开连接,并需要您重新进行身份验证。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:381
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:389
msgid ""
"UDP port for the Peer Relay service. Open this port on your router firewall/"
"NAT."
@@ -479,15 +500,11 @@ msgstr "DERP的UDP端口号。需要在防火墙/NAT规则中开放该端口。"
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:121
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:148
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:151
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:521
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:547
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:529
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:555
msgid "Unknown error"
msgstr "未知错误"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
-msgid "Use system DNS instead of MagicDNS."
-msgstr "使用系统 DNS 而不是 MagicDNS。"
-
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:226
msgid "Version"
msgstr "版本"
@@ -501,7 +518,7 @@ msgstr "启用后,将阻止来自 Tailscale 网络的所有入站连接。"
msgid "When using the exit node, access to the local LAN is allowed."
msgstr "使用出口节点时,允许访问本地局域网。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:447
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:455
msgid ""
"[Important] Log in to the Tailscale admin console and manually enable "
"\"Subnet Routes\" for this device."
@@ -511,7 +528,7 @@ msgstr "【重要】 登录 Tailscale 控制平面,在设备设置中手动授
msgid "ago"
msgstr "前"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:423
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:431
msgid ""
"and enables Masquerading and MSS Clamping (MTU fix) to ensure stable "
"connections."
diff --git a/applications/luci-app-tailscale-community/po/zh_Hant/community.po b/applications/luci-app-tailscale-community/po/zh_Hant/community.po
index 0bb011fca4..c566827b29 100644
--- a/applications/luci-app-tailscale-community/po/zh_Hant/community.po
+++ b/applications/luci-app-tailscale-community/po/zh_Hant/community.po
@@ -5,17 +5,17 @@ msgstr "Content-Type: text/plain; charset=UTF-8\n"
msgid "(Experimental) Reduce Memory Usage"
msgstr "(實驗性) 減少記憶體使用"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:444
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:452
msgid "1. Select \"Accept Routes\" (to access remote devices)."
msgstr "1. 勾選 接受路由 (接受遠端裝置訪問)。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:445
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:453
msgid ""
"2. In \"Advertise Routes\", select your local subnet (to allow remote "
"devices to access this LAN)."
msgstr "2. 在 通告路由 選擇本裝置的區域網段 (讓遠端裝置能訪問你)。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:446
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:454
msgid "3. Click \"Auto Configure Firewall\" (to allow traffic forwarding)."
msgstr "3. 點選 自動配置防火牆 (打通防火牆轉發)。"
@@ -23,7 +23,7 @@ msgstr "3. 點選 自動配置防火牆 (打通防火牆轉發)。"
msgid "Accept Routes"
msgstr "接受路由"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:453
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:461
msgid "Account Settings"
msgstr "賬戶設定"
@@ -31,11 +31,11 @@ msgstr "賬戶設定"
msgid "Advertise Exit Node"
msgstr "通告出口節點"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:412
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
msgid "Advertise Routes"
msgstr "通告路由"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:412
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
msgid ""
"Advertise subnet routes behind this device. Select from the detected subnets "
"below or enter custom routes (comma-separated)."
@@ -58,33 +58,33 @@ msgstr "允許透過 Tailscale 的 SSH 功能連線到此裝置。"
msgid "Allow user access to tailscale"
msgstr "允許使用者訪問 Tailscale"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:527
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:535
msgid "Are you sure you want to log out?"
msgstr "您確定要登出嗎?"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:420
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:428
msgid "Auto Configure Firewall"
msgstr "自動配置防火牆"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:534
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:542
msgid "Cancel"
msgstr "取消"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:478
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:486
msgid "Click to Log out account on this device."
msgstr "點選以登出此裝置上的賬戶。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:457
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:465
msgid "Click to get a login URL for this device."
msgstr "點選獲取此裝置的登入 URL。"
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:167
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:244
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:367
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:375
msgid "Collecting data ..."
msgstr "正在收集資料..."
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:553
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:561
msgid "Confirm Logout"
msgstr "確認登出"
@@ -92,32 +92,36 @@ msgstr "確認登出"
msgid "Connection Info"
msgstr "連線資訊"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:490
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "Controls how Tailscale DNS is handled."
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:498
msgid ""
"Could not open a new tab. Please check if your browser or an extension "
"blocked the pop-up."
msgstr "無法開啟新標籤頁。請檢查您的瀏覽器或擴充套件程式是否阻止了彈出視窗。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:462
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:470
msgid "Custom Login Server"
msgstr "自定義登入伺服器"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:470
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:478
msgid "Custom Login Server Auth Key"
msgstr "自定義登入伺服器認證金鑰"
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "DNS Mode"
+msgstr "DNS 模式"
+
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:21
msgid "Declare this device as an Exit Node."
msgstr "將此裝置宣告為出口節點。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:556
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:564
msgid "Devices List"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
-msgid "Disable MagicDNS"
-msgstr "停用 MagicDNS"
-
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:24
msgid "Disable SNAT"
msgstr "停用 SNAT"
@@ -128,11 +132,16 @@ msgid ""
"should leave this unchecked."
msgstr "為通告路由的流量停用源地址轉換 (SNAT)。大多數使用者應保持此項不勾選。"
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:227
msgid "Disabled"
msgstr "已停用"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:479
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "Disabled: system DNS only."
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:487
msgid "Disconnect from Tailscale and expire current node key."
msgstr "從 Tailscale 斷開連線並使當前節點金鑰過期。"
@@ -174,7 +183,7 @@ msgid ""
"performance (set GOGC=10)."
msgstr "啟用此選項可以減少記憶體使用,但可能會犧牲一些效能 (設定 GOGC=10)。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:515
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:523
msgid "Error"
msgstr "錯誤"
@@ -190,14 +199,14 @@ msgstr "獲取 DERP 區域地圖時出錯: %s"
msgid "Error reading cached DERP region map: %s"
msgstr "讀取快取的 DERP 區域地圖時出錯: %s"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:421
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:429
msgid ""
"Essential configuration for Subnet Routing (Site-to-Site) and Exit Node "
"features."
msgstr "子網路由和出口節點的基本配置。"
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:287
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:396
msgid "Exit Node"
msgstr "出口節點"
@@ -206,19 +215,19 @@ msgid ""
"Expose a web interface on port 5252 for managing this node over Tailscale."
msgstr "在埠 5252 上暴露一個 Web 介面,用於透過 Tailscale 管理此節點。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:432
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:438
msgid "Failed to configure firewall: %s"
msgstr "獲取防火牆設定失敗: %s"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:516
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:524
msgid "Failed to get login URL. You may close this tab."
msgstr "獲取登入 URL 失敗。您可以關閉此標籤頁。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:521
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:529
msgid "Failed to get login URL: %s"
msgstr "獲取登入 URL 失敗: %s"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:517
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:525
msgid "Failed to get login URL: Invalid response from server."
msgstr "獲取登入 URL 失敗: 伺服器響應無效。"
@@ -226,11 +235,11 @@ msgstr "獲取登入 URL 失敗: 伺服器響應無效。"
msgid "Firewall Mode"
msgstr "防火牆模式"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:429
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:435
msgid "Firewall configuration applied."
msgstr "已應用防火牆配置"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:376
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:384
msgid "General Settings"
msgstr "常規設定"
@@ -238,16 +247,16 @@ msgstr "常規設定"
msgid "Hostname"
msgstr "主機名"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:439
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:447
msgid "How to enable Site-to-Site?"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:458
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:466
msgid ""
"If the timeout is displayed, you can refresh the page and click Login again."
msgstr "如果顯示超時,您可以重新整理頁面並再次點選登入。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:472
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:480
msgid ""
"If you are using custom login server but not providing an Auth Key, will "
"redirect to the login page without pre-filling the key."
@@ -259,7 +268,7 @@ msgstr ""
msgid "Invalid Date"
msgstr "無效日期"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:422
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:430
msgid ""
"It automatically creates the tailscale interface, sets up firewall zones for "
"LAN <-> Tailscale forwarding,"
@@ -279,27 +288,31 @@ msgstr "已登出"
msgid "Last Seen"
msgstr "上次線上"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:464
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:472
msgid "Leave blank for default Tailscale control plane."
msgstr "留空以使用預設的 Tailscale 控制平面。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:540
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:548
msgid "Logging out..."
msgstr "正在登出..."
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:456
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:464
msgid "Login"
msgstr "登入"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:477
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:550
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:485
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:558
msgid "Logout"
msgstr "登出"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:547
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:555
msgid "Logout failed: %s"
msgstr "登出失敗: %s"
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "MagicDNS: Tailscale overrides resolv.conf."
+msgstr ""
+
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:88
msgid "N/A"
msgstr "N/A"
@@ -312,7 +325,7 @@ msgstr "未執行"
msgid "No peer devices found."
msgstr "未找到對等裝置。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:389
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:397
msgid "None"
msgstr ""
@@ -332,19 +345,27 @@ msgstr "離線"
msgid "Online"
msgstr "線上"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:463
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "OpenWrt Forward"
+msgstr "OpenWrt 轉發"
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
+msgid "OpenWrt Forward: MagicDNS via dnsmasq forwarding.(Only support ts.net)"
+msgstr ""
+
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:471
msgid ""
"Optional: Specify a custom control server URL (e.g., a Headscale instance, "
"%s)."
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:471
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:479
msgid ""
"Optional: Specify an authentication key for the custom control server. Leave "
"blank if not required."
msgstr "可選:為自定義控制伺服器指定一個認證金鑰。如果不需要,請留空。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:380
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
msgid "Peer Relay Port"
msgstr ""
@@ -352,9 +373,9 @@ msgstr ""
msgid "Please use the login button in the settings below to authenticate."
msgstr "請使用下方設定中的登入按鈕進行認證。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:500
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:540
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:508
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:514
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:548
msgid "Please wait."
msgstr "請稍候。"
@@ -366,16 +387,16 @@ msgstr "正在執行"
msgid "RX"
msgstr "接收"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:500
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:508
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:514
msgid "Requesting Login URL..."
msgstr "正在請求登入 URL..."
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:497
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:505
msgid "Requesting Tailscale login URL... Please wait."
msgstr "正在請求 Tailscale 登入 URL... 請稍候。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:388
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:396
msgid ""
"Select an exit node from the list. If enabled, Allow LAN Access is enabled "
"implicitly."
@@ -402,7 +423,7 @@ msgstr "開啟防護 (Shields Up)"
msgid "Status"
msgstr "狀態"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:544
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:552
msgid "Successfully logged out."
msgstr "登出成功。"
@@ -422,7 +443,7 @@ msgstr "傳送"
msgid "Tailnet Name"
msgstr "Tailnet 名稱"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:341
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:349
#: applications/luci-app-tailscale-community/root/usr/share/luci/menu.d/luci-app-tailscale-community.json:3
msgid "Tailscale"
msgstr "Tailscale"
@@ -443,11 +464,11 @@ msgstr "Tailscale IPv4"
msgid "Tailscale IPv6"
msgstr "Tailscale IPv6"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:496
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:504
msgid "Tailscale Login"
msgstr "Tailscale 登入"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:341
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:349
msgid ""
"Tailscale is a mesh VPN solution that makes it easy to connect your devices "
"securely. This configuration page allows you to manage Tailscale settings on "
@@ -460,17 +481,17 @@ msgstr ""
msgid "Tailscale status error"
msgstr ""
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:498
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:506
msgid "This can take up to 30 seconds."
msgstr "此過程最多可能需要 30 秒。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:528
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:536
msgid ""
"This will disconnect this device from your Tailnet and require you to re-"
"authenticate."
msgstr "這將使此裝置從您的 Tailnet 斷開連線,並需要您重新進行身份驗證。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:381
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:389
msgid ""
"UDP port for the Peer Relay service. Open this port on your router firewall/"
"NAT."
@@ -479,15 +500,11 @@ msgstr ""
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:121
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:148
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:151
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:521
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:547
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:529
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:555
msgid "Unknown error"
msgstr "未知錯誤"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:27
-msgid "Use system DNS instead of MagicDNS."
-msgstr "使用系統 DNS 而不是 MagicDNS。"
-
#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:226
msgid "Version"
msgstr "版本"
@@ -501,7 +518,7 @@ msgstr "啟用後,將阻止來自 Tailscale 網路的所有入站連線。"
msgid "When using the exit node, access to the local LAN is allowed."
msgstr "使用出口節點時,允許訪問本地區域網。"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:447
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:455
msgid ""
"[Important] Log in to the Tailscale admin console and manually enable "
"\"Subnet Routes\" for this device."
@@ -511,7 +528,7 @@ msgstr "【重要】 登入 Tailscale 控制平面,在裝置設定中手動授
msgid "ago"
msgstr "前"
-#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:423
+#: applications/luci-app-tailscale-community/htdocs/luci-static/resources/view/tailscale.js:431
msgid ""
"and enables Masquerading and MSS Clamping (MTU fix) to ensure stable "
"connections."
diff --git a/applications/luci-app-tailscale-community/root/etc/init.d/tailscale-settings b/applications/luci-app-tailscale-community/root/etc/init.d/tailscale-settings
index e1ed75a26f..3851328f7c 100755
--- a/applications/luci-app-tailscale-community/root/etc/init.d/tailscale-settings
+++ b/applications/luci-app-tailscale-community/root/etc/init.d/tailscale-settings
@@ -21,6 +21,51 @@ version_gte() {
return $?
}
+# Add/remove DNS forward entry in dnsmasq for MagicDNS via OpenWrt
+setup_tailscale_dns_forward() {
+ if [ ! -x /usr/sbin/tailscale ] && [ ! -x /usr/bin/tailscale ]; then
+ return 0
+ fi
+
+ local entry="/.ts.net/100.100.100.100"
+ local found=0
+
+ # Check if entry already exists in dnsmasq
+ if uci -q show dhcp.@dnsmasq[0].server 2>/dev/null | grep -Fqx "dhcp.@dnsmasq[0].server='$entry'"; then
+ found=1
+ fi
+
+ if [ "$found" = "0" ]; then
+ uci add_list dhcp.@dnsmasq[0].server="$entry"
+ uci commit dhcp
+ /etc/init.d/dnsmasq reload 2>/dev/null || /etc/init.d/dnsmasq restart 2>/dev/null
+ logger -t "$NAME" "Added DNS forward: $entry"
+ fi
+}
+
+remove_tailscale_dns_forward() {
+ local entry="/.ts.net/100.100.100.100"
+ local idx=0
+ local removed=0
+ while true; do
+ local val
+ val=$(uci -q get dhcp.@dnsmasq[0].server."${idx}" 2>/dev/null)
+ [ -z "$val" ] && break
+ if [ "$val" = "$entry" ]; then
+ uci -q del_list dhcp.@dnsmasq[0].server="$entry"
+ removed=1
+ break
+ fi
+ idx=$((idx + 1))
+ done
+
+ if [ "$removed" = "1" ]; then
+ uci commit dhcp
+ /etc/init.d/dnsmasq reload 2>/dev/null || /etc/init.d/dnsmasq restart 2>/dev/null
+ logger -t "$NAME" "Removed Tailscale DNS forward entry: $entry"
+ fi
+}
+
apply_settings() {
local ts_bin
if [ -x /usr/sbin/tailscale ]; then
@@ -35,7 +80,7 @@ apply_settings() {
config_load tailscale
local accept_routes advertise_exit_node exit_node exit_node_allow_lan_access
- local ssh disable_magic_dns shields_up runwebclient nosnat hostname
+ local ssh shields_up runwebclient nosnat hostname
local enable_relay relay_server_port
config_get accept_routes settings accept_routes '0'
@@ -43,7 +88,7 @@ apply_settings() {
config_get exit_node settings exit_node ''
config_get exit_node_allow_lan_access settings exit_node_allow_lan_access '0'
config_get ssh settings ssh '0'
- config_get disable_magic_dns settings disable_magic_dns '0'
+ config_get dns_mode settings dns_mode 'disabled'
config_get shields_up settings shields_up '0'
config_get runwebclient settings runwebclient '0'
config_get nosnat settings nosnat '0'
@@ -89,10 +134,22 @@ apply_settings() {
&& set -- "$@" --ssh=true \
|| set -- "$@" --ssh=false
- # --accept-dns (inverse of disable_magic_dns)
- [ "$disable_magic_dns" = "1" ] \
- && set -- "$@" --accept-dns=false \
- || set -- "$@" --accept-dns=true
+ # --accept-dns based on dns_mode
+ case "$dns_mode" in
+ magicdns)
+ set -- "$@" --accept-dns=true
+ remove_tailscale_dns_forward
+ ;;
+ openwrt_forward)
+ set -- "$@" --accept-dns=false
+ setup_tailscale_dns_forward
+ ;;
+ *)
+ # disabled (default)
+ set -- "$@" --accept-dns=false
+ remove_tailscale_dns_forward
+ ;;
+ esac
# --shields-up
[ "$shields_up" = "1" ] \
diff --git a/applications/luci-app-tailscale-community/root/usr/share/luci/menu.d/luci-app-tailscale-community.json b/applications/luci-app-tailscale-community/root/usr/share/luci/menu.d/luci-app-tailscale-community.json
index 70c90695cf..49fc630011 100644
--- a/applications/luci-app-tailscale-community/root/usr/share/luci/menu.d/luci-app-tailscale-community.json
+++ b/applications/luci-app-tailscale-community/root/usr/share/luci/menu.d/luci-app-tailscale-community.json
@@ -1,5 +1,5 @@
{
- "admin/services/tailscale": {
+ "admin/vpn/tailscale": {
"title": "Tailscale",
"order": 90,
"action": {
diff --git a/applications/luci-app-tailscale-community/root/usr/share/rpcd/ucode/tailscale.uc b/applications/luci-app-tailscale-community/root/usr/share/rpcd/ucode/tailscale.uc
index 3bb4aff7ef..8e2b7aa56a 100755
--- a/applications/luci-app-tailscale-community/root/usr/share/rpcd/ucode/tailscale.uc
+++ b/applications/luci-app-tailscale-community/root/usr/share/rpcd/ucode/tailscale.uc
@@ -123,7 +123,7 @@ methods.get_settings = {
settings.ssh = status_data?.RunSSH || false;
settings.runwebclient = status_data?.RunWebClient || false;
settings.nosnat = status_data?.NoSNAT || false;
- settings.disable_magic_dns = !status_data?.CorpDNS || false;
+ settings.dns_mode = uci.get('tailscale', 'settings', 'dns_mode') || 'disabled';
settings.fw_mode = split(uci.get('tailscale', 'settings', 'fw_mode'),' ')[0] || 'nftables';
}
}
@@ -254,21 +254,18 @@ methods.setup_firewall = {
}
// 2. config Firewall Zone
- let fw_all = uci.get_all('firewall');
let ts_zone_section = null;
let fwd_lan_to_ts = false;
let fwd_ts_to_lan = false;
- for (let sec_key in fw_all) {
- let s = fw_all[sec_key];
- if (s['.type'] == 'zone' && s['name'] == 'tailscale') {
- ts_zone_section = sec_key;
- }
- if (s['.type'] == 'forwarding') {
- if (s.src == 'lan' && s.dest == 'tailscale') fwd_lan_to_ts = true;
- if (s.src == 'tailscale' && s.dest == 'lan') fwd_ts_to_lan = true;
- }
- }
+ uci.foreach('firewall', 'zone', function(s) {
+ if (s['name'] == 'tailscale')
+ ts_zone_section = s['.name'];
+ });
+ uci.foreach('firewall', 'forwarding', function(s) {
+ if (s['src'] == 'lan' && s['dest'] == 'tailscale') fwd_lan_to_ts = true;
+ if (s['src'] == 'tailscale' && s['dest'] == 'lan') fwd_ts_to_lan = true;
+ });
if (ts_zone_section == null) {
let zid = uci.add('firewall', 'zone');
@@ -293,7 +290,7 @@ methods.setup_firewall = {
// check if 'tailscale' is already in the list
for (let n in net_list) {
- if (net_list[n] == 'tailscale') {
+ if (n == 'tailscale') {
has_ts_net = true;
break;
}
@@ -321,17 +318,11 @@ methods.setup_firewall = {
changed_firewall = true;
}
- // Exit node requires WAN <-> tailscale forwarding
- let fwd_wan_to_ts = false;
+ // Exit node requires WAN <- tailscale forwarding
let fwd_ts_to_wan = false;
-
- for (let sec_key in fw_all) {
- let s = fw_all[sec_key];
- if (s['.type'] == 'forwarding') {
- if (s.src == 'wan' && s.dest == 'tailscale') fwd_wan_to_ts = true;
- if (s.src == 'tailscale' && s.dest == 'wan') fwd_ts_to_wan = true;
- }
- }
+ uci.foreach('firewall', 'forwarding', function(s) {
+ if (s['src'] == 'tailscale' && s['dest'] == 'wan') fwd_ts_to_wan = true;
+ });
if (!fwd_ts_to_wan) {
let fid = uci.add('firewall', 'forwarding');
@@ -340,13 +331,6 @@ methods.setup_firewall = {
changed_firewall = true;
}
- if (!fwd_wan_to_ts) {
- let fid = uci.add('firewall', 'forwarding');
- uci.set('firewall', fid, 'src', 'wan');
- uci.set('firewall', fid, 'dest', 'tailscale');
- changed_firewall = true;
- }
-
// 4. save
if (changed_network) {
uci.save('network');