Внешний провайдер SSO, но логи Discourse говорят, что None уже истек (помогите!)

Мы используем Firebase в качестве внешнего провайдера единого входа (SSO). Мы следовали инструкциям Discourse по этому вопросу.

В логах появляется следующая ошибка:

Подробный лог SSO: Запущен процесс SSO add_groups: admin: moderator: avatar_force_update: avatar_url: bio: card_background_url: email: external_id: groups: locale: locale_force_update: logo

Подробный лог SSO: Nonce уже истёк add_groups: admin: moderator: avatar_force_update: avatar_url: bio: card_background_url: email: [реальная почта]: external_id: [внешний идентификатор]

Также в логах Discourse мы видим:

Подробный лог SSO: Запущен процесс SSO

add_groups: 
admin: 
moderator: 
avatar_force_update: 
avatar_url: 
bio: 
card_background_url: 
email: 
external_id: 
groups: 
locale: 
locale_force_update: 
logout: 
name: 
nonce: 773cb9d08db7007c9fb833e6c5e3a701
profile_background_url: 
remove_groups: 
require_activation: 
return_sso_url: https://discouse-site/session/sso_login
suppress_welcome_message: 
title: 
username: 
website: 
location: 

И

Подробный лог SSO: Nonce уже истёк

add_groups: 
admin: 
moderator: 
avatar_force_update: 
avatar_url: 
bio: 
card_background_url: 
email: [реальная почта]
external_id: Be06ze0v0YO7I8SArWRoUVsxJ1k1
groups: 
locale: 
locale_force_update: 
logout: 
name: [реальная почта]
nonce: Ym05dVkyVTlOV0kwTTJVeU1UTTVNamN6TnpNd01UbG1aVEJtWkRjMFlqTmtOV1U1TmpJbWNtVjBkWEp1WDNOemIxOTFjbXc5YUhSMGNITWxNMEVsTWtZbE1rWmpiMjF0ZFc1cGRIa3VZbTl2Wnk1aGNIQWxNa1p6WlhOemFXOXVKVEpHYzNOdlgyeHZaMmx1
profile_background_url: 
remove_groups: 
require_activation: 
return_sso_url: https://discouse-site/session/sso_login
suppress_welcome_message: 
title: 
username: [реальная почта]
website: 
location:  

Будем признательны за помощь от команды Discourse, так как в данный момент мы не можем использовать сайт.

Джеймс

Я не эксперт в этом, но, думаю, стоит проверить, правильно ли установлено время на вашем устройстве.

Спасибо за предложение, но, похоже, проблема не в часах. Сервер Discourse и сервер, с которого генерируется nonce, работают в одном часовом поясе.

Я делюсь способом, которым мы генерируем URL возврата, чтобы, надеюсь, прояснить эту проблему:

   public String generateSSORedirectURL(String nonce, String email, String uid) {

    // генерируем полезную нагрузку возврата
    HashMap<String, String> params = new HashMap<String, String>();
    params.put("nonce", nonce);
    params.put("external_id", uid);
    params.put("email", email);
    params.put("username", email);
    params.put("require_activation", "false");
    params.put("name", email);
    params.put("return_sso_url", "https://discourse-site/session/sso_login");
    log.info("params {}", params);

    // подготавливаем полезную нагрузку возврата
    String encodedParams = params.keySet().stream()
        .map(key -> key + "=" + encodeValue(params.get(key)))
        .collect(Collectors.joining("&"));
    log.info("encoded parameters {}", encodedParams);

    String returnPayload = Base64.getEncoder().encodeToString(encodedParams.getBytes());
    log.info("return Payload {}", returnPayload);

    // вычисляем подпись hmacSha256 для полезной нагрузки
    byte[] hmacSha256 = calcHmacSha256(ssoSecret.getBytes(), returnPayload.getBytes());
    log.info("hmacSha256 sig {}", hmacSha256);
    
    String hmacSha265Hex = String.format("%x", new BigInteger(1, hmacSha256));
    log.info("hmacSha256, sig in Hex {}", String.format("%x", new BigInteger(1, hmacSha256)));

    HashMap<String, String> params2 = new HashMap<String, String>();
    params2.put("sig", hmacSha265Hex);
    params2.put("sso", returnPayload);
    log.info("params2 {}", params);

    String encodedParams2 = params2.keySet().stream()
        .map(key -> key + "=" + encodeValue(params2.get(key)))
        .collect(Collectors.joining("&"));
    log.info("encoded parameters {}", encodedParams2);

    // формируем и возвращаем строку запроса
    String queryString = forumUrl + "session/sso_login?" + encodedParams2;
    log.info("queryString {}", queryString);

    return queryString;
}

Вы когда-нибудь разобрались с этим? @James_Hope