Mercurial > prosody-modules
comparison mod_s2sout_override/mod_s2sout_override.lua @ 5653:62c6e17a5e9d
Merge
author | Stephen Paul Weber <singpolyma@singpolyma.net> |
---|---|
date | Mon, 18 Sep 2023 08:24:19 -0500 |
parents | ae62d92506dc |
children |
comparison
equal
deleted
inserted
replaced
5652:eade7ff9f52c | 5653:62c6e17a5e9d |
---|---|
1 --% requires: s2sout-pre-connect-event | |
2 | |
3 local url = require"socket.url"; | |
4 local basic_resolver = require "net.resolvers.basic"; | |
5 | |
6 local override_for = module:get_option(module.name, {}); -- map of host to "tcp://example.com:5269" | |
7 | |
8 module:hook("s2sout-pre-connect", function(event) | |
9 local override = override_for[event.session.to_host] or override_for[event.session.to_host:gsub("^[^.]+%.", "*.")] or override_for["*"]; | |
10 if type(override) == "string" then | |
11 override = url.parse(override); | |
12 end | |
13 if type(override) == "table" and override.scheme == "tcp" and type(override.host) == "string" then | |
14 event.resolver = basic_resolver.new(override.host, tonumber(override.port) or 5269, override.scheme, {}); | |
15 elseif type(override) == "table" and override.scheme == "tls" and type(override.host) == "string" then | |
16 event.resolver = basic_resolver.new(override.host, tonumber(override.port) or 5270, "tcp", | |
17 { servername = event.session.to_host; sslctx = event.session.ssl_ctx }); | |
18 end | |
19 end); |