En este artículo, te guiaré paso a paso para conectar un backend construido con Node.js a Salesforce usando OAuth 2.0, e integrarlo con un frontend, en este caso, React.
Esta solución utiliza una Connected App en Salesforce y los paquetes sf-jwt-token y jsforce en el backend.
Explicaré cómo hacerlo en tu máquina local y en un entorno de prueba utilizando Ngrok.
1. Configuración en Salesforce
Para habilitar una comunicación segura entre Salesforce y nuestra aplicación, primero necesitamos configurar una Connected App en la interfaz de usuario (UI) de Salesforce.
Así que, antes de empezar a programar, necesitamos configurar Salesforce para permitir la integración con nuestra aplicación.
Pasos en la UI de Salesforce:
-
Crear una Connected App:
- Ve a Setup → App Manager → Create a Connected App.
- Habilita el acceso a la API seleccionando Enable OAuth Settings.
- En Selected OAuth Scopes, selecciona:
Perform request at any time (refresh_token, offline_access)
Manage user data via APIs (api)
-
Full access (full)
.
-
Configurar las políticas de OAuth:
- Dentro de la nueva aplicación, navega a Manage → Edit Policies y configura:
- Permitted Users: Admin approved users are pre-authorized.
- También necesitamos asignar el perfil que queremos usar en Manage Profiles.
- Dentro de la nueva aplicación, navega a Manage → Edit Policies y configura:
Consumer Key y Secret:
En la sección API (Enable OAuth Settings), haz clic en Manage Consumer Details y guarda el Consumer Key (Consumer_Id) y el Consumer Secret (Consumer_Secret).
Estos valores se usarán más adelante en el archivo.env
para la configuración del backend.Restablecer tu token de seguridad:
Restablece tu token de seguridad, si es necesario, navegando a tus configuraciones personales en Salesforce.
Este token también se agregará a las variables de entorno (explicado más abajo).
2. Configurar el servidor en Node.js
A continuación, configuraremos un backend en Express y las herramientas necesarias para interactuar con Salesforce.
Puedes usar este repositorio ya preparado para este propósito:
Backend Node
Instalar dependencias:
npm install express jsforce sf-jwt-token
Nota:
Escribo este artículo en diciembre de 2024, y creo que hay dos características interesantes recientes de Node.js que deberías conocer:
- Si usas Node.js v21.7.0 (abril de 2024) o posterior: Ya no necesitas dotenv para las variables de entorno, puedes usar
process.loadEnvFile()
al inicio de tu aplicación. Después de esto, tendrás tu archivo.env
como de costumbre en la raíz del proyecto, y podrás llamar tus variables desde cualquier parte del código usandoprocess.env.TU_VARIABLE
. Web Developer. - Además, desde Node.js v22 (Soporte a Largo Plazo desde octubre de 2024), puedes usar
node --watch <tu archivo>
en lugar del paquete nodemon para reinicios automáticos del servidor. Logrocket.
Así que, dos paquetes menos para instalar.
Variables de entorno:
Crea un archivo .env
y define lo siguiente:
CONSUMER_ID=tu_consumer_id
SF_USERNAME=tu_usuario_de_salesforce
LOGIN_URL=https://login.salesforce.com OR https://test.salesforce.com
¿Probando localmente? Usa Ngrok
Ngrok se utiliza para exponer tu servidor local a internet, permitiendo que Salesforce envíe callbacks a tu aplicación durante el proceso de autenticación (necesario principalmente en la primera llamada):
- Instala y ejecuta Ngrok.
- Ejecuta tu servidor.
- Apunta Ngrok al puerto donde se ejecuta tu backend escribiendo
ngrok.exe http <tu_puerto>
en tu terminal. - Copia la URL generada por Ngrok y configúrala como Callback URL en tu Connected App en la sección API (Enable OAuth Settings).
3. Clave privada y certificado
Genera una clave privada y un certificado con el siguiente comando en la terminal:
$ openssl req -nodes -new -x509 -keyout private.pem -out server.cert
Subir la firma digital a Salesforce
Ahora que los dos archivos están en tu proyecto, habilita la opción Use digital signatures en tu Connected App y sube el certificado generado en:
Setup → Certificates and Key Management.
Ahora, ejecuta la ruta del token en tu navegador:
http://localhost:3000/token
Si todo salió bien, obtendrás tu access_token
.
{
"access_token": "",
"scope": "api full",
"instance_url": "",
"id": "",
"token_type": "Bearer"
}
En esta solución, opté por solicitar un nuevo token de Salesforce para cada llamada a la API. Salesforce puede devolver el mismo token o emitir uno nuevo, ya que los tokens se actualizan periódicamente.
4. Usando JSforce
Con el token, puedes comenzar a interactuar con Salesforce desde tu servidor Node.js. Aquí hay un ejemplo simple:
const jsforce = require('jsforce');
const conn = new jsforce.Connection({
instanceUrl: 'https://tu-instancia.salesforce.com',
accessToken: 'tu_access_token',
});
conn.query('SELECT Id, Name FROM Account', (err, result) => {
if (err) return console.error(err);
console.log('Cuentas:', result.records);
});
5. Integración con React
Finalmente, usa React para crear un frontend que consuma datos del backend y los muestre de forma interactiva. Por ejemplo, podrías construir:
- Un formulario para crear registros en Salesforce.
- Una tabla para mostrar los datos de cuentas recuperados desde el backend.
En mi caso de uso, necesitaba una forma en que los empleados de una empresa pudieran registrar datos de desplazamiento y hacer registros en Salesforce, específicamente en Net Zero Cloud. Para este ejercicio, creé el objeto necesario y desarrollé la solución con un Developer Org gratuito.
También puedes usar este repositorio de frontend en React para este propósito:
Frontend React.
Conclusión
Integrar Salesforce, Node.js y React es una forma sencilla de experimentar con herramientas y hacer que todo funcione.
Espero que este artículo te ayude a empezar con tu propia solución de integración.
¿Tienes preguntas o ideas para mejorar este flujo de trabajo? Déjalas en los comentarios.
Top comments (0)