1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// Fireblocks API
//
// Fireblocks provides a suite of applications to manage digital asset operations and a complete development platform to build your business on the blockchain. - Visit our website for more information: [Fireblocks Website](https://fireblocks.com) - Visit our developer docs: [Fireblocks DevPortal](https://developers.fireblocks.com)
//
// The version of the OpenAPI document: 1.8.0
// Contact: developers@fireblocks.com
// Generated by: https://openapi-generator.tech
use {
crate::models,
serde::{Deserialize, Serialize},
};
/// MomoPaymentInfo : Mobile Money (MOMO) payment information for African mobile
/// payment services
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct MomoPaymentInfo {
/// The payment rail type for mobile money transfers
#[serde(rename = "rail")]
pub rail: Rail,
/// The addressing system used for mobile money transfers
#[serde(rename = "addressingSystem")]
pub addressing_system: AddressingSystem,
/// The given name (first name) of the account holder
#[serde(rename = "accountHolderGivenName")]
pub account_holder_given_name: String,
/// The surname (last name) of the account holder
#[serde(rename = "accountHolderSurname")]
pub account_holder_surname: String,
/// The country for the transfer (ISO 3166-1 alpha-2 code)
#[serde(rename = "country")]
pub country: String,
/// The mobile phone number associated with the mobile money account
#[serde(rename = "mobilePhoneNumber")]
pub mobile_phone_number: String,
/// The mobile money service provider
#[serde(rename = "provider")]
pub provider: Provider,
/// The document ID of the beneficiary
#[serde(
rename = "beneficiaryDocumentId",
skip_serializing_if = "Option::is_none"
)]
pub beneficiary_document_id: Option<String>,
/// The relationship between sender and beneficiary
#[serde(
rename = "beneficiaryRelationship",
skip_serializing_if = "Option::is_none"
)]
pub beneficiary_relationship: Option<String>,
}
impl MomoPaymentInfo {
/// Mobile Money (MOMO) payment information for African mobile payment
/// services
pub fn new(
rail: Rail,
addressing_system: AddressingSystem,
account_holder_given_name: String,
account_holder_surname: String,
country: String,
mobile_phone_number: String,
provider: Provider,
) -> MomoPaymentInfo {
MomoPaymentInfo {
rail,
addressing_system,
account_holder_given_name,
account_holder_surname,
country,
mobile_phone_number,
provider,
beneficiary_document_id: None,
beneficiary_relationship: None,
}
}
}
/// The payment rail type for mobile money transfers
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Rail {
#[serde(rename = "MOMO")]
Momo,
}
impl Default for Rail {
fn default() -> Rail {
Self::Momo
}
}
/// The addressing system used for mobile money transfers
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum AddressingSystem {
#[serde(rename = "MOMO")]
Momo,
}
impl Default for AddressingSystem {
fn default() -> AddressingSystem {
Self::Momo
}
}
/// The mobile money service provider
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Provider {
#[serde(rename = "M_PESA")]
MPesa,
#[serde(rename = "AIRTEL")]
Airtel,
#[serde(rename = "MTN")]
Mtn,
#[serde(rename = "TIGO")]
Tigo,
}
impl Default for Provider {
fn default() -> Provider {
Self::MPesa
}
}