Commit graph

26 commits

Author SHA1 Message Date
Kim Alvefur
869581384d net: Prefix module imports with prosody namespace 2023-03-17 16:23:12 +01:00
Kim Alvefur
b79cb49bfb net.connect: Clear TODO for Happy Eyeballs / RFC 8305, close #1246
Gotta have the DOAP references!
2022-08-19 14:24:31 +02:00
Kim Alvefur
9e8e910f1e net.connect: Fix accumulation of connection attempt references
Connection attempts that failed the Happy Eyeballs race were not
unreferenced and would accumulate.

Tested by inspecting the 'pending_connections_map' after establishing
s2s with a s2s target where the IPv6 port has a -j DROP rule causing it
to time out and the IPv4 attempt wins the race.

Expected is that the losing connection stays around until net.server
timeouts kick in where it should be removed. The map table should tend
towards being empty during idle times.
2022-04-20 22:41:54 +02:00
Matthew Wild
28e919462b net.connect: Improve logging on connection attempt failure 2022-03-21 11:15:30 +00:00
Matthew Wild
b42fe8746c net.connect: Improve handling of failure when attempts are still pending
This could lead to failure being reported too early, even if some connections
have not yet failed.
2022-03-21 11:01:58 +00:00
Matthew Wild
a188ece31a net.connect: When more targets are immediately available, try them after a delay
RFC 8305
2022-03-18 16:16:57 +00:00
Matthew Wild
f278c021e6 net.connect: Support for multiple pending connection attempts 2022-03-18 16:16:01 +00:00
Kim Alvefur
9f1af0be2e net.connect: Allow passing TLS context from resolver
Only allowing it to be passed directly makes it hard to combine plain
(i.e. starttls) and Direct TLS connections in the same connection
resolution procedure. But now we can, using chained resolvers!
2022-01-21 17:57:47 +01:00
Kim Alvefur
068388d9c7 net.connect: Prefer last connection error over last resolver error
E.g. "connection refused" over one IP version instead of NoError for the
other IP version.
2021-11-13 13:32:43 +01:00
Kim Alvefur
93121127fa net.connect: Propagate last error message from resolvers
Previously it would only say "unable to resolve server" for all DNS
problems. While "NoError in A lookup" might not make much sense to
users, it should help in debugging more than the previous generic error.

Friendlier errors will be future work.
2021-11-12 16:52:55 +01:00
Kim Alvefur
7b89ab9b86 net.connect: Remove TODO about use_ipv4/6 done in 3bfb20be844c 2020-06-22 01:42:18 +02:00
Matthew Wild
c5fcad823a Backed out changeset 44ef46e1a951 (not optimal API) 2020-01-25 14:25:29 +00:00
Matthew Wild
d3a6636c1c net.connect: Add API to create custom connect()s with options, incl. use_ipv[46] 2020-01-24 13:48:49 +00:00
Kim Alvefur
9d5c3cb856 net.connect: Mention RFC 6724 regression
Default Address Selection algorithm is not applied, resulting in a
strong bias towards IPv4.
2019-12-07 17:39:29 +01:00
Kim Alvefur
40ffc88bad net.connect: Add some TODOs and FIXMEs
And mention issue numbers: #1246, #1428 and #1429
2019-12-07 17:05:00 +01:00
Kim Alvefur
e8f099babc net.connect: Add some TODO comments 2019-11-26 00:12:51 +01:00
Kim Alvefur
75bfec7731 net.*: Remove tostring call from logging
Taken care of by loggingmanager now
2019-07-30 02:35:17 +02:00
Kim Alvefur
7a86af343f net.connect: Fix passing request table to new listener
This could be a return value from ondetach
2018-09-26 17:36:53 +02:00
Kim Alvefur
7f9c753df9 net.connect: Remove manual onattach callback invocation 2018-09-26 15:07:25 +02:00
Matthew Wild
5eb41ade9b net.connect: Fix to store correct parameter 2018-02-26 15:26:08 +00:00
Matthew Wild
3b771f4dcd net.connect: Improve error message 2018-02-26 15:25:52 +00:00
Matthew Wild
8b8926d7bb net.connect: Handle immediate failures of server.addclient 2018-02-26 15:25:34 +00:00
Matthew Wild
8ab5e4497e net.connect: Handle case when resolver runs out of targets 2018-02-26 15:21:27 +00:00
Matthew Wild
85261e71be net.connect: Track last connection error 2018-02-26 15:20:35 +00:00
Matthew Wild
df664e829b net.connect: Default to *a pattern if none provided 2018-02-23 16:23:03 +00:00
Matthew Wild
c27281a720 net.connect: New API for outgoing connections, based on 'service resolvers' 2018-02-23 15:53:45 +00:00