Implémentation node.js de synchronisation 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 « J'aime »

Salut, j’ai essayé le morceau de code ci-dessus dans mon application node et cela fonctionnait bien lors de la redirection vers http://localhost:4200/?sso=bm9uY2U9OTRiNzM1ODU1NDUxOTBmNTE3YWE1NzM0YjA5MDFiODQmcmV0dXJuX3Nzb191cmw9aHR0cCUzQSUyRiUyRmxvY2FsaG9zdCUzQTMwMDAlMkZzZXNzaW9uJTJGc3NvX2xvZ2lu&sig=9fdb6d9f8bd91005d3612c476c91c2acbb650b5532feb9eb131405e2bbe0c0c2

Cela me donne un timeout parfois et parfois je reçois “You’re all caught up!”.

Après quelques essais, je ne peux même plus accéder au panneau d’administration sur mon localhost:4200, il continue de rediriger vers l’URL ci-dessus.

J’ai déjà vidé le cache et les cookies de mon navigateur.

Aidez-moi s’il vous plaît.

Chaque fois, je n’obtiens que cela. Même je ne peux pas accéder à mon panneau d’administration en cliquant sur le bouton de connexion, il redirige vers l’URL de redirection SSO.