Class: Payabli::MoneyOut::Client
- Inherits:
-
Object
- Object
- Payabli::MoneyOut::Client
- Defined in:
- lib/payabli/money_out/client.rb
Instance Method Summary collapse
-
#authorize_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::AuthCapturePayoutResponse
Authorizes transaction for payout.
-
#cancel_all_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::CaptureAllOutResponse
Cancels an array of payout transactions.
-
#cancel_out_delete(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponse0000
Cancel a payout transaction by ID.
-
#cancel_out_get(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponse0000
Cancel a payout transaction by ID.
-
#capture_all_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::CaptureAllOutResponse
Captures an array of authorized payout transactions for settlement.
-
#capture_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::AuthCapturePayoutResponse
Captures a single authorized payout transaction by ID.
-
#get_check_image(request_options: {}, **params) ⇒ String
Retrieve the image of a check associated with a processed transaction.
- #initialize(client:) ⇒ void constructor
-
#payout_details(request_options: {}, **params) ⇒ Payabli::Types::BillDetailResponse
Returns details for a processed money out transaction.
-
#reissue_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::ReissuePayoutResponse
Reissues a payout transaction with a new payment method.
-
#send_v_card_link(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::OperationResult
Sends a virtual card link via email to the vendor associated with the ‘transId`.
-
#update_check_payment_status(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponse00Responsedatanonobject
Updates the status of a processed check payment transaction.
-
#v_card_get(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::VCardGetResponse
Retrieves vCard details for a single card in an entrypoint.
Constructor Details
#initialize(client:) ⇒ void
9 10 11 |
# File 'lib/payabli/money_out/client.rb', line 9 def initialize(client:) @client = client end |
Instance Method Details
#authorize_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::AuthCapturePayoutResponse
Authorizes transaction for payout. If you don’t pass the ‘autoCapture` field with a value of `true`, authorized transactions aren’t flagged for settlement until captured. Use ‘referenceId` returned in the response to capture the transaction.
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# File 'lib/payabli/money_out/client.rb', line 30 def (request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) query_param_names = %i[allow_duplicated_bills do_not_create_bills force_vendor_creation] query_params = {} query_params["allowDuplicatedBills"] = params[:allow_duplicated_bills] if params.key?(:allow_duplicated_bills) query_params["doNotCreateBills"] = params[:do_not_create_bills] if params.key?(:do_not_create_bills) query_params["forceVendorCreation"] = params[:force_vendor_creation] if params.key?(:force_vendor_creation) params = params.except(*query_param_names) headers = {} headers["idempotencyKey"] = params[:idempotency_key] if params[:idempotency_key] request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "POST", path: "MoneyOut/authorize", headers: headers, query: query_params, body: Payabli::MoneyOutTypes::Types::AuthorizePayoutBody.new(params).to_h, request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::MoneyOutTypes::Types::AuthCapturePayoutResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#cancel_all_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::CaptureAllOutResponse
Cancels an array of payout transactions.
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 |
# File 'lib/payabli/money_out/client.rb', line 76 def cancel_all_out(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "POST", path: "MoneyOut/cancelAll", body: params, request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::MoneyOutTypes::Types::CaptureAllOutResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#cancel_out_delete(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponse0000
Cancel a payout transaction by ID.
145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 |
# File 'lib/payabli/money_out/client.rb', line 145 def cancel_out_delete(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "DELETE", path: "MoneyOut/cancel/#{URI.encode_uri_component(params[:reference_id].to_s)}", request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::Types::PayabliApiResponse0000.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#cancel_out_get(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponse0000
Cancel a payout transaction by ID.
111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 |
# File 'lib/payabli/money_out/client.rb', line 111 def cancel_out_get(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "GET", path: "MoneyOut/cancel/#{URI.encode_uri_component(params[:reference_id].to_s)}", request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::Types::PayabliApiResponse0000.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#capture_all_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::CaptureAllOutResponse
Captures an array of authorized payout transactions for settlement. The maximum number of transactions that can be captured in a single request is 500.
180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 |
# File 'lib/payabli/money_out/client.rb', line 180 def capture_all_out(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) headers = {} headers["idempotencyKey"] = params[:idempotency_key] if params[:idempotency_key] request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "POST", path: "MoneyOut/captureAll", headers: headers, body: params, request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::MoneyOutTypes::Types::CaptureAllOutResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#capture_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::AuthCapturePayoutResponse
Captures a single authorized payout transaction by ID. If the transaction was authorized with ‘autoCapture` set to `true`, you don’t need to call this endpoint to capture the transaction for processing.
221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 |
# File 'lib/payabli/money_out/client.rb', line 221 def capture_out(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) headers = {} headers["idempotencyKey"] = params[:idempotency_key] if params[:idempotency_key] request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "GET", path: "MoneyOut/capture/#{URI.encode_uri_component(params[:reference_id].to_s)}", headers: headers, request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::MoneyOutTypes::Types::AuthCapturePayoutResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#get_check_image(request_options: {}, **params) ⇒ String
Retrieve the image of a check associated with a processed transaction. The check image is returned in the response body as a base64-encoded string. The check image is only available for payouts that have been processed.
363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 |
# File 'lib/payabli/money_out/client.rb', line 363 def get_check_image(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "GET", path: "MoneyOut/checkimage/#{URI.encode_uri_component(params[:asset_name].to_s)}", request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i return if code.between?(200, 299) error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end |
#payout_details(request_options: {}, **params) ⇒ Payabli::Types::BillDetailResponse
Returns details for a processed money out transaction.
259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 |
# File 'lib/payabli/money_out/client.rb', line 259 def payout_details(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "GET", path: "MoneyOut/details/#{URI.encode_uri_component(params[:trans_id].to_s)}", request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::Types::BillDetailResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#reissue_out(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::ReissuePayoutResponse
Reissues a payout transaction with a new payment method. This creates a new transaction linked to the original and marks the original transaction as reissued.
The original transaction must be in Processing or Processed status. The payment method in the request body is used directly. The endpoint doesn’t fall back to vendor-managed payment methods.
The new transaction goes through the standard authorize-and-capture flow automatically. Both the original and new transactions are linked through their event histories for audit purposes.
453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 |
# File 'lib/payabli/money_out/client.rb', line 453 def reissue_out(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) query_param_names = %i[trans_id] query_params = {} query_params["transId"] = params[:trans_id] if params.key?(:trans_id) params = params.except(*query_param_names) headers = {} headers["idempotencyKey"] = params[:idempotency_key] if params[:idempotency_key] request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "POST", path: "MoneyOut/reissue", headers: headers, query: query_params, body: Payabli::MoneyOutTypes::Types::ReissuePayoutBody.new(params).to_h, request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::MoneyOutTypes::Types::ReissuePayoutResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#send_v_card_link(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::OperationResult
Sends a virtual card link via email to the vendor associated with the ‘transId`.
326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 |
# File 'lib/payabli/money_out/client.rb', line 326 def send_v_card_link(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "POST", path: "vcard/send-card-link", body: Payabli::MoneyOut::Types::SendVCardLinkRequest.new(params).to_h, request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::MoneyOutTypes::Types::OperationResult.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#update_check_payment_status(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponse00Responsedatanonobject
Updates the status of a processed check payment transaction. This endpoint handles the status transition, updates related bills, creates audit events, and triggers notifications.
The transaction must meet all of the following criteria:
-
Status: Must be in Processing or Processed status.
-
**Payment method**: Must be a check payment method.
### Allowed status values
| Value | Status | Description | |——-|——–|————-| | ‘0` | Cancelled/Voided | Cancels the check transaction. Reverts associated bills to their previous state (Approved or Active), creates “Cancelled” events, and sends a `payout_transaction_voidedcancelled` notification if the notification is enabled. | | `5` | Paid | Marks the check transaction as paid. Updates associated bills to “Paid” status, creates “Paid” events, and sends a `payout_transaction_paid` notification if the notification is enabled. |
411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 |
# File 'lib/payabli/money_out/client.rb', line 411 def update_check_payment_status(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "PATCH", path: "MoneyOut/status/#{URI.encode_uri_component(params[:trans_id].to_s)}/#{URI.encode_uri_component(params[:check_payment_status].to_s)}", request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::Types::PayabliApiResponse00Responsedatanonobject.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#v_card_get(request_options: {}, **params) ⇒ Payabli::MoneyOutTypes::Types::VCardGetResponse
Retrieves vCard details for a single card in an entrypoint.
293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 |
# File 'lib/payabli/money_out/client.rb', line 293 def v_card_get(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "GET", path: "MoneyOut/vcard/#{URI.encode_uri_component(params[:card_token].to_s)}", request_options: ) begin response = @client.send(request) rescue Net::HTTPRequestTimeout raise Payabli::Errors::TimeoutError end code = response.code.to_i if code.between?(200, 299) Payabli::MoneyOutTypes::Types::VCardGetResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |