Skip to main content
NOWPayments Plugin

NOWPayments Plugin

Integrates NOWPayments cryptocurrency payment processing into your e-commerce store.

Latest version0.1.29
Compatibility^3.0.0
Last publishedDec 22, 2025
Vendure Community
Vendure CommunityOpen source plugins by the Vendure community

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 createNowPaymentsPaymentIntent mutation 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:

  1. Payment Intent Creation: Frontend calls createNowPaymentsPaymentIntent mutation to get a payment URL
  2. Customer Redirect: Customer is redirected to NOWPayments to complete payment
  3. Webhook Processing: NOWPayments sends IPN webhook to /nowpayments/ipn
  4. Automatic Payment Addition: Controller uses addPaymentToOrder to automatically add settled payments to orders
  5. 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:

Ts

NOWPayments Setup

1. Create a NOWPayments Account

  1. Sign up at nowpayments.io
  2. Complete KYC verification
  3. Get your API key from the dashboard

2. Configure IPN (Instant Payment Notification)

  1. Set your IPN URL to: https://yourdomain.com/nowpayments/ipn
  2. Get your IPN secret from the NOWPayments dashboard
  3. Ensure your server is accessible via HTTPS

3. Environment Variables

Bash

Usage

Payment Flow

The plugin follows a similar pattern to Stripe's payment flow:

  1. Customer selects NOWPayments during checkout
  2. Frontend calls createNowPaymentsPaymentIntent mutation to get the payment URL
  3. Customer is redirected to the NOWPayments payment page (direct link or invoice)
  4. Customer pays with their chosen cryptocurrency
  5. NOWPayments sends IPN webhook to your server
  6. Payment is automatically added to the order via addPaymentToOrder
  7. Order status is updated to PaymentSettled when payment is complete

Using the GraphQL Mutation

The plugin exposes a createNowPaymentsPaymentIntent mutation that returns a payment URL:

Graphql

Response:

Json

Example usage in your storefront:

Typescript

GraphQL Query:

Graphql

Payment Statuses

The plugin handles various payment statuses from NOWPayments IPN callbacks:

StatusOrder StateDescription
finishedPaymentSettledPayment completed successfully - payment is automatically added to order via addPaymentToOrder
partially_paidPaymentAuthorizedPartial payment received (metadata updated, payment remains authorized)
confirmingPaymentAuthorizedPayment is being confirmed on blockchain (metadata updated)
confirmedPaymentAuthorizedPayment confirmed on blockchain (metadata updated)
sendingPaymentAuthorizedPayment is being sent (metadata updated)
waitingPaymentAuthorizedPayment is waiting for user action (metadata updated)
expiredPaymentDeclinedPayment has expired - payment is cancelled
failedPaymentDeclinedPayment 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

OptionTypeRequiredDefaultDescription
apiKeystring-Your NOWPayments.io API key
ipnSecretstring-Your NOWPayments.io IPN secret
hoststring'http://localhost:3000'Your Vendure server host
sandboxbooleanfalseEnable sandbox mode for testing
useInvoicesbooleanfalseUse invoices instead of direct payment links
invoicePrefixstring'VC-'Prefix for invoice numbers (must not end with digit)
simpleTotalbooleanfalseUse simple total calculation
allowZeroConfirmbooleantrueAllow zero confirmation payments
formSubmissionMethodbooleantrueUse form submission method
debugEmailstring-Email for debug notifications
debugPostUrlstring-URL for debug POST notifications
is_fixed_ratebooleanfalseUse fixed rate pricing for cryptocurrency conversions
is_fee_paid_by_userbooleanfalseWhether 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 if useInvoices is 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

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 createNowPaymentsPaymentIntent mutation requires owner permission (customer must be authenticated)

Development

Building the Plugin

Running Tests

Bash

Development Mode

Troubleshooting

Common Issues

  1. IPN not received:

    • Check your server is accessible via HTTPS
    • Verify IPN URL is correct in NOWPayments dashboard
    • Check server logs for errors
  2. Invalid signature errors:

    • Verify IPN secret is correct
    • Ensure HMAC calculation is working properly
    • Check for encoding issues
  3. 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)
  4. Sandbox mode issues:

    • Ensure NOWPAYMENTS_SANDBOX=true is set
    • Use sandbox API keys for testing
    • Check sandbox endpoints are being used

Debug Mode

Enable debug mode by setting the environment variable:

Bash

This will log detailed information about payment processing and IPN handling.

Support

For support with this plugin:

  1. Check the Vendure documentation
  2. Review the NOWPayments documentation
  3. Check the server logs for error details
  4. 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

OK