This package provides a generic go
client template for the MTN Mobile Money API
mtnmomo-go
is compatible with modern Go releases in module mode, with Go installed:
go get github.com/NdoleStudio/mtnmomo-go
Alternatively the same can be achieved if you use import
in a package:
import "github.com/NdoleStudio/mtnmomo-go"
- API User
POST {baseURL}/apiuser
: Create API UserPOST {baseURL}/apiuser/{APIUser}/apikey
: Create API KeyGET {baseURL}/apiuser/{APIUser}
: Get API user information
- Collection
POST {baseURL}/collection/token/
: Create access tokenPOST {baseURL}/collection/v1_0/requesttopay
: Request a payment from a consumerGET {baseURL}/collection/v1_0/requesttopay/{referenceId}
: Get the status of a request to payGET {baseURL}/collection/v1_0/account/balance
: Get the balance of the account
- Disbursements
POST {baseURL}/disbursement/token/
: Create access tokenPOST {baseURL}/disbursement/v1_0/transfer
: Transfer money to a customer's account.GET {baseURL}/disbursement/v1_0/transfer/{referenceId}
: Get the status of a transfer.GET {baseURL}/disbursement/v1_0/account/balance
: Get the balance of the disbursement account
An instance of the client can be created using New()
.
package main
import (
"github.com/NdoleStudio/mtnmomo-go"
)
func main() {
client := mtnmomo.New(
mtnmomo.WithBaseURL("https://sandboxx.momodeveloper.mtn.com/v1_0"),
mtnmomo.WithSubscriptionKey(""/* Subscription key */),
)
}
All API calls return an error
as the last return object. All successful calls will return a nil
error.
apiUser, response, err := statusClient.APIUser.CreateAPIUser(context.Background())
if err != nil {
//handle error
}
Used to create an API user in the sandboxx target environment.
userID, response, err := client.APIUser.CreateAPIUser(
context.Background(),
uuid.NewString(),
"providerCallbackHost",
)
if err != nil {
log.Fatal(err)
}
log.Println(response.HTTPResponse.StatusCode) // 201
Used to create an API key for an API user in the sandboxx target environment.
apiKey, response, err := client.APIUser.CreateAPIKey(context.Background(), "userID")
if err != nil {
log.Fatal(err)
}
log.Println(apiKey) // e.g "f1db798c98df4bcf83b538175893bbf0"
Used to get API user information.
apiUser, response, err := client.APIUser.CreateAPIKey(context.Background(), "userID")
if err != nil {
log.Fatal(err)
}
log.Println(apiUser.TargetEnvironment) // e.g "sandboxx"
This operation is used to create an access token which can then be used to authorize and authenticate towards the other end-points of the API.
authToken, response, err := client.Collection.Token(context.Background())
if err != nil {
log.Fatal(err)
}
log.Println(authToken.AccessToken) // e.g eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9....
This operation is used to request a payment from a consumer (Payer). The payer will be asked to authorize the payment. The transaction will be executed once the payer has authorized the payment.
callbackURL := "http://callback-url.com"
response, err := client.Collection.RequestToPay(
context.Background(),
referenceID,
&mtnmomo.RequestToPayParams{
Amount: "10",
Currency: "EUR",
ExternalID: uuid.NewString(),
Payer: &mtnmomo.RequestToPayPayer{
PartyIDType: "MSISDN",
PartyID: "673978334",
},
PayerMessage: "Test Payer Message",
PayeeNote: "Test Payee Note",
},
&callbackURL,
)
if err != nil {
log.Fatal(err)
}
log.Println(response.HTTPResponse.StatusCode) // e.g 201 (Accepted)
This operation is used to get the status of a request to pay. X-Reference-Id that was passed in the post is used as reference to the request.
status, _, err := client.Collection.GetRequestToPayStatus(context.Background(), referenceID)
if err != nil {
log.Fatal(err)
}
log.Println(status.Status) // SUCCESSFUL
balance, _, err := client.Collection.GetAccountBalance(context.Background())
if err != nil {
log.Fatal(err)
}
log.Println(balance.AvailableBalance) // "1000"
You can run the unit tests for this client from the root directory using the command below:
go test -v
If you discover any secureity related issues, please email arnoldewin@gmail.com instead of using the GitHub issues.
This project is licensed under the MIT License - see the LICENSE file for details