Merge 2e80dffa68 into b3762fc61c
				
					
				
			This commit is contained in:
		
						commit
						5a63712c34
					
				| @ -83,6 +83,7 @@ | |||||||
|   -- connected to using a known IP address. |   -- connected to using a known IP address. | ||||||
|   next_node = { |   next_node = { | ||||||
|     -- anycast IPs of all nodes |     -- anycast IPs of all nodes | ||||||
|  |     -- name = { 'nextnode.location.community.example.org', 'nextnode', 'nn' }, | ||||||
|     ip4 = '10.xxx.0.xxx', |     ip4 = '10.xxx.0.xxx', | ||||||
|     ip6 = 'fdxx:xxxx:xxxx::xxxx', |     ip6 = 'fdxx:xxxx:xxxx::xxxx', | ||||||
|   }, |   }, | ||||||
|  | |||||||
| @ -163,6 +163,7 @@ next_node \: package | |||||||
|     :: |     :: | ||||||
| 
 | 
 | ||||||
|       next_node = { |       next_node = { | ||||||
|  |         name = { 'nextnode.location.community.example.org', 'nextnode', 'nn' }, | ||||||
|         ip4 = '10.23.42.1', |         ip4 = '10.23.42.1', | ||||||
|         ip6 = 'fdca:ffee:babe:1::1', |         ip6 = 'fdca:ffee:babe:1::1', | ||||||
|         mac = '16:41:95:40:f7:dc' |         mac = '16:41:95:40:f7:dc' | ||||||
| @ -172,7 +173,13 @@ next_node \: package | |||||||
|     omitted, there will be no IPv4 or IPv6 anycast address. The MAC address |     omitted, there will be no IPv4 or IPv6 anycast address. The MAC address | ||||||
|     defaults to ``16:41:95:40:f7:dc``; this value usually doesn't need to be |     defaults to ``16:41:95:40:f7:dc``; this value usually doesn't need to be | ||||||
|     changed, but it can be adjusted to match existing deployments that use a |     changed, but it can be adjusted to match existing deployments that use a | ||||||
|     different value. |     different value. Each entry in the ``name``-field will be resolved to the | ||||||
|  |     IPv4 and IPv6-address. | ||||||
|  |     For this to work, clients must use the next-node as their resolver. In | ||||||
|  |     batman-based networks this requires setting the central DHCP server to | ||||||
|  |     deliver this address as DNS server via DHCP option. When running a radvd | ||||||
|  |     inside the network, this should be set to deliver the next-node | ||||||
|  |     IPv6-address via rdnss. | ||||||
| 
 | 
 | ||||||
| mesh \: optional | mesh \: optional | ||||||
|     Options specific to routing protocols. |     Options specific to routing protocols. | ||||||
|  | |||||||
| @ -70,6 +70,7 @@ if need_table({'dns'}, nil, false) then | |||||||
| 	need_number({'dns', 'cacheentries'}, false) | 	need_number({'dns', 'cacheentries'}, false) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | need_string_array(in_domain({'next_node', 'name'}), false) | ||||||
| need_string_match(in_domain({'next_node', 'ip6'}), '^[%x:]+$', false) | need_string_match(in_domain({'next_node', 'ip6'}), '^[%x:]+$', false) | ||||||
| need_string_match(in_domain({'next_node', 'ip4'}), '^%d+.%d+.%d+.%d+$', false) | need_string_match(in_domain({'next_node', 'ip4'}), '^%d+.%d+.%d+.%d+$', false) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -25,22 +25,21 @@ if dns.servers then | |||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| if next_node.name and next_node.ip4 then | local function set_dns_record(name, ip, sectionname) | ||||||
| 	uci:section('dhcp', 'domain', 'nextnode4', { | 	if not ip then return end | ||||||
| 		name = next_node.name, | 	uci:section('dhcp', 'domain', sectionname, { | ||||||
| 		ip = next_node.ip4, | 		name = name, | ||||||
|  | 		ip = ip, | ||||||
| 	}) | 	}) | ||||||
| else |  | ||||||
| 	uci:delete('dhcp', 'domain', 'nextnode4') |  | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| if next_node.name and next_node.ip6 then | uci:delete_all('dhcp', 'domain', function(s) | ||||||
| 	uci:section('dhcp', 'domain', 'nextnode6', { | 	return (s['.name'] and string.match(s['.name'], "^nextnode[46]")) | ||||||
| 		name = next_node.name, | end) | ||||||
| 		ip = next_node.ip6, | 
 | ||||||
| 	}) | for i, name in ipairs(next_node.name or {}) do | ||||||
| else | 	set_dns_record(name, next_node.ip4, 'nextnode4_' .. i) | ||||||
| 	uci:delete('dhcp', 'domain', 'nextnode6') | 	set_dns_record(name, next_node.ip6, 'nextnode6_' .. i) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| uci:save('dhcp') | uci:save('dhcp') | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user