Hola,
para mi empresa, necesitaba utilizar esta función desde nuestro backend Node.js, así que aquí tienes una implementación de referencia en JavaScript utilizando crypto y Buffer de Node.js si a alguien le interesa:
Nota:
Para mayor coherencia, estoy utilizando los mismos valores de variables que en la implementación de PHP.
Configura tus credenciales de API y la clave secreta de SSO
const apiKey = '4fe83002bb5fba8c9a61a65e5b4b0a3cf8233b0e4ccafc85ebd6607abab4651a';
const apiUser = 'system';
const connectSecret = 'jdhb19*Xh3!nu(#k';
Configura los parámetros de sso
const ssoRecord = new URLSearchParams({
external_id: 1,
email: 'bob@example.com',
username: 'bob',
add_groups: 'eurorack',
require_activation: true,
}).toString();
const ssoPayload = Buffer.from(ssoRecord, 'utf8').toString('base64');
const signature = crypto.createHmac('sha256', connectSecret).update(ssoPayload).digest('hex');
Envía la solicitud POST
const updatedUser = await fetch({ // o axios
method: 'POST',
url: 'https://forum.example.com/admin/users/sync_sso',
headers: {
'Api-Key': apiKey,
'Api-Username': apiUser,
'Content-Type': 'application/json',
},
body: JSON.stringify({
sso: ssoPayload,
sig: signature,
})
}).then((response) => response.json());