Skip to content

Async (and blocking!) Rust bindings for the Stripe API

License

Notifications You must be signed in to change notification settings

mzeitlin11/async-stripe

This branch is 87 commits behind arlyon/async-stripe:master.

Folders and files

NameName
Last commit message
Last commit date
Jan 10, 2024
Sep 6, 2023
Feb 21, 2024
Feb 20, 2024
Feb 27, 2024
May 25, 2023
Nov 11, 2022
Jan 17, 2023
Mar 23, 2021
Feb 21, 2024
Jul 30, 2022
Feb 27, 2024
Mar 14, 2017
Jan 17, 2019
Apr 6, 2023
Feb 20, 2024
May 9, 2023
Jan 29, 2022
May 19, 2023
May 19, 2023
May 19, 2023
May 19, 2023

Repository files navigation

async-stripe

CI async-stripe on crates.io async-stripe  on docs.rs

Convenient rust bindings and types for the Stripe HTTP API aiming to support the entire API surface. Not the case? Please open an issue. We update our definitions every week to ensure that we are up to date. Want to see a changelog of the Stripe API? Look no further.

Documentation

See the Rust API docs, the examples, or payments.rs.

Installation

async-stripe is compatible with the async-std and tokio runtimes and the native-tls and rustls backends. When adding the dependency, you must select a runtime feature.

[dependencies]
async-stripe = { version = "0.31", features = ["runtime-tokio-hyper"] }

Feature Flags

Runtimes

  • runtime-tokio-hyper
  • runtime-tokio-hyper-rustls
  • runtime-blocking
  • runtime-blocking-rustls
  • runtime-async-std-surf

API Features

Additionally, since this is a large library, it is possible to conditionally enable features as required to reduce compile times and final binary size. Refer to the Stripe API docs to determine which APIs are included as part of each feature flag.

# Example: Core-only (enough to create a `Charge` or `Card` or `Customer`)
async-stripe = { version = "*", default-features = false, features = ["runtime-async-std-surf"] }

# Example: Support for "Subscriptions" and "Invoices"
async-stripe = { version = "*", default-features = false, features = ["runtime-async-std-surf", "billing"] }

API Versions

This library always tracks the latest version of the stripe API.

https://github.com/arlyon/async-stripe/blob/f0fd7115aa3b7500134da10f848c8e93ba8eca2e/src/resources/generated/version.rs#L1-L3

If you want to find a version that matches the API you are on, you can easily navigate back through the git blame in that file. Set the corresponding crate version depending on which version of the Stripe API you are pinned to. If you don't see the specific version you are on, prefer the next available version.

MSRV

We currently have 1.68.0 pinned in CI, so any version of rustc newer than that should work. If this is not the case, please open an issue. As a policy, we permit MSRV increases in non-breaking releases. If you have a compelling usecase for bumping it, we are usually open to do so, as long as the rust version is not too new (generally 3 releases).

Contributing

See CONTRIBUTING.md for information on contributing to async-stripe.

License

This project started as a fork of stripe-rs. We would not be here without them! :)

Licensed under either of

at your option.

About

Async (and blocking!) Rust bindings for the Stripe API

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 100.0%