Crates.io | paypal-rust |
lib.rs | paypal-rust |
version | 0.0.9-alpha |
source | src |
created_at | 2022-09-29 16:33:33.004467 |
updated_at | 2023-05-30 09:53:10.155113 |
description | Rust bindings for the PayPal REST API |
homepage | https://github.com/HannTechGmbH/paypal-rust/ |
repository | https://github.com/HannTechGmbH/paypal-rust/ |
max_upload_size | |
id | 676767 |
size | 301,326 |
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.
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);
}
This library offers a "utils" feature that enables the utils
module. This module contains
some useful functions for working with the PayPal API.