use super::common::*;
#[derive(Debug, Clone, serde::Serialize, serde::Deserialize)]
pub struct Customer {
pub customer_id: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub personal_details: Option<PersonalDetails>,
}
#[derive(Debug, Clone, Default, serde::Serialize, serde::Deserialize)]
pub struct PaymentInstrumentResponse {
#[serde(skip_serializing_if = "Option::is_none")]
pub token: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub active: Option<bool>,
#[serde(rename = "type")]
#[serde(skip_serializing_if = "Option::is_none")]
pub r#type: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub card: Option<PaymentInstrumentResponseCard>,
#[serde(skip_serializing_if = "Option::is_none")]
pub mandate: Option<MandateResponse>,
#[serde(skip_serializing_if = "Option::is_none")]
pub created_at: Option<crate::datetime::DateTime>,
}
#[derive(Debug, Clone, Default, serde::Serialize, serde::Deserialize)]
pub struct PaymentInstrumentResponseCard {
#[serde(skip_serializing_if = "Option::is_none")]
pub last_4_digits: Option<String>,
#[serde(rename = "type")]
#[serde(skip_serializing_if = "Option::is_none")]
pub r#type: Option<CardType>,
}
#[derive(Debug, Clone, Default, serde::Serialize, serde::Deserialize)]
pub struct UpdateBody {
#[serde(skip_serializing_if = "Option::is_none")]
pub personal_details: Option<PersonalDetails>,
}
pub type ListPaymentInstrumentsResponse = Vec<PaymentInstrumentResponse>;
use crate::client::Client;
#[derive(Debug)]
pub enum CreateErrorBody {
BadRequest,
Unauthorized(Problem),
Forbidden(ErrorForbidden),
Conflict(Error),
}
#[derive(Debug)]
pub enum GetErrorBody {
Unauthorized(Problem),
Forbidden(ErrorForbidden),
NotFound(Error),
}
#[derive(Debug)]
pub enum UpdateErrorBody {
Unauthorized(Problem),
Forbidden(ErrorForbidden),
NotFound(Error),
}
#[derive(Debug)]
pub enum ListPaymentInstrumentsErrorBody {
Unauthorized(Problem),
Forbidden(ErrorForbidden),
NotFound(Error),
}
#[derive(Debug)]
pub enum DeactivatePaymentInstrumentErrorBody {
BadRequest(Error),
Unauthorized(Problem),
Forbidden(ErrorForbidden),
NotFound(Error),
}
#[derive(Debug)]
pub struct CustomersClient<'a> {
client: &'a Client,
}
impl<'a> CustomersClient<'a> {
pub(crate) fn new(client: &'a Client) -> Self {
Self { client }
}
pub fn client(&self) -> &Client {
self.client
}
pub async fn create(
&self,
body: Customer,
) -> crate::error::SdkResult<Customer, CreateErrorBody> {
let path = "/v0.1/customers";
let url = format!("{}{}", self.client.base_url(), path);
let mut request = self
.client
.http_client()
.post(&url)
.header("User-Agent", crate::version::user_agent())
.timeout(self.client.timeout())
.json(&body);
if let Some(authorization) = self.client.authorization() {
request = request.header("Authorization", format!("Bearer {}", authorization));
}
for (header_name, header_value) in self.client.runtime_headers() {
request = request.header(*header_name, header_value);
}
let response = request.send().await?;
let status = response.status();
match status {
reqwest::StatusCode::CREATED => {
let data: Customer = response.json().await?;
Ok(data)
}
reqwest::StatusCode::BAD_REQUEST => {
Err(crate::error::SdkError::api(CreateErrorBody::BadRequest))
}
reqwest::StatusCode::UNAUTHORIZED => {
let body: Problem = response.json().await?;
Err(crate::error::SdkError::api(CreateErrorBody::Unauthorized(
body,
)))
}
reqwest::StatusCode::FORBIDDEN => {
let body: ErrorForbidden = response.json().await?;
Err(crate::error::SdkError::api(CreateErrorBody::Forbidden(
body,
)))
}
reqwest::StatusCode::CONFLICT => {
let body: Error = response.json().await?;
Err(crate::error::SdkError::api(CreateErrorBody::Conflict(body)))
}
_ => {
let body_bytes = response.bytes().await?;
let body = crate::error::UnknownApiBody::from_bytes(body_bytes.as_ref());
Err(crate::error::SdkError::unexpected(status, body))
}
}
}
pub async fn get(
&self,
customer_id: impl Into<String>,
) -> crate::error::SdkResult<Customer, GetErrorBody> {
let path = format!("/v0.1/customers/{}", customer_id.into());
let url = format!("{}{}", self.client.base_url(), path);
let mut request = self
.client
.http_client()
.get(&url)
.header("User-Agent", crate::version::user_agent())
.timeout(self.client.timeout());
if let Some(authorization) = self.client.authorization() {
request = request.header("Authorization", format!("Bearer {}", authorization));
}
for (header_name, header_value) in self.client.runtime_headers() {
request = request.header(*header_name, header_value);
}
let response = request.send().await?;
let status = response.status();
match status {
reqwest::StatusCode::OK => {
let data: Customer = response.json().await?;
Ok(data)
}
reqwest::StatusCode::UNAUTHORIZED => {
let body: Problem = response.json().await?;
Err(crate::error::SdkError::api(GetErrorBody::Unauthorized(
body,
)))
}
reqwest::StatusCode::FORBIDDEN => {
let body: ErrorForbidden = response.json().await?;
Err(crate::error::SdkError::api(GetErrorBody::Forbidden(body)))
}
reqwest::StatusCode::NOT_FOUND => {
let body: Error = response.json().await?;
Err(crate::error::SdkError::api(GetErrorBody::NotFound(body)))
}
_ => {
let body_bytes = response.bytes().await?;
let body = crate::error::UnknownApiBody::from_bytes(body_bytes.as_ref());
Err(crate::error::SdkError::unexpected(status, body))
}
}
}
pub async fn update(
&self,
customer_id: impl Into<String>,
body: UpdateBody,
) -> crate::error::SdkResult<Customer, UpdateErrorBody> {
let path = format!("/v0.1/customers/{}", customer_id.into());
let url = format!("{}{}", self.client.base_url(), path);
let mut request = self
.client
.http_client()
.put(&url)
.header("User-Agent", crate::version::user_agent())
.timeout(self.client.timeout())
.json(&body);
if let Some(authorization) = self.client.authorization() {
request = request.header("Authorization", format!("Bearer {}", authorization));
}
for (header_name, header_value) in self.client.runtime_headers() {
request = request.header(*header_name, header_value);
}
let response = request.send().await?;
let status = response.status();
match status {
reqwest::StatusCode::OK => {
let data: Customer = response.json().await?;
Ok(data)
}
reqwest::StatusCode::UNAUTHORIZED => {
let body: Problem = response.json().await?;
Err(crate::error::SdkError::api(UpdateErrorBody::Unauthorized(
body,
)))
}
reqwest::StatusCode::FORBIDDEN => {
let body: ErrorForbidden = response.json().await?;
Err(crate::error::SdkError::api(UpdateErrorBody::Forbidden(
body,
)))
}
reqwest::StatusCode::NOT_FOUND => {
let body: Error = response.json().await?;
Err(crate::error::SdkError::api(UpdateErrorBody::NotFound(body)))
}
_ => {
let body_bytes = response.bytes().await?;
let body = crate::error::UnknownApiBody::from_bytes(body_bytes.as_ref());
Err(crate::error::SdkError::unexpected(status, body))
}
}
}
pub async fn list_payment_instruments(
&self,
customer_id: impl Into<String>,
) -> crate::error::SdkResult<ListPaymentInstrumentsResponse, ListPaymentInstrumentsErrorBody>
{
let path = format!("/v0.1/customers/{}/payment-instruments", customer_id.into());
let url = format!("{}{}", self.client.base_url(), path);
let mut request = self
.client
.http_client()
.get(&url)
.header("User-Agent", crate::version::user_agent())
.timeout(self.client.timeout());
if let Some(authorization) = self.client.authorization() {
request = request.header("Authorization", format!("Bearer {}", authorization));
}
for (header_name, header_value) in self.client.runtime_headers() {
request = request.header(*header_name, header_value);
}
let response = request.send().await?;
let status = response.status();
match status {
reqwest::StatusCode::OK => {
let data: ListPaymentInstrumentsResponse = response.json().await?;
Ok(data)
}
reqwest::StatusCode::UNAUTHORIZED => {
let body: Problem = response.json().await?;
Err(crate::error::SdkError::api(
ListPaymentInstrumentsErrorBody::Unauthorized(body),
))
}
reqwest::StatusCode::FORBIDDEN => {
let body: ErrorForbidden = response.json().await?;
Err(crate::error::SdkError::api(
ListPaymentInstrumentsErrorBody::Forbidden(body),
))
}
reqwest::StatusCode::NOT_FOUND => {
let body: Error = response.json().await?;
Err(crate::error::SdkError::api(
ListPaymentInstrumentsErrorBody::NotFound(body),
))
}
_ => {
let body_bytes = response.bytes().await?;
let body = crate::error::UnknownApiBody::from_bytes(body_bytes.as_ref());
Err(crate::error::SdkError::unexpected(status, body))
}
}
}
pub async fn deactivate_payment_instrument(
&self,
customer_id: impl Into<String>,
token: impl Into<String>,
) -> crate::error::SdkResult<(), DeactivatePaymentInstrumentErrorBody> {
let path = format!(
"/v0.1/customers/{}/payment-instruments/{}",
customer_id.into(),
token.into()
);
let url = format!("{}{}", self.client.base_url(), path);
let mut request = self
.client
.http_client()
.delete(&url)
.header("User-Agent", crate::version::user_agent())
.timeout(self.client.timeout());
if let Some(authorization) = self.client.authorization() {
request = request.header("Authorization", format!("Bearer {}", authorization));
}
for (header_name, header_value) in self.client.runtime_headers() {
request = request.header(*header_name, header_value);
}
let response = request.send().await?;
let status = response.status();
match status {
reqwest::StatusCode::NO_CONTENT => Ok(()),
reqwest::StatusCode::BAD_REQUEST => {
let body: Error = response.json().await?;
Err(crate::error::SdkError::api(
DeactivatePaymentInstrumentErrorBody::BadRequest(body),
))
}
reqwest::StatusCode::UNAUTHORIZED => {
let body: Problem = response.json().await?;
Err(crate::error::SdkError::api(
DeactivatePaymentInstrumentErrorBody::Unauthorized(body),
))
}
reqwest::StatusCode::FORBIDDEN => {
let body: ErrorForbidden = response.json().await?;
Err(crate::error::SdkError::api(
DeactivatePaymentInstrumentErrorBody::Forbidden(body),
))
}
reqwest::StatusCode::NOT_FOUND => {
let body: Error = response.json().await?;
Err(crate::error::SdkError::api(
DeactivatePaymentInstrumentErrorBody::NotFound(body),
))
}
_ => {
let body_bytes = response.bytes().await?;
let body = crate::error::UnknownApiBody::from_bytes(body_bytes.as_ref());
Err(crate::error::SdkError::unexpected(status, body))
}
}
}
}