Merge e7a47fd150 into 869ceb425c
				
					
				
			This commit is contained in:
		
						commit
						704c4c4719
					
				| @ -55,6 +55,7 @@ uci:delete('fastd', 'mesh_vpn', 'user') | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| local add_groups | local add_groups | ||||||
|  | local ports = {} | ||||||
| 
 | 
 | ||||||
| local function add_peer(group, name, config) | local function add_peer(group, name, config) | ||||||
| 	uci:section('fastd', 'peer', group .. '_peer_' .. name, { | 	uci:section('fastd', 'peer', group .. '_peer_' .. name, { | ||||||
| @ -64,6 +65,20 @@ local function add_peer(group, name, config) | |||||||
| 		key = config.key, | 		key = config.key, | ||||||
| 		remote = config.remotes, | 		remote = config.remotes, | ||||||
| 	}) | 	}) | ||||||
|  | 
 | ||||||
|  | 	for k,r in ipairs(config.remotes) | ||||||
|  | 	do | ||||||
|  | 		for i in string.gmatch(r, "%S+") | ||||||
|  | 		do | ||||||
|  | 			if (tonumber(i)) | ||||||
|  | 			then | ||||||
|  | 				if not isinset(tonumber(i),ports) | ||||||
|  | 				then | ||||||
|  | 					table.insert(ports, i) | ||||||
|  | 				end | ||||||
|  | 			end | ||||||
|  | 		end | ||||||
|  | 	end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| local function add_group(name, config, parent) | local function add_group(name, config, parent) | ||||||
| @ -98,7 +113,31 @@ function add_groups(prefix, groups, parent) | |||||||
| 	end | 	end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | function isinset(needle, haystack) | ||||||
|  | 	for i,v in ipairs(haystack) | ||||||
|  | 	do | ||||||
|  | 		if (tonumber(v) == tonumber(needle)) | ||||||
|  | 		then | ||||||
|  | 			return true | ||||||
|  | 		end | ||||||
|  | 	end | ||||||
|  | 	return false | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| add_groups('mesh_vpn', site.mesh_vpn.fastd.groups) | add_groups('mesh_vpn', site.mesh_vpn.fastd.groups) | ||||||
| 
 | 
 | ||||||
|  | for _,p in ipairs(ports) | ||||||
|  | do | ||||||
|  | 	uci:section('firewall', 'rule', 'wan_fastd_' .. p, { | ||||||
|  | 		name = 'wan_fastd_' .. p, | ||||||
|  | 		dest = 'wan', | ||||||
|  | 		dest_port = p, | ||||||
|  | 		proto = 'udp', | ||||||
|  | 		target = 'ACCEPT', | ||||||
|  | 	}) | ||||||
|  | end | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| uci:save('fastd') | uci:save('fastd') | ||||||
|  | uci:save('firewall') | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user