Este tutorial proporciona código de implementación de ejemplo para una aplicación Node.js/Express. Puedes modificar este código para tu marco específico (Next.js, React, Vue, etc.) y personalizar la interfaz de usuario según las necesidades de tu aplicación.
- Crear productos de suscripción con precios por asiento
- Configurar complementos para asientos adicionales
- Generar enlaces de pago con cantidades de complementos personalizadas
- Manejar sesiones de pago con conteos de asientos dinámicos
Lo que Estamos Construyendo
Vamos a crear un modelo de precios por asiento:- Plan Base: $49/mes para hasta 5 miembros del equipo
- Complemento por Asiento: $2/mes por asiento adicional
- Enlaces de Pago: Pago dinámico con cantidades de asientos personalizadas
Antes de comenzar, asegúrate de tener:
- Una cuenta de Dodo Payments
- Familiaridad básica con TypeScript/Node.js
Paso 1: Crea Tu Complemento de Asiento
Ahora necesitamos crear un complemento que represente asientos adicionales. Este complemento se adjuntará a nuestra suscripción base y permitirá a los clientes comprar asientos adicionales.
1
Navegar a Complementos
- En tu panel de Dodo Payments, permanece en la sección Productos
- Haz clic en la pestaña Complementos
- Haz clic en Crear Complemento
2
Ingresa los detalles del complemento
Completa estos valores para nuestro complemento de asiento:Nombre del Complemento:
Additional Team SeatDescripción: Add extra team members to your workspace with full access to all featuresPrecio: Ingresa → 2.00Moneda: Debe coincidir con la moneda de tu suscripción baseCategoría de Impuestos: Selecciona la categoría apropiada para tu producto.3
Guarda tu complemento
- Revisa todos tus ajustes:
- Nombre: Asiento Adicional para el Equipo
- Precio: $2.00/mes
- Haz clic en Crear Complemento
¡Complemento creado! Tu complemento de asiento ahora está disponible para adjuntarse a las suscripciones.
Paso 2: Crea Tu Producto de Suscripción Base
Comenzaremos creando un producto de suscripción base que incluya 5 miembros del equipo. Esta será la base de nuestro modelo de precios por asiento.
1
Navegar a Productos
- Inicia sesión en tu panel de Dodo Payments
- Haz clic en Productos en la barra lateral izquierda
- Haz clic en el botón Crear Producto
- Selecciona Suscripción como tipo de producto
2
Completa los detalles de la suscripción
Ahora ingresaremos los detalles específicos para nuestro plan base:Nombre del Producto:
MotionDescripción: Where your team's documentation lives.Precio Recurrente: Ingresa → 49.00Ciclo de Facturación: Selecciona → MonthlyMoneda: Selecciona tu moneda preferida (por ejemplo, USD)Paso 3: Conectar el Complemento a la Suscripción
Ahora necesitamos asociar nuestro complemento de asiento con la suscripción base para que los clientes puedan comprar asientos adicionales durante el pago.1
Adjuntar el complemento de asiento

