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
//!# MPESA Services //! Using the builder pattern in this to procedurally build Mpesa service specific payloads which are //! ultimately consumed and the request sent by calling the `send` method. //! Some of the builder methods for certain services are optional with default values standing in //! their place when the builder gets consumed //! //! Here are the currently available services: //! 1. [Account Balance](https://developer.safaricom.co.ke/docs#account-balance-api) //! 2. [B2B](https://developer.safaricom.co.ke/docs#b2b-api) //! 3. [B2C](https://developer.safaricom.co.ke/docs?shell#b2c-api) //! 4. [C2B Register](https://developer.safaricom.co.ke/docs?shell#c2b-api) //! 5. [C2B Simulate](https://developer.safaricom.co.ke/docs#account-balance-api) //! //! Also worth noting I am using `reqwest::blocking::Client` to make http requests. Research ongoing //! on how to make this crate async. #![allow(non_snake_case)] mod account_balance; mod b2b; mod b2c; mod c2b_register; mod c2b_simulate; mod express_request; pub use account_balance::{AccountBalanceBuilder, AccountBalanceResponse}; pub use b2b::{B2bBuilder, B2bResponse}; pub use b2c::{B2cBuilder, B2cResponse}; pub use c2b_register::{C2bRegisterBuilder, C2bRegisterResponse}; pub use c2b_simulate::{C2bSimulateBuilder, C2bSimulateResponse}; pub use express_request::{MpesaExpressRequestBuilder, MpesaExpressRequestResponse};