Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/altipla-consulting/redsys-golang
Redsys integration for Go.
https://github.com/altipla-consulting/redsys-golang
golang redsys
Last synced: about 1 month ago
JSON representation
Redsys integration for Go.
- Host: GitHub
- URL: https://github.com/altipla-consulting/redsys-golang
- Owner: altipla-consulting
- License: mit
- Created: 2018-01-25T12:24:33.000Z (almost 7 years ago)
- Default Branch: main
- Last Pushed: 2024-11-01T15:39:02.000Z (2 months ago)
- Last Synced: 2024-11-01T16:27:25.695Z (2 months ago)
- Topics: golang, redsys
- Language: Go
- Homepage: https://pkg.go.dev/github.com/altipla-consulting/redsys-golang
- Size: 39.1 KB
- Stars: 2
- Watchers: 7
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# redsys-golang
[![Go Reference](https://pkg.go.dev/badge/github.com/altipla-consulting/redsys-golang.svg)](https://pkg.go.dev/github.com/altipla-consulting/redsys-golang)
Redsys integration for Go.
## Install
```shell
go get github.com/altipla-consulting/redsys-golang
```## Usage
Follow this steps to integrate with Redsys:
1. First and foremost you will need to **request the bank credentials in person at your entity.** The will provide you with access to the test environment along with the following important information:
- Merchant code.
- Terminal number.
- A signing key.
In the test environment, you will have access to PDFs describing the integration process we are preparing. We recommend reading these documents thoroughly to understand how the different methods work.You can also read this more concise documentation: https://pagosonline.redsys.es/conexion-redireccion.html
2. **Sign the payment server-side** with this library:
```go
sess := redsys.Session{
Order: "0001abcdabcd",
Lang: redsys.LangES,
Client: "John Doe",
Amount: 1234,
Product: "My Awesome Product",
URLOK: "https://www.example.com/order-confirmed",
URLKO: "https://www.example.com/order-cancelled",
Data: "custom-data",
}
merchant := redsys.Merchant{
Code: "1234_YOUR_MERCHANT_CODE",
Name: "My Awesome Shop",
Terminal: 1234,
Secret: "YOUR_SECRET",
URLNotification: "https://www.example.com/background-notification",
Debug: true,
}
signed, err := redsys.Sign(ctx, merchant, rs)
if err != nil {
return nil, errors.Trace(err)
}
```3. **Send a form from the browser to the bank.** It is important to send it client-side; it can't be a POST request from Go. Sending the form will redirect the user to the bank to make the payment.
You can prepare a HTML form:
```html
Submit
```If you are in a more dynamic environment (e.g. with React or Vue using APIs to sign the transaction) you can also use a pure Javascript solution to build and send the form:
```js
// DOM manipulation to create a fake form that we can send to the
// remote POST endpoint of the bank network.
let form = document.createElement('form')
form.setAttribute('method', 'POST')
form.setAttribute('action', params.url)let input = document.createElement('input')
input.setAttribute('type', 'hidden')
input.setAttribute('name', 'Ds_SignatureVersion')
input.value = params.signatureVersion
form.appendChild(input)input = document.createElement('input')
input.setAttribute('type', 'hidden')
input.setAttribute('name', 'Ds_Signature')
input.value = params.signature
form.appendChild(input)input = document.createElement('input')
input.setAttribute('type', 'hidden')
input.setAttribute('name', 'Ds_MerchantParameters')
input.value = params.params
form.appendChild(input)
document.body.appendChild(form)form.submit()
```4. **The user will complete the transaction**, cancel, verify its credit card, etc. on the bank page. When the transaction finishes (successfully or not), a background notification will be sent automatically to the configured endpoint. In parallel, the user will be redirected to the OK/KO page. Both requests will have parameters in the query string that can be read.
5. **Verify the received parameters.** Since anyone can send requests to public pages, you need to ensure the bank has signed the data and everything is legal and secure. Use our library to verify the parameters:
```go
signed := redsys.Signed{
SignatureVersion: r.FormValue("Ds_SignatureVersion"),
Params: r.FormValue("Ds_MerchantParameters"),
Signature: r.FormValue("Ds_Signature"),
}
operation, err := redsys.Confirm(ctx, "YOUR_SECRET", signed)
if err != nil {
return nil, errors.Trace(err)
}
```6. **Use the `operation` variable** to show messages to the user, approve the transaction and perform any necessary actions according to its status and data.
## Contributing
You can make pull requests or create issues in GitHub. Any code you send should be formatted using `make gofmt`.
## License
[MIT License](LICENSE)