From fcde9731a52a0545f413587da4d27c61a3fbacb3 Mon Sep 17 00:00:00 2001 From: Lovro Colic Date: Mon, 29 Jan 2024 14:26:11 +0100 Subject: [PATCH] add support for invoice payment url --- lib/lago/api/resources/invoice.rb | 7 +++++++ spec/lago/api/resources/invoice_spec.rb | 22 ++++++++++++++++++++++ 2 files changed, 29 insertions(+) diff --git a/lib/lago/api/resources/invoice.rb b/lib/lago/api/resources/invoice.rb index b6d4f79..a307eab 100644 --- a/lib/lago/api/resources/invoice.rb +++ b/lib/lago/api/resources/invoice.rb @@ -49,6 +49,13 @@ def retry_payment(invoice_id) JSON.parse(response.to_json, object_class: OpenStruct) end + def payment_url(invoice_id) + path = "/api/v1/invoices/#{invoice_id}/payment_url" + response = connection.post({}, path)['invoice_payment_details'] + + JSON.parse(response.to_json, object_class: OpenStruct) + end + def whitelist_params(params) result = { payment_status: params[:payment_status], diff --git a/spec/lago/api/resources/invoice_spec.rb b/spec/lago/api/resources/invoice_spec.rb index 4fe1452..d92f9dd 100644 --- a/spec/lago/api/resources/invoice_spec.rb +++ b/spec/lago/api/resources/invoice_spec.rb @@ -261,4 +261,26 @@ expect(result).to eq(true) end end + + describe '#payment_url' do + let(:url_response) do + { + 'invoice_payment_details' => { + 'payment_url' => 'https://example.com', + } + }.to_json + end + + before do + stub_request(:post, "https://api.getlago.com/api/v1/invoices/#{invoice_id}/payment_url") + .with(body: {}) + .to_return(body: url_response, status: 200) + end + + it 'returns payment url' do + result = resource.payment_url(invoice_id) + + expect(result.payment_url).to eq('https://example.com') + end + end end