NOWPayments Plugin
Integrates NOWPayments cryptocurrency payment processing into your e-commerce store.
A cryptocurrency payment gateway plugin for Vendure that integrates with NOWPayments.io, enabling your store to accept payments in Bitcoin, Ethereum, and 100+ other cryptocurrencies.
Features
- ✅ Cryptocurrency Payments: Accept payments in Bitcoin, Ethereum, Litecoin, and 100+ other cryptocurrencies
- ✅ Dual Payment Modes: Support for both direct payment links and invoices
- ✅ Secure IPN Handling: Instant Payment Notification webhook processing with HMAC signature verification
- ✅ Multiple Payment Statuses: Handle finished, partially_paid, confirming, confirmed, sending, and failed payments
- ✅ Sandbox Mode: Test your integration safely with sandbox endpoints
- ✅ Configurable Options: Customizable invoice prefixes, total calculations, and debug settings
- ✅ Full IPN Storage: Complete IPN response storage with outcome_currency tracking
- ✅ TypeScript Support: Full type definitions for excellent developer experience
- ✅ GraphQL API: Exposes
createNowPaymentsPaymentIntentmutation for easy integration - ✅ Automatic Payment Processing: Payments are automatically added to orders via webhook callbacks
- ✅ Stripe-like Architecture: Follows the same payment flow pattern as Vendure's Stripe plugin for consistency
Architecture
This plugin follows the same architectural pattern as Vendure's official Stripe plugin:
- Payment Intent Creation: Frontend calls
createNowPaymentsPaymentIntentmutation to get a payment URL - Customer Redirect: Customer is redirected to NOWPayments to complete payment
- Webhook Processing: NOWPayments sends IPN webhook to
/nowpayments/ipn - Automatic Payment Addition: Controller uses
addPaymentToOrderto automatically add settled payments to orders - Payment Handler: Payment method handler processes the payment and sets appropriate state
This architecture ensures consistency with other Vendure payment plugins and makes integration straightforward.
Installation
Configuration
Add the plugin to your Vendure config:
NOWPayments Setup
1. Create a NOWPayments Account
- Sign up at nowpayments.io
- Complete KYC verification
- Get your API key from the dashboard
2. Configure IPN (Instant Payment Notification)
- Set your IPN URL to:
https://yourdomain.com/nowpayments/ipn - Get your IPN secret from the NOWPayments dashboard
- Ensure your server is accessible via HTTPS
3. Environment Variables
Usage
Payment Flow
The plugin follows a similar pattern to Stripe's payment flow:
- Customer selects NOWPayments during checkout
- Frontend calls
createNowPaymentsPaymentIntentmutation to get the payment URL - Customer is redirected to the NOWPayments payment page (direct link or invoice)
- Customer pays with their chosen cryptocurrency
- NOWPayments sends IPN webhook to your server
- Payment is automatically added to the order via
addPaymentToOrder - Order status is updated to
PaymentSettledwhen payment is complete
Using the GraphQL Mutation
The plugin exposes a createNowPaymentsPaymentIntent mutation that returns a payment URL:
Response:
Example usage in your storefront:
GraphQL Query:
Payment Statuses
The plugin handles various payment statuses from NOWPayments IPN callbacks:
| Status | Order State | Description |
|---|---|---|
finished | PaymentSettled | Payment completed successfully - payment is automatically added to order via addPaymentToOrder |
partially_paid | PaymentAuthorized | Partial payment received (metadata updated, payment remains authorized) |
confirming | PaymentAuthorized | Payment is being confirmed on blockchain (metadata updated) |
confirmed | PaymentAuthorized | Payment confirmed on blockchain (metadata updated) |
sending | PaymentAuthorized | Payment is being sent (metadata updated) |
waiting | PaymentAuthorized | Payment is waiting for user action (metadata updated) |
expired | PaymentDeclined | Payment has expired - payment is cancelled |
failed | PaymentDeclined | Payment failed - payment is cancelled |
Note: Only finished status payments are automatically added to orders. Other statuses update payment metadata but don't settle the payment.
Configuration Options
| Option | Type | Required | Default | Description |
|---|---|---|---|---|
apiKey | string | ✅ | - | Your NOWPayments.io API key |
ipnSecret | string | ✅ | - | Your NOWPayments.io IPN secret |
host | string | ❌ | 'http://localhost:3000' | Your Vendure server host |
sandbox | boolean | ❌ | false | Enable sandbox mode for testing |
useInvoices | boolean | ❌ | false | Use invoices instead of direct payment links |
invoicePrefix | string | ❌ | 'VC-' | Prefix for invoice numbers (must not end with digit) |
simpleTotal | boolean | ❌ | false | Use simple total calculation |
allowZeroConfirm | boolean | ❌ | true | Allow zero confirmation payments |
formSubmissionMethod | boolean | ❌ | true | Use form submission method |
debugEmail | string | ❌ | - | Email for debug notifications |
debugPostUrl | string | ❌ | - | URL for debug POST notifications |
is_fixed_rate | boolean | ❌ | false | Use fixed rate pricing for cryptocurrency conversions |
is_fee_paid_by_user | boolean | ❌ | false | Whether transaction fees are paid by the user |
Supported Cryptocurrencies
- Bitcoin (BTC)
- Ethereum (ETH)
- Litecoin (LTC)
- Bitcoin Cash (BCH)
- Ripple (XRP)
- Cardano (ADA)
- Polkadot (DOT)
- Chainlink (LINK)
- And 100+ more...
API Extensions
The plugin extends the Vendure GraphQL API with the following:
GraphQL Mutations
createNowPaymentsPaymentIntent: String!- Creates a payment intent and returns the payment URL (invoice URL ifuseInvoicesis enabled, otherwise payment URL)- Requires: Owner permission (customer must be logged in)
- Returns: Payment URL string that the customer should be redirected to
Payment Method Handler
nowpayments- The payment method handler for NOWPayments
IPN Webhook Endpoint
POST /nowpayments/ipn- Webhook endpoint for NOWPayments IPN callbacks- Headers:
x-nowpayments-sig(HMAC signature for verification) - Body: NOWPayments IPN payload (JSON)
- Automatically processes payments and adds them to orders via
addPaymentToOrder
- Headers:
Payment Flow URLs
The plugin automatically generates the following URLs for payment flows:
- Success URL:
{host}/checkout/confirmation/{orderCode}- Redirected to after successful payment - Cancel URL:
{host}/checkout/cancel/{orderCode}- Redirected to if payment is cancelled - IPN URL:
{host}/nowpayments/ipn- Webhook endpoint for payment notifications
Note: Replace {host} with your actual Vendure server URL (e.g., https://yourdomain.com).
Security Features
- HMAC Signature Verification: All IPN requests are verified using SHA512 HMAC before processing
- Order Validation: Payment amounts and currencies are validated against order totals
- Secure API Communication: All API calls use HTTPS
- Transaction Safety: Webhook processing uses database transactions to ensure data consistency
- Error Logging: Comprehensive error logging for debugging
- Owner-Only Mutations: The
createNowPaymentsPaymentIntentmutation requires owner permission (customer must be authenticated)
Development
Building the Plugin
Running Tests
Development Mode
Troubleshooting
Common Issues
-
IPN not received:
- Check your server is accessible via HTTPS
- Verify IPN URL is correct in NOWPayments dashboard
- Check server logs for errors
-
Invalid signature errors:
- Verify IPN secret is correct
- Ensure HMAC calculation is working properly
- Check for encoding issues
-
Payment not settling:
- Check payment status in NOWPayments dashboard (must be
finished) - Verify order ID format matches expected pattern (includes invoice prefix if used)
- Review server logs for processing errors
- Ensure IPN webhook is being received and processed
- Check that payment status is
finished(only finished payments are added to orders)
- Check payment status in NOWPayments dashboard (must be
-
Sandbox mode issues:
- Ensure
NOWPAYMENTS_SANDBOX=trueis set - Use sandbox API keys for testing
- Check sandbox endpoints are being used
- Ensure
Debug Mode
Enable debug mode by setting the environment variable:
This will log detailed information about payment processing and IPN handling.
Support
For support with this plugin:
- Check the Vendure documentation
- Review the NOWPayments documentation
- Check the server logs for error details
- Contact support with specific error messages and logs
License
This plugin is licensed under the MIT License.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Changelog
See CHANGELOG.md for a list of changes between versions.
Add Release commit

