A Go client library for Adyen payments platform.
This is not an official client library. Adyen has official libraries for multiple platforms Github, but not Go yet.
This package provides core functionality to perform most common types of a Payment requests to an API. If you see some functionality is missing, please, open an issue (or better yet, a pull request).
go get github.com/zhutik/adyen-api-go
Please check separate repository with Adyen API playground, where you can test API and get some usage examples for Adyen API library
https://github.com/zhutik/adyen-api-go-example
Or you can visit Wiki page for more details and examples
- Authorise (Encrypted in recommended)
- Authorise 3D
- Recurring payments and retrieving stored payment methods
- Capture
- Cancel
- Refund (CancelOrRefund)
- Notifications
import "github.com/zhutik/adyen-api-go"
// Configure Adyen API
instance := adyen.New(
adyen.Testing,
os.Getenv("ADYEN_USERNAME"),
os.Getenv("ADYEN_PASSWORD"),
)
req := &adyen.AuthoriseEncrypted{
Amount: &adyen.Amount{
Value: 1000, // amount * 100, f.e. 10,30 EUR = 1030
Currency: "EUR" // or use instance.Currency
},
MerchantAccount: os.Getenv("ADYEN_ACCOUNT"), // your merchant account in Adyen
AdditionalData: &adyen.AdditionalData{Content: "encryptedData"}, // encrypted data from a form
Reference: "your-order-number",
}
// Perform authorise transaction
g, err := instance.Payment().AuthoriseEncrypted(req)
Load Client Side JS for form encryption to include on credit card form page
// Configure Adyen API
instance := adyen.New(
adyen.Testing,
os.Getenv("ADYEN_USERNAME"),
os.Getenv("ADYEN_PASSWORD"),
)
url := &adyen.ClientURL(os.Getenv("ADYEN_CLIENT_TOKEN"))
Currently, MerchantAccount and Currency need to be set for every request manually
To shortcut configuration, additional methods could be used to set and retrieve those settings.
// Configure Adyen API
instance := adyen.New(
adyen.Testing,
os.Getenv("ADYEN_USERNAME"),
os.Getenv("ADYEN_PASSWORD"),
)
// set parameters once for current instance
instance.Currency = "USD"
instance.MerchantAccount = "TEST_MERCHANT_ACCOUNT"
// futher, information could be retrieved to populate request
req := &adyen.AuthoriseEncrypted{
Amount: &adyen.Amount{
Value: 1000,
Currency: instance.Currency
},
MerchantAccount: instance.MerchantAccount,
AdditionalData: &adyen.AdditionalData{Content: "encryptedData"}, // encrypted data from a form
Reference: "your-order-number",
}
Adyen's Production environment requires additional configuration to the Test environment for security reasons. Namely, this includes a random hexadecimal string that's generated for your account and the company account name.
In the following examples, the environmenst have been hard-coded for clarity. They would typically come from environments variables instead.
To target the Test environment:
env := adyen.TestEnvironment()
To target the Production environment:
env, err := adyen.ProductionEnvironment("5409c4fd1cc98a4e", "AcmeAccount123")
$ export ADYEN_CLIENT_TOKEN="YOUR_ADYEN_CLIENT_TOKEN"
$ export ADYEN_USERNAME="YOUR_ADYEN_API_USERNAME"
$ export ADYEN_PASSWORD="YOUR_API_PASSWORD"
$ export ADYEN_ACCOUNT="YOUR_MERCHANT_ACCOUNT"
Settings explanation:
- ADYEN_CLIENT_TOKEN - Library token in Adyen, used to load external JS file from Adyen to validate Credit Card information
- ADYEN_USERNAME - Adyen API username, usually starts with ws@
- ADYEN_PASSWORD - Adyen API password for username
- ADYEN_ACCOUNT - Selected Merchant Account
Update your settings to include
$ export ADYEN_HMAC="YOUR_HMAC_KEY"
$ export ADYEN_SKINCODE="YOUR_SKINCODE_ID"
$ export ADYEN_SHOPPER_LOCALE="YOUR_SHOPPER_LOCALE"
Use HPP constructor to initialize new Adyen API instance
import "github.com/zhutik/adyen-api-go"
// Configure Adyen API
instance := adyen.NewWithHMAC(
adyen.Testing,
os.Getenv("ADYEN_USERNAME"),
os.Getenv("ADYEN_PASSWORD"),
os.Getenv("ADYEN_HMAC"),
)
Perform requests as usual:
timeIn := time.Now().Local().Add(time.Minute * time.Duration(60))
req := &adyen.DirectoryLookupRequest{
CurrencyCode: "EUR",
MerchantAccount: os.Getenv("ADYEN_ACCOUNT"),
PaymentAmount: 1000,
SkinCode: os.Getenv("ADYEN_SKINCODE"),
MerchantReference: "your-order-number",
SessionsValidity: timeIn.Format(time.RFC3339),
}
g, err := instance.Payment().DirectoryLookup(req)
or generate redirect URL for selected payment method
Example with iDEAL for Netherlands:
timeIn := time.Now().Local().Add(time.Minute * time.Duration(60))
req := &adyen.SkipHppRequest{
MerchantReference: "your-order-number",
PaymentAmount: 1000,
CurrencyCode: "EUR",
ShipBeforeDate: timeIn.Format(time.RFC3339),
SkinCode: os.Getenv("ADYEN_SKINCODE"),
MerchantAccount: os.Getenv("ADYEN_ACCOUNT"),
ShopperLocale: "nl",
SessionsValidity: timeIn.Format(time.RFC3339),
CountryCode: "NL",
BrandCode: "ideal",
IssuerID: "1121",
}
url, err := instance.Payment().GetHPPRedirectURL(req)
http.Redirect(w, r, url, http.StatusTemporaryRedirect)
Supported Calls:
- Directory Lookup
- Locale payment methods redirect
Please check separate repository with Adyen API playgroup, where you can test API and get some usage example for Adyen API library
https://github.com/zhutik/adyen-api-go-example
Open http://localhost:8080 in your browser and check implemented actions.
Test credit cards could be found https://docs.adyen.com/support/integration#testcardnumbers
- Move some constants into enum files.
- Parse URLs for environment's BaseURL, ClientURL and HppURL methods instead of string concatenation (needs to return an error as well).
- Reduced API surface by making most types and functions unexported.