Continuous integration status:
Repository for PayPal's Node SDK (node.js version >=0.6.x) and Node samples for REST API. For a full working app and documentation, have a look at the PayPal Node SDK Page.
v1.0.0 notice: If upgrading from paypal rest sdk 0.*, Please view Breaking Changes in release_notes.md
The Payment Card Industry (PCI) Council has mandated that early versions of TLS be retired from service. All organizations that handle credit card information are required to comply with this standard. As part of this obligation, PayPal is updating its services to require TLS 1.2 for all HTTPS connections. At this time, PayPal will also require HTTP/1.1 for all connections. See the PayPal TLS Update repository for more information.
**TLSv1_2 warning: Due to PCI compliance, merchant servers using a version of TLS that does not support TLSv1_2 will receive a warning.
**To verify that your server supports PCI compliant version of TLS, run this sample with your sandbox credentials.
npm install paypal-rest-sdk
To write an app using the SDK
Register for a developer account and get your client_id and secret at PayPal Developer Portal.
Add dependency 'paypal-rest-sdk' in your package.json file.
Require 'paypal-rest-sdk' in your file
var paypal = ;
Create config options, with parameters (mode, client_id, secret).
For multiple configuration support, have a look at the sample
Invoke the rest api (eg: store a credit card) with required parameters (eg: data, config_options, callback).
var card_data ="type": "visa""number": "4417119669820331""expire_month": "11""expire_year": "2018""cvv2": "123""first_name": "Joe""last_name": "Shopper";paypalcreditCard
For exploring additional payment capabilites, such as handling discounts, insurance, soft_descriptor and invoice_number, have a look at this example. These bring REST payment functionality closer to parity with older Merchant APIs.
Customizing a PayPal payment experience is available as of version 1.1.0 enabling merchants to provide a customized experience to consumers from the merchant’s website to the PayPal payment. Get started with the supported rest methods and samples.
To receive notifications from PayPal about Payment events on your server, webhook support is now available as of version 1.2.0. For creating and managing Webhook and Webhook Events, check out the samples to see how you can use the node sdk to manage webhooks, webhook events and verify that the response unaltered and is really from PayPal. Please follow the Webhook Validation sample to understand how to verify the authenticity of webhook messages. It is also important to note that simulated messages generated using the Webhook simulator would not be compatible with the verification process since they are only mock data.
To use OpenID Connect
// OpenID configurationpaypal;// Authorize urlpaypalopenIdConnect;// Get tokeninfo with Authorize codepaypalopenIdConnecttokeninfo;// Get tokeninfo with Refresh codepaypalopenIdConnecttokeninfo;// Get userinfo with Access codepaypalopenIdConnectuserinfo;// Logout urlpaypalopenIdConnect;
Instructions for running samples are located in the sample directory.
To run the test suite first invoke the following command within the repo
If Grunt is not installed:
npm install -g grunt-cli
If Mocha is not installed:
npm install -g mocha
To install the development dependencies (run where the
Run the tests:
To run the tests without the mocks:
NOCK_OFF=true mocha -t 60000
As of version 1.6.2, full request/response are logged for non production environments with NODE_ENV=development set
You can set the environment variable on the command line by running
NODE_ENV=development node <path of script> or by executing
export NODE_ENV=development and then running your Node.js script. Please see your command terminal/shell's manual pages for specific information.
It is recommended to provide Paypal-Debug-Id if requesting PayPal Merchant Technical Services for support. You can get access to the debug id by setting environment variable NODE_ENV=development.
The error object returned for any bad request has error.response populated with details. NODE_ENV=development setting also gives you access to stringfied response in error messages.
[REST API Reference] (https://developer.paypal.com/webapps/developer/docs/api/)
Code released under SDK LICENSE
Pull requests and new issues are welcome. See CONTRIBUTING.md for details.