Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

node.js SDK for PayPal RESTful APIs

License

NotificationsYou must be signed in to change notification settings

sergeyleschev/PayPal-node-SDK

 
 

Repository files navigation

This SDK is deprecated. You can continue to use it, but no new features or support requests will be accepted.For alternatives, please visitthe current SDK homepage on the PayPal Developer Portal

PayPal REST SDK

Continuous integration status:

Build StatusCoverage StatusGitter chat

NPM status:

NPM versionDependency 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 thePayPal Node SDK Page.

2.0 Beta: We now have a 2.0 beta available, featuring promise support, and a revamped integration. Check out the2.0-beta branch for details, or runnpm install paypal-rest-sdk@beta.

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 hasmandated 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 thePayPal 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, test against the PayPal sandbox environment which uses TLS 1.2.

Direct Credit Card Support

Important: The PayPal REST API no longer supports new direct credit card integrations. Please instead considerBraintree Direct; which is, PayPal's preferred integration solution for accepting direct credit card payments in your mobile app or website. Braintree, a PayPal service, is the easiest way to accept credit cards, PayPal, and many other payment methods.

PayPal Checkout v2

Please note that if you are integrating with PayPal Checkout, this SDK and corresponding APIv1/payments are in the process of being deprecated.

We recommend that you integrate with APIv2/checkout/orders andv2/payments. Please refer to theCheckout Node.js SDK to continue with the integration.

2.0 Release Candidate!

We're releasing abrand new version of our SDK! 2.0 is currently at release candidate status, and represents a full refactor, with the goal of making all of our APIs extremely easy to use. 2.0 includes all of the existing APIs (except payouts), and includes the new Orders API (disputes and Marketplace coming soon). Check out theFAQ and migration guide, and let us know if you have any suggestions or issues!

Installation

npm install paypal-rest-sdk

Usage

To write an app using the SDK

  • Register for a developer account and get your client_id and secret atPayPal Developer Portal.

  • Add dependency 'paypal-rest-sdk' in your package.json file.

  • Require 'paypal-rest-sdk' in your file

    varpaypal=require('paypal-rest-sdk');
  • Create config options, with parameters (mode, client_id, secret).

    paypal.configure({'mode':'sandbox',//sandbox or live'client_id':'EBWKjlELKMYqRNQ6sYvFo64FtaRLRR5BdHEESmha49TM','client_secret':'EO422dn3gQLgDbuwqTjzrFgFtaRLRR5BdHEESmha49TM'});
  • For multiple configuration support, have a look at thesample

  • Invoke the rest api (eg: create a PayPal payment) with required parameters (eg: data, config_options, callback).

    varcreate_payment_json={"intent":"sale","payer":{"payment_method":"paypal"},"redirect_urls":{"return_url":"http://return.url","cancel_url":"http://cancel.url"},"transactions":[{"item_list":{"items":[{"name":"item","sku":"item","price":"1.00","currency":"USD","quantity":1}]},"amount":{"currency":"USD","total":"1.00"},"description":"This is the payment description."}]};paypal.payment.create(create_payment_json,function(error,payment){if(error){throwerror;}else{console.log("Create Payment Response");console.log(payment);}});
  • For creatingSubscription Payments, check out thesamples for creating planned sets of future recurring payments at periodic intervals.

  • To createFuture Payments, check out thissample for executing future payments for a customer who has granted consent on a mobile device.

  • Forexploring additional payment capabilites, such as handling discounts, insurance, soft_descriptor and invoice_number, have a look at thisexample. These bring REST payment functionality closer to parity with older Merchant APIs.

  • Customizing aPayPal 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 thesupported rest methods andsamples.

  • For creating and managingOrders, i.e. getting consent from buyer for a purchase but only placing the funds on hold when the merchant is ready to fulfill theorder, have a look atsamples.

  • For creatingbatch and single payouts, check out the samples forpayouts andpayout items. ThePayouts feature enables you to make PayPal payments to multiple PayPal accounts in a single API call.

  • ForInvoicing, check out thesamples to see how you can use the node sdk to create, send and manage invoices.

  • To receivenotifications from PayPal about Payment events on your server, webhook support is now available as of version 1.2.0. For creating and managingWebhook and Webhook Events, check out thesamples to see how you can use the node sdk to manage webhooks, webhook events andverify that the response unaltered and is really from PayPal. Please follow theWebhook Validation sample to understand how to verify the authenticity of webhook messages. It is also important to note that simulated messages generated using theWebhook simulator would not be compatible with the verification process since they are only mock data.

  • To use OpenID Connect

    // OpenID configurationpaypal.configure({'openid_client_id':'CLIENT_ID','openid_client_secret':'CLIENT_SECRET','openid_redirect_uri':'http://example.com'});// Authorize urlpaypal.openIdConnect.authorizeUrl({'scope':'openid profile'});// Get tokeninfo with Authorize codepaypal.openIdConnect.tokeninfo.create("Replace with authorize code",function(error,tokeninfo){console.log(tokeninfo);});// Get tokeninfo with Refresh codepaypal.openIdConnect.tokeninfo.refresh("Replace with refresh_token",function(error,tokeninfo){console.log(tokeninfo);});// Get userinfo with Access codepaypal.openIdConnect.userinfo.get("Replace with access_code",function(error,userinfo){console.log(userinfo);});// Logout urlpaypal.openIdConnect.logoutUrl("Replace with tokeninfo.id_token");

Running Samples

Instructions for running samples are located in thesample directory.

Running Tests

To run the test suite first invoke the following command within the repo

IfGrunt is not installed:

npm install -g grunt-cli

IfMocha is not installed:

npm install -g mocha

To install the development dependencies (run where thepackage.json is):

npm install

Run the tests:

grunttest (timeout is specifiedin milliseconds eg: 15000ms)

To run the tests without the mocks:

NOCK_OFF=true mocha -t 60000

Debugging

  • As of version 1.6.2, full request/response are logged for non production environments with PAYPAL_DEBUG set

    You can set the environment variable on the command line by runningPAYPAL_DEBUG=1 node <path of script> or by executingexport PAYPAL_DEBUG=1 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 PAYPAL_DEBUG=1.

  • The error object returned for any bad request has error.response populated withdetails. PAYPAL_DEBUG=1 setting also gives you access to stringfied response in error messages.

Reference

[REST API Reference] (https://developer.paypal.com/webapps/developer/docs/api/)

Contribution

  • If you would like to contribute, please fork the repo and send in a pull request.
  • Please ensure you run grunt before sending in the pull request.

License

Code released underSDK LICENSE

Contributions

Pull requests and new issues are welcome. SeeCONTRIBUTING.md for details.

About

node.js SDK for PayPal RESTful APIs

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript98.7%
  • Other1.3%

[8]ページ先頭

©2009-2025 Movatter.jp