Tengo una aplicación React y quiero implementar la función SSO. Pero siempre obtengo un error de nonce

Ya he comprobado enable discourse connect, y especificado la discourse connect url y configurado el discourse connect secret correctamente.
En la página de la discourse connect url, estoy haciendo lo siguiente:

function rediretUserToDiscourse(user) {
        const url = new URL(window.location)
        const searchParams = new URLSearchParams(url.search);
        const ssoValue = searchParams.get("sso");
        const decodedSSOValue = window.atob(ssoValue);
        const queryParams = decodedSSOValue.split("&");

        let nonce = null;
        for (let param of queryParams) {
            const [key, value] = param.split("=");
            if (key === "nonce") {
                nonce = value;
                break;
            }
        }

        if (user) {
            const payload = `nonce=${nonce}&name=${user.username}&username=${user.username}&email=${user.email}&external_id=${user.id}&avatar_url=${user.avatar}`;

            const encodedPayload = window.btoa(JSON.stringify(payload));
            const secret = "discourse_connect_secret";

            hmac(encodedPayload, secret, HmacAlgorithms.HmacSHA256, Encoders.hex)
                .then(signature => {
                    if (signature) {
                        const discourseLoginURL = `https://community.mydomaine.co/session/sso_login?sso=${encodedPayload}&sig=${signature}`;
                        window.location.href = discourseLoginURL;
                    }
                });
        }
    };

Todo funciona perfectamente (la firma es válida y me redirige a Discourse). Pero sigo recibiendo el siguiente error: Nonce is incorrect, was generated in a different browser session, or has expired. He pasado horas buscando una solución aquí, en Google y en ChatGPT (¿por qué no :p?) y todavía no he encontrado una solución.

¿Alguien sabe cómo puedo solucionarlo, por favor?