Comparison

plugins/mod_s2s/s2sout.lib.lua @ 4959:ab696f5394cf

mod_s2s/s2sout.lib: Fix indentation
author Matthew Wild <mwild1@gmail.com>
date Sun, 22 Jul 2012 16:29:52 +0100
parent 4957:1722a6bea115
child 4987:d37f2abac72c
comparison
equal deleted inserted replaced
4957:1722a6bea115 4959:ab696f5394cf
171 host_session.ip_hosts = IPs; 171 host_session.ip_hosts = IPs;
172 local handle4, handle6; 172 local handle4, handle6;
173 local have_other_result = not(has_ipv4) or not(has_ipv6) or false; 173 local have_other_result = not(has_ipv4) or not(has_ipv6) or false;
174 174
175 if has_ipv4 then 175 if has_ipv4 then
176 handle4 = adns.lookup(function (reply, err) 176 handle4 = adns.lookup(function (reply, err)
177 handle4 = nil; 177 handle4 = nil;
178 178
179 -- COMPAT: This is a compromise for all you CNAME-(ab)users :) 179 -- COMPAT: This is a compromise for all you CNAME-(ab)users :)
180 if not (reply and reply[#reply] and reply[#reply].a) then 180 if not (reply and reply[#reply] and reply[#reply].a) then
181 local count = max_dns_depth; 181 local count = max_dns_depth;
182 reply = dns.peek(connect_host, "CNAME", "IN"); 182 reply = dns.peek(connect_host, "CNAME", "IN");
183 while count > 0 and reply and reply[#reply] and not reply[#reply].a and reply[#reply].cname do 183 while count > 0 and reply and reply[#reply] and not reply[#reply].a and reply[#reply].cname do
184 log("debug", "Looking up %s (DNS depth is %d)", tostring(reply[#reply].cname), count); 184 log("debug", "Looking up %s (DNS depth is %d)", tostring(reply[#reply].cname), count);
185 reply = dns.peek(reply[#reply].cname, "A", "IN") or dns.peek(reply[#reply].cname, "CNAME", "IN"); 185 reply = dns.peek(reply[#reply].cname, "A", "IN") or dns.peek(reply[#reply].cname, "CNAME", "IN");
186 count = count - 1; 186 count = count - 1;
187 end 187 end
188 end 188 end
189 -- end of CNAME resolving 189 -- end of CNAME resolving
190 190
191 if reply and reply[#reply] and reply[#reply].a then 191 if reply and reply[#reply] and reply[#reply].a then
192 for _, ip in ipairs(reply) do 192 for _, ip in ipairs(reply) do
193 log("debug", "DNS reply for %s gives us %s", connect_host, ip.a); 193 log("debug", "DNS reply for %s gives us %s", connect_host, ip.a);
194 IPs[#IPs+1] = new_ip(ip.a, "IPv4"); 194 IPs[#IPs+1] = new_ip(ip.a, "IPv4");
195 end 195 end
196 end 196 end
197 197
198 if have_other_result then 198 if have_other_result then
199 if #IPs > 0 then 199 if #IPs > 0 then
200 rfc3484_dest(host_session.ip_hosts, sources); 200 rfc3484_dest(host_session.ip_hosts, sources);
201 for i = 1, #IPs do 201 for i = 1, #IPs do
202 IPs[i] = {ip = IPs[i], port = connect_port}; 202 IPs[i] = {ip = IPs[i], port = connect_port};
203 end 203 end
204 host_session.ip_choice = 0; 204 host_session.ip_choice = 0;
205 s2sout.try_next_ip(host_session); 205 s2sout.try_next_ip(host_session);
206 else
207 log("debug", "DNS lookup failed to get a response for %s", connect_host);
208 host_session.ip_hosts = nil;
209 if not s2sout.attempt_connection(host_session, "name resolution failed") then -- Retry if we can
210 log("debug", "No other records to try for %s - destroying", host_session.to_host);
211 err = err and (": "..err) or "";
212 s2s_destroy_session(host_session, "DNS resolution failed"..err); -- End of the line, we can't
213 end
214 end
206 else 215 else
207 log("debug", "DNS lookup failed to get a response for %s", connect_host); 216 have_other_result = true;
208 host_session.ip_hosts = nil; 217 end
209 if not s2sout.attempt_connection(host_session, "name resolution failed") then -- Retry if we can 218 end, connect_host, "A", "IN");
210 log("debug", "No other records to try for %s - destroying", host_session.to_host);
211 err = err and (": "..err) or "";
212 s2s_destroy_session(host_session, "DNS resolution failed"..err); -- End of the line, we can't
213 end
214 end
215 else
216 have_other_result = true;
217 end
218 end, connect_host, "A", "IN");
219 else 219 else
220 have_other_result = true; 220 have_other_result = true;
221 end 221 end
222 222
223 if has_ipv6 then 223 if has_ipv6 then
224 handle6 = adns.lookup(function (reply, err) 224 handle6 = adns.lookup(function (reply, err)
225 handle6 = nil; 225 handle6 = nil;
226 226
227 if reply and reply[#reply] and reply[#reply].aaaa then 227 if reply and reply[#reply] and reply[#reply].aaaa then
228 for _, ip in ipairs(reply) do 228 for _, ip in ipairs(reply) do
229 log("debug", "DNS reply for %s gives us %s", connect_host, ip.aaaa); 229 log("debug", "DNS reply for %s gives us %s", connect_host, ip.aaaa);
230 IPs[#IPs+1] = new_ip(ip.aaaa, "IPv6"); 230 IPs[#IPs+1] = new_ip(ip.aaaa, "IPv6");
231 end 231 end
232 end 232 end
233 233
234 if have_other_result then 234 if have_other_result then
235 if #IPs > 0 then 235 if #IPs > 0 then
236 rfc3484_dest(host_session.ip_hosts, sources); 236 rfc3484_dest(host_session.ip_hosts, sources);
237 for i = 1, #IPs do 237 for i = 1, #IPs do
238 IPs[i] = {ip = IPs[i], port = connect_port}; 238 IPs[i] = {ip = IPs[i], port = connect_port};
239 end 239 end
240 host_session.ip_choice = 0; 240 host_session.ip_choice = 0;
241 s2sout.try_next_ip(host_session); 241 s2sout.try_next_ip(host_session);
242 else
243 log("debug", "DNS lookup failed to get a response for %s", connect_host);
244 host_session.ip_hosts = nil;
245 if not s2sout.attempt_connection(host_session, "name resolution failed") then -- Retry if we can
246 log("debug", "No other records to try for %s - destroying", host_session.to_host);
247 err = err and (": "..err) or "";
248 s2s_destroy_session(host_session, "DNS resolution failed"..err); -- End of the line, we can't
249 end
250 end
242 else 251 else
243 log("debug", "DNS lookup failed to get a response for %s", connect_host); 252 have_other_result = true;
244 host_session.ip_hosts = nil; 253 end
245 if not s2sout.attempt_connection(host_session, "name resolution failed") then -- Retry if we can 254 end, connect_host, "AAAA", "IN");
246 log("debug", "No other records to try for %s - destroying", host_session.to_host);
247 err = err and (": "..err) or "";
248 s2s_destroy_session(host_session, "DNS resolution failed"..err); -- End of the line, we can't
249 end
250 end
251 else
252 have_other_result = true;
253 end
254 end, connect_host, "AAAA", "IN");
255 else 255 else
256 have_other_result = true; 256 have_other_result = true;
257 end 257 end
258 return true; 258 return true;
259 elseif host_session.ip_hosts and #host_session.ip_hosts > host_session.ip_choice then -- Not our first attempt, and we also have IPs left to try 259 elseif host_session.ip_hosts and #host_session.ip_hosts > host_session.ip_choice then -- Not our first attempt, and we also have IPs left to try