11 releases
0.0.9-alpha | May 30, 2023 |
---|---|
0.0.8-alpha | Mar 8, 2023 |
0.0.6-alpha | Feb 27, 2023 |
0.0.5-alpha | Jan 8, 2023 |
0.0.2-alpha.1 | Sep 30, 2022 |
#84 in Finance
230KB
5K
SLoC
paypal-rust
Rust bindings for the PayPal REST API.
This library is a work in progress. While functional, it is not yet advised to be used in production (The API will change, tests are not yet complete, etc).
For more information on the PayPal REST API, visit the PayPal Developer Portal. We aren't affiliated with PayPal in any way and this library is not endorsed by them.
Usage
use dotenv::dotenv;
use paypal_rust::client::AppInfo;
use paypal_rust::{
AmountWithBreakdown, Client, CreateOrderDto, CurrencyCode, Environment, Order,
OrderApplicationContext, OrderIntent, PurchaseUnitRequest
};
#[tokio::main]
async fn main() {
dotenv().ok();
let username = std::env::var("CLIENT_ID").expect("CLIENT_ID must be set");
let password = std::env::var("CLIENT_SECRET").expect("CLIENT_SECRET must be set");
let client = Client::new(username, password, Environment::Sandbox)
.unwrap()
.with_app_info(AppInfo {
name: "PayPal Rust Test App".to_string(),
version: "1.0".to_string(),
website: None,
});
client.authenticate().await.unwrap();
let order = Order::create(
&client,
CreateOrderDto {
intent: OrderIntent::Capture,
payer: None,
purchase_units: vec![PurchaseUnitRequest::new(AmountWithBreakdown::new(
CurrencyCode::Euro,
"10.00".to_string(),
))],
application_context: Some(
OrderApplicationContext::new()
.return_url("https://example.com/#/return".to_string())
.cancel_url("https://example.com/#/cancel".to_string()),
),
},
).await.unwrap();
println!("Created order: {:?}", order);
}
Features
This library offers a "utils" feature that enables the utils
module. This module contains
some useful functions for working with the PayPal API.
Dependencies
~12–28MB
~370K SLoC