If you're looking to install stripe.js, our clientside tokenization library - this is not it. These are serverside node.js bindings only.
These stripe-node bindings are intended to deal with secret keys, and to take actions that should not occur in the browser without compromising security. Additionally, stripe.js is not offered as an npm package, primarily for compliance reasons. We work very hard to have extremely high availability around the world and constant backwards compatibility when stripe.js is updated. You should include stripe.js (in most cases asyncronous script injection is a great choice) with the following url: https://js.stripe.com/v2/
Read about Version 2 here (Released October 18th, 2013)
npm install stripe --save
Documentation is available at https://stripe.com/docs/api/node.
Set your secret API key. This is available in your dashboard.
var stripe = require('stripe')(' your stripe API key ');
Every resource is accessed via your stripe
instance:
// stripe.{ RESOURCE_NAME }.{ METHOD_NAME }
Every resource method accepts an optional callback as the last argument:
stripe.customers.create(
{ email: '[email protected]' },
function(err, customer) {
err; // null if no error occurred
customer; // the created customer object
}
);
Additionally, every resource method returns a promise, so you don't have to use the regular callback. E.g.
// Create a new customer and then a new charge for that customer:
stripe.customers.create({
email: '[email protected]'
}).then(function(customer){
return stripe.customers.createSource(customer.id, {
source: {
object: 'card',
exp_month: 10,
exp_year: 2018,
number: '4242 4242 4242 4242',
cvc: 100
}
});
}).then(function(source) {
return stripe.charges.create({
amount: 1600,
currency: 'usd',
customer: source.customer
});
}).then(function(charge) {
// New charge created on a new customer
}).catch(function(err) {
// Deal with an error
});
To use the Stripe-Account
header, simply pass an extra options hash:
// Retrieve the balance for a connected account:
stripe.balance.retrieve({
stripe_account: "acct_foo"
}).then(function(balance) {
// The balance object for the connected account
}).catch(function(err) {
// Error
});
Where you see params
it is a plain JavaScript object, e.g. { email: '[email protected]' }
- accounts
retrieve(accountId)
create([params])
list([params])
update([params])
- applePayDomains
create(params)
list([params])
retrieve(applePayDomainId)
del(applePayDomainId)
- balance
retrieve()
listTransactions([params])
retrieveTransaction(transactionId)
- charges
create(params)
list([params])
retrieve(chargeId)
capture(chargeId[, params])
update(chargeId[, params])
updateDispute(chargeId[, params])
closeDispute(chargeId[, params])
setMetadata(chargeId, metadataObject)
(metadata info)setMetadata(chargeId, key, value)
getMetadata(chargeId)
markAsSafe(chargeId)
markAsFraudulent(chargeId)
- coupons
create(params)
list([params])
update(couponId[, params])
retrieve(couponId)
del(couponId)
- customers
create(params)
list([params])
update(customerId[, params])
retrieve(customerId)
del(customerId)
listSources(customerId)
deleteSource(customerId, {source: 'source_token'})
setMetadata(customerId, metadataObject)
(metadata info)setMetadata(customerId, key, value)
getMetadata(customerId)
createSubscription(customerId, params)
updateSubscription(customerId, subscriptionId, [, params])
cancelSubscription(customerId, subscriptionId, [, params])
listSubscriptions(params)
retrieveSubscription(customerId, subscriptionId)
createSource(customerId[, params])
listCards(customerId)
retrieveCard(customerId, cardId)
updateCard(customerId, cardId[, params])
deleteCard(customerId, cardId)
deleteDiscount(customerId)
- events (types of events)
list([params])
retrieve(eventId)
- invoiceItems
create(params)
list([params])
update(invoiceItemId[, params])
retrieve(invoiceItemId)
del(invoiceItemId)
- invoices
create(params)
list([params])
update(invoiceId[, params])
retrieve(invoiceId)
retrieveLines(invoiceId)
retrieveUpcoming(customerId[, params])
pay(invoiceId)
- orders
create(params)
list([params])
update(orderId[, params])
retrieve(orderId)
pay(orderId)
- orderReturns
list([params])
retrieve(orderId)
- plans
create(params)
list([params])
update(planId[, params])
retrieve(planId)
del(planId)
- products
create(params)
list([params])
update(productId[, params])
retrieve(productId)
del(productId)
- recipients
create(params)
list([params])
update(recipientId[, params])
retrieve(recipientId)
del(recipientId)
setMetadata(recipientId, metadataObject)
(metadata info)setMetadata(recipientId, key, value)
- refunds
create(params)
list([params])
update(refundId[, params])
retrieve(refundId)
- skus
create(params)
list([params])
update(skuId[, params])
retrieve(skuId)
del(skuId)
- subscriptions
create(params)
list([params])
update(subscriptionID[, params])
retrieve(subscriptionId)
del(subscriptionId)
- tokens
create(params)
retrieve(tokenId)
- threeDSecure
create(params)
- transfers
create(params)
list([params])
retrieve(transferId)
update(transferId[, params])
reverse(transferId[, params])
cancel(transferId)
(Deprecated -- usereverse
)listTransactions(transferId[, params])
setMetadata(transferId, metadataObject)
(metadata info)setMetadata(transferId, key, value)
getMetadata(transferId)
- bitcoinReceivers
create(params)
retrieve(receiverId)
list([params])
getMetadata(receiverId)
stripe.setApiKey(' your secret api key ');
stripe.setTimeout(20000); // in ms
(default is node's default:120000ms
)
- In-depth Documentation
- Version 2 Overview
- REST API Version
- Error Handling
- Passing Options
- Using Stripe Connect
Run all tests:
$ npm install
$ npm test
Run a single test suite:
$ npm run mocha -- test/Error.spec.js
Run a single test (case sensitive):
$ npm run mocha -- test/Error.spec.js --grep 'Populates with type'
If you wish, you may run tests using your Stripe Test API key by setting the environment variable STRIPE_TEST_API_KEY
before running tests:
$ export STRIPE_TEST_API_KEY='sk_test....'
$ npm test
Note: On Windows use SET
instead of export
for setting the STRIPE_TEST_API_KEY
environment variable.
If you don't have a prefixed key (in the form sk_test_...
) you can get one by rolling your "Test Secret Key". This can be done under your dashboard (Account Setting -> API Keys -> Click the roll icon next to the "test secret key"). This should give you a new prefixed key ('sk_test_..'), which will then be usable by the node mocha tests.
Originally by Ask Bjørn Hansen ([email protected]). Development was sponsored by YellowBot. Now officially maintained by Stripe.