Mercurial > prosody-modules
view mod_s2sout_override/mod_s2sout_override.lua @ 5803:f55e65315ba0
mod_pubsub_serverinfo: implemented all basic features
This commit replaces the earlier proof-of-concept to a solution that:
- reports on remotely-connected domains
- uses disco/info to detect if those domains opt-in
- publishes domain names for remote domains that do so
- caches the disco/info response
author | Guus der Kinderen <guus.der.kinderen@gmail.com> |
---|---|
date | Wed, 03 Jan 2024 23:05:14 +0100 |
parents | ae62d92506dc |
children |
line wrap: on
line source
--% requires: s2sout-pre-connect-event local url = require"socket.url"; local basic_resolver = require "net.resolvers.basic"; local override_for = module:get_option(module.name, {}); -- map of host to "tcp://example.com:5269" module:hook("s2sout-pre-connect", function(event) local override = override_for[event.session.to_host] or override_for[event.session.to_host:gsub("^[^.]+%.", "*.")] or override_for["*"]; if type(override) == "string" then override = url.parse(override); end if type(override) == "table" and override.scheme == "tcp" and type(override.host) == "string" then event.resolver = basic_resolver.new(override.host, tonumber(override.port) or 5269, override.scheme, {}); elseif type(override) == "table" and override.scheme == "tls" and type(override.host) == "string" then event.resolver = basic_resolver.new(override.host, tonumber(override.port) or 5270, "tcp", { servername = event.session.to_host; sslctx = event.session.ssl_ctx }); end end);