- Desplázate hacia abajo hasta la sección Complementos
- Haz clic en Agregar Complementos
- Desde el menú desplegable, selecciona tu complemento de asiento
- Confirma que aparece en la configuración de tu suscripción
2
Guarda los cambios de la suscripción
- Revisa la configuración completa de tu suscripción:
- Plan base: $49/mes por 5 asientos
- Complemento: $2/mes por asiento adicional
- Prueba gratuita: 14 días
- Haz clic en Guardar Cambios
¡Precios por asiento configurados! Los clientes ahora pueden comprar tu plan base y agregar asientos adicionales según sea necesario.
Paso 4: Generar Enlaces de Pago con Cantidades de Complementos Personalizadas
Ahora vamos a crear una aplicación Express.js que genere enlaces de pago con cantidades de complementos personalizadas. Aquí es donde entra el verdadero poder de los precios por asiento: puedes crear dinámicamente sesiones de pago con cualquier número de asientos adicionales.1
Configura tu proyecto
Crea un nuevo proyecto de Node.js e instala las dependencias requeridas:Crea un archivo
tsconfig.json:2
Crea tu archivo de entorno
Crea un archivo
.env con tu clave API de Dodo Payments:3
Implementa la creación de la sesión de pago
Crea un archivo
src/server.ts con el siguiente código:4
Agrega una interfaz web simple
Crea un archivo
public/index.html para facilitar las pruebas:¡Interfaz web creada! Ahora tienes una interfaz simple para probar diferentes cantidades de asientos.
5
Sirve archivos estáticos
Agrega esto a tu
src/server.ts para servir el archivo HTML:¡Archivos estáticos configurados! Visita
http://localhost:3000 para ver tu interfaz de demostración.Paso 5: Prueba Tu Implementación
Probemos nuestra implementación de precios por asiento para asegurarnos de que todo funcione correctamente.1
Inicia tu servidor
- Asegúrate de tener tu archivo
.envcon la clave API correcta - Actualiza los IDs de producto y complemento en tu código con los valores reales de tu panel de Dodo Payments
- Inicia tu servidor:
Tu servidor debería iniciarse correctamente y mostrar “Servidor en ejecución en http://localhost:3000”
2
Prueba la interfaz web

- Abre tu navegador y ve a
http://localhost:3000 - Deberías ver la interfaz de demostración de precios por asiento
- Prueba diferentes cantidades de asientos (0, 3, 10, etc.)
- Haz clic en “Generar Enlace de Pago” para cada cantidad
- Verifica que las URL de pago se generen correctamente
3
Prueba una sesión de pago
- Genera un enlace de pago con 3 asientos adicionales
- Haz clic en la URL de pago para abrir el pago de Dodo Payments
- Verifica que el pago muestre:
- Plan base: $49/mes
- Asientos adicionales: 3 × 2 dólares = $6/mes
- Completa la compra de prueba
El pago debería mostrar el desglose de precios correcto y permitirte completar la compra.
4
Escucha los webhooks y actualiza tu base de datos
Para mantener tu base de datos sincronizada con los cambios de suscripción y asientos, necesitas escuchar los eventos de webhook de Dodo Payments. Los webhooks notifican a tu backend cuando un cliente completa el pago, actualiza su suscripción o cambia la cantidad de asientos.Sigue la guía oficial de webhooks de Dodo Payments para obtener instrucciones paso a paso sobre cómo configurar los puntos finales de webhook y manejar eventos:
Documentación de Webhooks de Dodo Payments
Aprende cómo recibir y procesar de manera segura eventos de webhook para la gestión de suscripciones y asientos.
Solución de Problemas
Problemas comunes y sus soluciones:Fallo en la creación del pago
Fallo en la creación del pago
Causas posibles:
- ID de producto o ID de complemento inválido
- La clave API no tiene permisos suficientes
- Complemento no asociado correctamente con la suscripción
- Problemas de conectividad de red
- Verifica que los IDs de producto y complemento existan en tu panel de Dodo Payments
- Asegúrate de que el complemento esté correctamente adjunto a la suscripción
- Asegúrate de que la clave API tenga permisos para crear sesiones de pago
- Prueba la conectividad de la API con una simple solicitud GET
¡Felicidades! Has Implementado Precios por Asiento
¡Has creado con éxito un sistema de precios por asiento con Dodo Payments! Esto es lo que lograste:Suscripción Base
Creado un producto de suscripción con 5 asientos incluidos a $49/mes
Complementos por Asiento
Configurados complementos para asientos adicionales a $2/mes por asiento
Pago
Construida una API que genera sesiones de pago con cantidades de asientos personalizadas
Interfaz Web
Creada una interfaz web simple para probar diferentes cantidades de asientos
Este ejemplo demuestra solo una implementación mínima de precios por asiento. Para uso en producción, deberías agregar un manejo de errores robusto, autenticación, validación de datos, medidas de seguridad y adaptar la lógica para ajustarse a los requisitos de tu aplicación.