Implementación de node.js para sincronizar SSO

Here is example with NodeJS if anyone needs it:

'use strict';

const axios = require('axios');
const crypto = require('crypto');
const qs = require('querystring');
const config = require('./config');

function getHash(data, secret) {
  return crypto.createHmac('sha256', secret)
    .update(data)
    .digest('hex');
}

function syncSso() {
  const endpoint = `${config.discourse.url}/admin/users/sync_sso`;
  const params = {
    external_id: 1,
    email: 'bob@example.com',
    username: 'bob',
    add_groups: 'eurorack',
    require_activation: true
  };
  const headers = {
    'Api-Key': config.discourse.apiKey,
    'Api-Username':  config.discourse.apiUsername,
    'Content-Type': 'multipart/form-data'
  };
  const sso = Buffer.from(qs.stringify(params)).toString('base64');
  const sig = getHash(sso, config.discourse.ssoSecret);
  return axios.post(endpoint, qs.stringify({ sso, sig }), { headers })
    .then(({ data }) => data)
    .catch(err => err);
}
3 Me gusta

Hola, probé el fragmento de código anterior en mi aplicación de Node.js y funcionaba bien, luego de redirigir a http://localhost:4200/?sso=bm9uY2U9OTRiNzM1ODU1NDUxOTBmNTE3YWE1NzM0YjA5MDFiODQmcmV0dXJuX3Nzb191cmw9aHR0cCUzQSUyRiUyRmxvY2FsaG9zdCUzQTMwMDAlMkZzZXNzaW9uJTJGc3NvX2xvZ2lu&sig=9fdb6d9f8bd91005d3612c476c91c2acbb650b5532feb9eb131405e2bbe0c0c2

A veces me da tiempo de espera y otras veces recibo “¡Estás al día!”.

Después de varios intentos, ahora ni siquiera puedo acceder al panel de administración en mi localhost:4200, me redirige constantemente a la URL anterior.

Ya borré la caché y las cookies de mi navegador.

Por favor, ayúdenme.

Cada vez recibo solo esto. Incluso no puedo acceder a mi panel de administración, al hacer clic en el botón de inicio de sesión, se redirige a la URL de redirección SSO.