Software /
code /
prosody-modules
File
mod_s2sout_override/mod_s2sout_override.lua @ 5624:d8622797e315
mod_http_oauth2: Shorten default token validity periods
With refresh tokens, short lifetime for access tokens is not a problem.
The arbitrary choice of one hour seems reasonable. RFC 6749 has it as
example value.
One week for refresh tokens matching the default archive retention
period. This means that a client that remains unused for one week will
have to sign in again. An actively used client will continually push
that forward with each used refresh token.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Mon, 24 Jul 2023 01:30:14 +0200 |
parent | 5487:6cf2f32dbf40 |
child | 5631:b87a23b45725 |
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]; 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);