Las API para PDT e IPN son similares. La principal diferencia es cuando recibe la notificación. Por esa razón, recomendaría implementar ambos.
- Con PDT, recibe la notificación al instante y puede realizar cualquier procesamiento adicional necesario y mostrar al usuario una página de confirmación.
- Con IPN se le garantiza que se le notificará que se recibió el pago incluso si la computadora del usuario explota antes de que pueda enviarle el PDT.
Implemente ambos y obtenga lo mejor de ambos mundos. Pero si solo está haciendo uno, IPN es el confiable.
Un inconveniente: si implementa ambos, existe la posibilidad de que sus pagos se procesen dos veces. Tenga cuidado de asegurarse de que eso no suceda. La aplicación que escribí maneja el PDT y el IPN de manera casi idéntica (la parte del backend es la misma) y ese código adquiere un bloqueo por usuario web en la base de datos, de modo que si el mismo usuario intenta enviar el mismo pago exacto varias veces, solo se puede procesar una vez. Una vez procesado, el resultado de ese proceso se reutiliza para cualquier intento posterior de procesarlo.
Editar
Una cosa más: IPN lleva más información que PDT. Hay muchos mensajes diferentes que puede recibir de IPN, como notificación de devolución de cargo, etc., y por lo tanto, realmente debería implementarlo.
El sistema PDT de PayPal envía confirmaciones de pedidos a sitios de comerciantes que utilizan PayPal Payments Standard y les permite autenticar esta información. Estos sitios pueden mostrar estos datos localmente en una página de "confirmación de pedido".
¿Cuándo usar PDT?
IPN proporciona las mismas capacidades descritas anteriormente. Entonces, ¿cuándo debería elegir PDT en lugar de IPN?
Con PDT, su sitio recibe una notificación de inmediato cuando un cliente completa el pago. Sin embargo, con IPN, existe un retraso material entre el momento en que un cliente completa el pago y el momento en que su sitio recibe la notificación de este evento.
Por lo tanto, use PDT si su sitio incluye una función que requiere una notificación de pago inmediata.
Por ejemplo, considere una tienda de música digital. Con PDT, esta tienda puede permitir que los clientes descarguen sus compras de inmediato, ya que PDT envía confirmaciones de pedidos de inmediato. Con IPN, no es posible el cumplimiento inmediato de pedidos.
Ventajas de IPN
PDT tiene una gran debilidad: envía confirmaciones de pedidos una vez y solo una vez. Como resultado, cuando PDT envía una confirmación, su sitio debe estar ejecutándose; de lo contrario, nunca recibirá el mensaje.
Con IPN, por el contrario, la entrega de confirmaciones de pedidos está prácticamente garantizada, ya que IPN reenvía una confirmación hasta que su sitio acuse recibo. Por esta razón, PayPal recomienda que implemente IPN en lugar de PDT.
Otra ventaja de IPN es que envía muchos tipos de notificaciones, mientras que PDT envía solo confirmaciones de pedidos. Por lo tanto, al usar IPN, su sitio puede recibir, por ejemplo, notificaciones de contracargos y confirmaciones de pedidos. Nota: Si su sitio debe ser notificado de los pagos de inmediato, puede implementar tanto IPN como PDT. Sin embargo, si lo hace, su sitio recibirá dos confirmaciones de pedido por cada venta. Como resultado, debe tener cuidado de tomar medidas (por ejemplo, enviar un producto) en solo una copia de un mensaje de confirmación determinado.
Documentación aquí