Ruby
Officiele Ruby SDK voor de Cost+ betaalgateway
Officiele Ruby SDK voor de Cost+ betaalgateway. Vereenvoudigt de HPP (Hosted Payment Page) doorverwijzingsflow, HMAC-payloadondertekening en webhookverificatie.
Kenmerken
- HMAC-SHA256-handtekeninggeneratie en constant-time verificatie
- Automatische snake_case-mapping van de API naar Ruby-vriendelijke OpenStruct-objecten
- Webhook-parsing + API-gebaseerde bestellingsverificatie
- Getest op Ruby 3.1, 3.2 en 3.3
- Op Sinatra gebaseerde demo-app voor handelaren inbegrepen
Vereisten
- Ruby 3.1 of hoger
- Een Cost+ handelaarsaccount — dashboard.costplus.io
Installatie
Voeg toe aan uw Gemfile:
gem "nopayn"Voer dan uit:
bundle installOf installeer direct:
gem install nopaynSnelstart
1. De client initialiseren
require "nopayn"
nopayn = NoPayn::Client.new(
api_key: "your-api-key",
merchant_id: "your-project"
)2. Een betaling aanmaken en doorverwijzen naar de HPP
result = nopayn.generate_payment_url(
amount: 1295, # €12.95 in cents
currency: "EUR",
merchant_order_id: "ORDER-001",
description: "Premium Widget",
return_url: "https://shop.example.com/success",
failure_url: "https://shop.example.com/failure",
webhook_url: "https://shop.example.com/webhook",
locale: "en-GB",
expiration_period: "PT30M"
)
# Redirect the customer
# result.order_url → HPP (customer picks payment method)
# result.payment_url → direct link to the first transaction's payment method
# result.signature → HMAC-SHA256 for verification
# result.order_id → NoPayn order UUID3. De webhook afhandelen
post "/webhook" do
request.body.rewind
raw_body = request.body.read
verified = nopayn.verify_webhook(raw_body)
puts verified.order.status # "completed", "cancelled", etc.
puts verified.is_final # true when the order won't change
if verified.order.status == "completed"
# Fulfil the order
end
status 200
endAPI-referentie
NoPayn::Client.new(api_key:, merchant_id:, base_url:)
| Parameter | Type | Vereist | Standaard |
|---|---|---|---|
api_key | String | Ja | — |
merchant_id | String | Ja | — |
base_url | String | Nee | https://api.nopayn.co.uk |
client.create_order(params) -> OpenStruct
Maakt een bestelling aan via POST /v1/orders/.
| Parameter | Type | Vereist | Beschrijving |
|---|---|---|---|
:amount | Integer | Ja | Bedrag in kleinste valuta-eenheid (centen) |
:currency | String | Ja | ISO 4217-code (EUR, GBP, USD, NOK, SEK) |
:merchant_order_id | String | Nee | Uw interne bestellingsreferentie |
:description | String | Nee | Bestellingsbeschrijving |
:return_url | String | Nee | Doorverwijzing na geslaagde betaling |
:failure_url | String | Nee | Doorverwijzing bij annulering/verloop/fout |
:webhook_url | String | Nee | Asynchrone statuswijzigingsmeldingen |
:locale | String | Nee | HPP-taal (en-GB, de-DE, nl-NL, enz.) |
:payment_methods | Array<String> | Nee | HPP-methoden filteren |
:expiration_period | String | Nee | ISO 8601-duur (PT30M) |
Beschikbare betaalmethoden: credit-card, apple-pay, google-pay, vipps-mobilepay
client.get_order(order_id) -> OpenStruct
Haalt bestellingsdetails op via GET /v1/orders/{id}/.
client.create_refund(order_id, amount, description: nil) -> OpenStruct
Voert een volledige of gedeeltelijke terugbetaling uit via POST /v1/orders/{id}/refunds/.
client.generate_payment_url(params) -> OpenStruct
Hulpmethode die een bestelling aanmaakt en retourneert:
result.order_id # NoPayn order UUID
result.order_url # HPP URL
result.payment_url # Direct payment URL (first transaction)
result.signature # HMAC-SHA256 of amount:currency:order_id
result.order # Full order OpenStructclient.generate_signature(amount, currency, order_id) -> String
Genereert een HMAC-SHA256 hex-handtekening.
client.verify_signature(amount, currency, order_id, signature) -> Boolean
Constant-time verificatie van een HMAC-SHA256-handtekening.
client.verify_webhook(raw_body) -> OpenStruct
Parst de webhook-body en roept vervolgens GET /v1/orders/{id}/ aan om de werkelijke status te verifieren.
Standalone HMAC-hulpmiddelen
require "nopayn"
sig = NoPayn::Signature.generate("your-api-key", 1295, "EUR", "order-uuid")
ok = NoPayn::Signature.verify("your-api-key", 1295, "EUR", "order-uuid", sig)Foutafhandeling
begin
nopayn.create_order(amount: 100, currency: "EUR")
rescue NoPayn::ApiError => e
puts e.status_code # 401, 400, etc.
puts e.error_body # Raw API error response
rescue NoPayn::Error => e
puts e.message # Network or parsing error
end| Uitzondering | Bovenliggende klasse | Beschrijving |
|---|---|---|
NoPayn::Error | StandardError | Basisfout voor alle SDK-fouten |
NoPayn::ApiError | NoPayn::Error | HTTP-fout van de API |
NoPayn::WebhookError | NoPayn::Error | Ongeldige webhook-payload |
Bestellingsstatussen
| Status | Definitief? | Beschrijving |
|---|---|---|
new | Nee | Bestelling aangemaakt |
processing | Nee | Betaling wordt verwerkt |
completed | Ja | Betaling geslaagd — lever de goederen |
cancelled | Ja | Betaling geannuleerd door klant |
expired | Ja | Betaallink verlopen |
error | Ja | Technische storing |
Best practices voor webhooks
- Verifieer altijd via de API — de webhook-payload bevat alleen het bestelling-ID, nooit de status. De
verify_webhookvan de SDK doet dit automatisch. - Retourneer HTTP 200 om de ontvangst te bevestigen. Elke andere code triggert tot 10 herhaalpogingen (2 minuten tussenpozen).
- Implementeer een backup-poller — voor bestellingen ouder dan 10 minuten die nog geen definitieve status hebben bereikt, poll
get_orderals vangnet. - Wees idempotent — u kunt dezelfde webhook meerdere keren ontvangen.
Testkaarten
Gebruik deze kaarten in Cost+ testmodus (sandbox-website):
| Kaart | Nummer | Opmerkingen |
|---|---|---|
| Visa (geslaagd) | 4111 1111 1111 1111 | Willekeurige CVV |
| Mastercard (geslaagd) | 5544 3300 0003 7 | Willekeurige CVV |
| Visa (geweigerd) | 4111 1111 1111 1105 | Do Not Honor |
| Visa (onvoldoende saldo) | 4111 1111 1111 1151 | Insufficient Funds |
Gebruik een willekeurige toekomstige vervaldatum en een willekeurige 3-cijferige CVC.
Demo-app
Een op Sinatra gebaseerde demo-app is opgenomen in de GitHub-repository om de volledige betalingsflow te testen.
Ondersteuning
Hulp nodig? Neem contact op met ons supportteam via support@costplus.io.