An unofficial Go SDK for working with Fincra API
go get github.com/neymarjimoh/fincra-go
import "github.com/neymarjimoh/fincra-go"
import (
"time"
fincra "github.com/neymarjimoh/fincra-go"
)
const (
SECRET_KEY = "<Your secret key>"
)
// to indicate environment when integrating, use `WithSandbox()`
newClient := fincra.NewClient(SECRET_KEY, fincra.WithSandbox(true))
// to indicate http request timeout to use, use `WithTimeout()`
newClient := fincra.NewClient(SECRET_KEY, fincra.WithTimeout(5*time.Second))
// to create a context for library functions
ctx := context.Background()
Note:
- The
WithSandbox
argument is optional. If not specified, it defaults to false and you will be using the Production(live) API. For example:newClient := fincra.NewClient(SECRET_KEY)
- The
WithTimeout
argument is optional. If not specified, it defaults to 60 seconds - Get your keys from your Fincra dashboard and be sure to add it as environment variables
This method lets you retrieve the unique Identifier of your business and other information such as your email etc.
Usage example:
resp, err := client.GetBusinessId(ctx)
This method is used for creating a Beneficiary.
Usage example:
data := &fincra.CreateBeneficiaryBody{
FirstName: "efe",
LastName: "ebieroma",
Email: "[email protected]",
PhoneNumber: "09090909090",
AccountHolderName: "efe stephen ebieroma",
Bank: fincra.Bank{
Name: "Wema Bank",
Code: "06",
SortCode: "928927",
Branch: "Ota",
Address: fincra.Address{
Country: "GB",
State: "Lagos",
Zip: "123455",
City: "Paris",
Street: "Osapa London",
},
},
Type: fincra.Individual, // or Corporate
Currency: "GBP",
PaymentDestination: fincra.CryptoWallet,
UniqueIdentifier: "4",
DestinationAddress: "Osapa London",
BusinessId: "6457d39b12b4401f99a54772",
}
resp, err := client.CreateBeneficiary(ctx, data)
NOTE: PaymentDestination accepts an enum of CryptoWallet (crypto_wallet), BankAccount (bank_account) or MobileMoneyWallet (mobile_money_wallet)
This method is used for retrieving a single beneficiary attached to a business.
Usage example:
data := &fincra.GetAllBeneficiariesParams{
BusinessId: "617fefbe4a68ec99ba6af0be",
Page: "1", // optional, defaults to 1
PerPage: "20", // optional, defaults to 10
}
resp, err := client.GetAllBeneficiaries(ctx, data);
This method is used for retrieving a single beneficiary attached to a business.
Usage example:
data := &fincra.GetBeneficiaryParams{
BusinessId: "617fefbe4a68ec99ba6af0be",
BeneficiaryId: "618fefbe4a68ec99ba5af0be",
}
resp, err := client.GetBeneficiary(ctx, data);
This method is used for updating a Beneficiary.
Usage example:
data := &fincra.UpdateBeneficiaryBody{
FirstName: "efe",
LastName: "ebieroma",
Email: "[email protected]",
PhoneNumber: "09090909090",
AccountHolderName: "efe stephen ebieroma",
DestinationAddress: "Osapa London",
BusinessId: "6457d39b12b4401f99a54772",
BeneficiaryId: "646db15a8cdec23981165184",
}
resp, err := client.UpdateBeneficiary(ctx, data)
More details about the parameters for the above method here
This method is used for deleting a beneficiary.
Usage example:
data := &fincra.GetBeneficiaryParams{
BusinessId: "617fefbe4a68ec99ba6af0be",
BeneficiaryId: "618fefbe4a68ec99ba5af0be",
}
resp, err := client.DeleteBeneficiary(data);
This method can convert one currency to another provided that it's a supported conversion currency e.g NGN to USD.
Usage example:
data := &fincra.CreateConversionBody{
BusinessId: "617fefbe4a68ec99ba6af0be",
QuoteReference: "124246677268282782728",
}
resp, err := client.CreateConversion(ctx, data);
This method provides a list of all conversions performed by a business.
Usage example:
businessId := "617fefbe4a68ec99ba6af0be"
resp, err := client.GetBusinessConversions(ctx, businessId);
This method fetches a specific conversion performed by a parent Business or sub account.
Usage example:
conversionId := "617fefbe4a68ec99ba6af0bh"
resp, err := client.GetConversion(ctx, conversionId);
The Quotes service provides a method that allows you to generate quotes for Real-time transactions occurring on your integration.
This method is used for generating a quote.
Usage example:
data := &fincra.CreateQuoteBody{
Action: "send",
TransactionType: "conversion",
FeeBearer: "business",
PaymentDestination: fincra.FliqPayWallet,
BeneficiaryType: fincra.Individual,
Business: "6457d39b12b4401f99a54772",
Amount: "150",
DestinationCurrency: "USD",
SourceCurrency: "NGN",
}
resp, err := client.CreateQuote(ctx, data);
This method lets you list all the chargebacks incurred on your account.
Usage example:
businessId := "6457d39b12b4401f99a54772"
resp, err := client.ListChargeBacks(ctx, businessId)
This method lets you accept a chargeback
Usage example:
data := &fincra.AcceptChargeBackDto{
BusinessId: "617fefbe4a68ec99ba6af0be",
ChargeBackId: "7171892",
}
resp, err := client.AcceptChargeBack(ctx, data)
This method lets you reject a chargeback
Usage example:
data := &fincra.RejectChargeBackDto{
BusinessId: "617fefbe4a68ec99ba6af0be",
ChargeBackId: "7171892",
Reason: "no money on ground",
}
resp, err := client.RejectChargeBack(ctx, data)
This method lists all the account balance information of a business
Usage example:
businessId := "6457d39b12b4401f99a54772"
resp, err := client.ListWallets(ctx, businessId)
This method provides information to the merchant about a specific account balance
Usage example:
walletId := "66433"
resp, err := client.ListWallet(ctx, walletId)
This method fetches all pay-ins and pay-outs that occurred on your integration
Usage example:
data := fincra.LogsDto{
Business: "6457d39b12b4401f99a54772",
Action: fincra.Credit,
Page: "2",
PerPage: "10",
Amount: "500",
}
resp, err := client.ListWalletLogs(ctx, data)
This method lets you verify a bank account
Usage example:
data := fincra.VerifyBankAccountBody{
AccountNumber: "0929292929",
Type: fincra.Nuban, // it can be fincra.Iban
BankCode: "044",
Iban: "999",
}
resp, err := client.VerifyBankAccount(ctx, data)
This method lets you verify a bank account
Usage example:
data := fincra.VerifyBVNBody{
Bvn: "09292929221",
Business: "6457d39b12b4401f99a54772",
}
resp, err := client.VerifyBVN(ctx, data)
- Create a virtual account here
This method lets you create NGN and MCY virtual accounts. You’ll need to complete currency-specific fields as well as shared fields applicable to all currencies. E.g firstName and lastName are applicable to both NGN and MCY account requests while meansofID is applicable to only MCY accounts.
Usage example:
data := fincra.CreateVirtualAccountDto{
Currency: "NGN",
UtilityBill: "https://www.planetware.com/wpimages/2020/02/france-in-pictures-beautiful-places-to-photograph-eiffel-tower.jpg",
AccountType: "individual",
KYCInformation: fincra.KYCInformationDto{
FirstName: "John",
LastName: "Doe",
Email: "[email protected]",
BusinessName: "JohnDoe",
},
Channel: "providus",
}
resp, err := client.CreateVirtualAccount(ctx, data)
- List virtual accounts here
This method fetches all virtual accounts belonging to a merchant.
Usage example:
options := fincra.Options{
Currency: "NGN",
}
resp, err := client.ListVirtualAccounts(ctx, options)
N/B: In Options
, one or more of Currency
, BusinessName
, IssuedDate
, RequestedDate
, AccountNumber
and Status
must be passed as payload.
- List virtual account requests here
This method is used for getting all account requests belonging to a merchant.
Usage example:
resp, err := client.ListVirtualAccountRequests(ctx)
- Fetch a virtual account by currency here
This method is used for retrieving an account that is belongs to a merchant by currency.
Usage example:
resp, err := client.ListVirtualAccountByCurrency("EUR")
- Fetch a virtual account by BVN here
This method is used for retrieving an account that is belongs to a merchant by BVN.
Usage example: Accepts two parameters. First parameter represents the BVN and second represents the business ID.
resp, err := client.ListVirtualAccountByBvn(ctx, "0123456789", "6457d39b12b4401f99a54772")
- Fetch a virtual account here
This method is used for retrieving a virtual account.
Usage example: Accepts a parameter that represents the Virtual Account ID.
resp, err := client.ListVirtualAccount(ctx, "6457d39b12b4401f99a54772")
- Payins endpoints, tests and update README
- Payouts endpoints, tests and update README
- Checkouts endpoints, tests and update README