stripe-rust
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/.
Usage
Put this in your Cargo.toml
:
[]
= "0.4.5"
And this in your crate root:
extern crate stripe;
To see how the library is used, look through the examples folder.
Getting Started
To get started, we need to create a client:
let client = new;
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.
/* Creating a Stripe Charge */
let token = "TOKEN_FROM_CHECKOUT";
let mut params = default;
// NOTE: Stripe represents currency in the lowest denominations (e.g. cents)
params.amount = Some; // e.g. $10.95
params.source = Some;
// Example: Override currency to be in Canadian Dollars
params.currency = Some;
let charge = create.unwrap;
println!; // => Charge { id: "ch_12345", amount: 1095, .. }
/* Listing Stripe Charges */
let params = default;
let charges = list.unwrap;
println!; // => List { data: [Charge { id: "ch_12345", .. }] }
Using Custom Connect accounts
This crate supports impersonating a custom connect account.
To impersonate the account get a new Client and pass in the account id.
let client = client.with;
// Then, all requests can be made normally
let params = default;
let customers = list.unwrap;
println!; // => List { data: [Customer { .. }] }