Rust API bindings for the Stripe v1 HTTP API.
This is compatible with all currently supported versions of Stripe's client-side libraries including https://js.stripe.com/v2/ and https://js.stripe.com/v3/.
Put this in your Cargo.toml
:
toml
[dependencies]
stripe-rust = "0.10.2"
And this in your crate root:
rust
extern crate stripe;
To see how the library is used, look through the examples folder.
To get started, we need to create a client:
rust
let client = stripe::Client::new("sk_test_YOUR_STRIPE_SECRET");
Then we can begin making requests as we'd like. Most Stripe requests accept
many optional parameters, so we usually get the ::default()
params and then
set the ones we want from there.
Most requests for creating or updating a Stripe object use the same Rust struct, so you may frequently need to refer to the official API docs to determine which fields are required for either request.
```rust /* Creating a Stripe Charge */
let token = "TOKENFROMCHECKOUT".parse().expect("token to be valid"); let mut params = stripe::CreateCharge::new();
// NOTE: Stripe represents currency in the lowest denominations (e.g. cents) params.amount = Some(1095); // e.g. $10.95 params.source = Some(stripe::PaymentSourceParams::Token(token));
// Example: Override currency to be in Canadian Dollars params.currency = Some(stripe::Currency::CAD);
let charge = stripe::Charge::create(&client, params).unwrap(); println!("{:?}", charge); // => Charge { id: "ch_12345", amount: 1095, .. } ```
```rust /* Listing Stripe Charges */
let params = stripe::ListCharges::new(); let charges = stripe::Charge::list(&client, params).unwrap(); println!("{:?}", charges); // => List { data: [Charge { id: "ch_12345", .. }] } ```
This crate supports impersonating a custom connect account.
To impersonate the account get a new Client and pass in the account id.
```rust let client = client.withheaders(stripe::Headers { stripeaccount: Some("acctABC".tostring()), clientid: Some("caXYZ".to_string()) });
// Then, all requests can be made normally let params = stripe::CustomerListParams::default(); let customers = stripe::Customer::list(&client, params).unwrap(); println!("{:?}", customers); // => List { data: [Customer { .. }] } ```