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
//! # Bakong KHQR SDK
//!
//! Unofficial Rust SDK for Bakong KHQR (Cambodia's centralized QR payment system).
//!
//! ## Features
//!
//! - QR Code Generation (Individual and Merchant accounts)
//! - QR Code Decoding
//! - CRC16 Verification
//! - Bakong API Integration
//!
//! ## Quick Start
//!
//! ```rust,no_run
//! use bakong_khqr::{BakongKHQR, IndividualInfo};
//!
//! let khqr = BakongKHQR::new("your_token");
//!
//! // Generate QR code
//! let info = IndividualInfo::builder()
//! .bakong_account_id("user@bank")
//! .merchant_name("Coffee Shop")
//! .merchant_city("Phnom Penh")
//! .currency("KHR")
//! .amount(50000.0)
//! .build()
//! .unwrap();
//!
//! let result = khqr.generate_qr(info).unwrap();
//! println!("QR Code: {}", result.qr);
//! println!("MD5 Hash: {}", result.md5);
//! ```
//!
//! ## API Usage
//!
//! ```rust,no_run
//! use bakong_khqr::{BakongKHQR, SourceInfo};
//!
//! #[tokio::main]
//! async fn main() -> Result<(), bakong_khqr::BakongError> {
//! let khqr = BakongKHQR::new("your_token");
//!
//! // Check if Bakong account exists
//! let response = khqr.check_bakong_account("user@bank").await?;
//! println!("Account exists: {:?}", response.data);
//!
//! // Check transaction by MD5
//! let tx = khqr.check_transaction_by_md5("md5_hash").await?;
//!
//! // Generate deeplink
//! let deeplink = khqr.generate_deeplink(
//! "qr_string",
//! SourceInfo {
//! app_name: "My App".to_string(),
//! app_icon_url: None,
//! app_deep_link_callback: None,
//! },
//! ).await?;
//!
//! Ok(())
//! }
//! ```
pub use BakongKHQR;
pub use ;
pub use ;
pub use KHQRDecoder;
pub use ;
pub use *;
pub use ;