Class: Payabli::Vendor::Client
- Inherits:
-
Object
- Object
- Payabli::Vendor::Client
- Defined in:
- lib/payabli/vendor/client.rb
Instance Method Summary collapse
-
#add_vendor(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponseVendors
Creates a vendor in an entrypoint.
-
#delete_vendor(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponseVendors
Delete a vendor.
-
#edit_vendor(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponseVendors
Updates a vendor's information.
-
#enrich_vendor(request_options: {}, **params) ⇒ Payabli::Types::VendorEnrichResponse
Triggers AI-powered vendor enrichment for an existing vendor.
-
#get_enrichment_call_status(request_options: {}, **params) ⇒ Payabli::Types::VendorCallStatusResponse
Returns the latest AI outreach call activity for a vendor.
-
#get_vendor(request_options: {}, **params) ⇒ Payabli::Types::VendorQueryRecord
Retrieves a vendor's details, including enrichment status and payment acceptance info when available.
- #initialize(client:) ⇒ void constructor
-
#schedule_enrichment_call(request_options: {}, **params) ⇒ Payabli::Types::VendorScheduleCallResponse
Schedules an AI outreach call to a vendor to collect their preferred payment method and contact email.
Constructor Details
#initialize(client:) ⇒ void
9 10 11 |
# File 'lib/payabli/vendor/client.rb', line 9 def initialize(client:) @client = client end |
Instance Method Details
#add_vendor(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponseVendors
Creates a vendor in an entrypoint.
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
# File 'lib/payabli/vendor/client.rb', line 25 def add_vendor(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "POST", path: "Vendor/single/#{URI.encode_uri_component(params[:entry].to_s)}", body: Payabli::Types::VendorData.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::Types::PayabliApiResponseVendors.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#delete_vendor(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponseVendors
Delete a vendor.
129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 |
# File 'lib/payabli/vendor/client.rb', line 129 def delete_vendor(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "DELETE", path: "Vendor/#{URI.encode_uri_component(params[:id_vendor].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::PayabliApiResponseVendors.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#edit_vendor(request_options: {}, **params) ⇒ Payabli::Types::PayabliApiResponseVendors
Updates a vendor's information. Send only the fields you need to update.
94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 |
# File 'lib/payabli/vendor/client.rb', line 94 def edit_vendor(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "PUT", path: "Vendor/#{URI.encode_uri_component(params[:id_vendor].to_s)}", body: Payabli::Types::VendorData.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::Types::PayabliApiResponseVendors.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#enrich_vendor(request_options: {}, **params) ⇒ Payabli::Types::VendorEnrichResponse
Triggers AI-powered vendor enrichment for an existing vendor. Runs one or more enrichment stages (invoice scan,
web search) based on the scope parameter. Can automatically apply extracted payment acceptance info and vendor
contact information to the vendor record, or return raw results for manual review. Contact Payabli to enable
this feature.
166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 |
# File 'lib/payabli/vendor/client.rb', line 166 def enrich_vendor(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request_data = Payabli::Vendor::Types::VendorEnrichRequest.new(params).to_h non_body_param_names = %w[entry] body = request_data.except(*non_body_param_names) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "POST", path: "Vendor/enrich/#{URI.encode_uri_component(params[:entry].to_s)}", body: body, 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::VendorEnrichResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#get_enrichment_call_status(request_options: {}, **params) ⇒ Payabli::Types::VendorCallStatusResponse
Returns the latest AI outreach call activity for a vendor. The response is a composite object with a state
discriminator (none, scheduled, successful, or failed); the block that matches the current state is
populated. When the vendor has no call activity, state is none and the response returns HTTP 200.
250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 |
# File 'lib/payabli/vendor/client.rb', line 250 def get_enrichment_call_status(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "GET", path: "Vendor/#{URI.encode_uri_component(params[:id_vendor].to_s)}/enrichment/call-status", 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::VendorCallStatusResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#get_vendor(request_options: {}, **params) ⇒ Payabli::Types::VendorQueryRecord
Retrieves a vendor's details, including enrichment status and payment acceptance info when available.
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 |
# File 'lib/payabli/vendor/client.rb', line 60 def get_vendor(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "GET", path: "Vendor/#{URI.encode_uri_component(params[:id_vendor].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::VendorQueryRecord.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |
#schedule_enrichment_call(request_options: {}, **params) ⇒ Payabli::Types::VendorScheduleCallResponse
Schedules an AI outreach call to a vendor to collect their preferred payment method and contact email. This is the third enrichment stage. Calls are scheduled for the next business day at around 9 AM in the vendor's timezone, with retries on no-answer and a fallback payment method applied when retries are exhausted. This feature is opt-in at the org level. Contact your Payabli representative to enable it, provision a phone number, and discuss pricing.
209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 |
# File 'lib/payabli/vendor/client.rb', line 209 def schedule_enrichment_call(request_options: {}, **params) params = Payabli::Internal::Types::Utils.normalize_keys(params) request_data = Payabli::Vendor::Types::ScheduleEnrichmentCallRequest.new(params).to_h non_body_param_names = %w[entry] body = request_data.except(*non_body_param_names) request = Payabli::Internal::JSON::Request.new( base_url: [:base_url], method: "POST", path: "Vendor/enrich/schedule_call/#{URI.encode_uri_component(params[:entry].to_s)}", body: body, 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::VendorScheduleCallResponse.load(response.body) else error_class = Payabli::Errors::ResponseError.subclass_for_code(code) raise error_class.new(response.body, code: code) end end |