Swiftpack.co - Package - vapor-community/stripe-provider

Vapor Stripe Provider

Swift Vapor CircleCI

Stripe is a payment platform that handles credit cards, bitcoin and ACH transfers. They have become one of the best platforms for handling payments for projects, services or products.

Getting Started

In your Package.swift file, add the following

.package(url: "https://github.com/vapor-community/stripe-provider.git", from: "2.2.0")

Register the config and the provider to your Application

let config = StripeConfig(apiKey: "sk_12345678")


try services.register(StripeProvider())

app = try Application(services: services)

stripeClient = try app.make(StripeClient.self)

And you are all set. Interacting with the API is quite easy and adopts the Future syntax used in Vapor 3. Making calls to the api is straight forward.

let cardParams = ["exp_month": 1,
                  "exp_year": 2030,
                  "number": "4242424242424242",
                  "cvc": 123,
                  "object": "card"]

let futureCharge = try stripeClient.charge.create(amount: 2500, currency: .usd, source: cardParams)

futureCharge.do({ (charge) in
    // do something with charge object...
}).catch({ (error) in

And you can always check the documentation to see the required paramaters for specific API calls.

Whats Implemented

Core Resources

  • [x] Balance
  • [x] Charges
  • [x] Customers
  • [x] Disputes
  • [ ] Events
  • [x] File Links
  • [x] File Uploads
  • [x] Payouts
  • [x] Refunds
  • [x] Tokens

Payment Methods

  • [x] Bank Accounts
  • [x] Cards
  • [x] Sources


  • [x] Coupons
  • [x] Discounts
  • [x] Invoices
  • [x] Invoice Items
  • [x] Plans
  • [x] Subscriptions
  • [x] Subscription items


  • [x] Account
  • [ ] Application Fee Refunds
  • [ ] Application Fees
  • [ ] Country Specs
  • [x] External Accounts
  • [x] Transfers
  • [x] Transfer Reversals


  • [x] Orders
  • [x] Order Items
  • [x] Products
  • [x] Returns
  • [x] SKUs
  • [x] Ephemeral Keys


Vapor Stripe Provider is available under the MIT license. See the LICENSE file for more info.

Want to help?

Feel free to submit a pull request whether it's a clean up, a new approach to handling things, adding a new part of the API, or even if it's just a typo. All help is welcomed! 😀


Stars: 96
Help us keep the lights on



2.2.6 - Jan 7, 2019

Properly encodes the Stripe Terms of Acceptance date as an epoch date.

2.2.5 - Jan 5, 2019

Connect Account creation now accept all parameters

2.2.4 - Oct 18, 2018

2.2.3 - Oct 10, 2018

2.2.2 - Oct 8, 2018

Fixes a URL correction on the sources endpoint