Overview

Clients handle the authentication and requests to the ledger. A ledger may have different authentication strategies, so clients will accept different arguments. For example, QuickBooks Online utilizes Oauth 2.0 while NetSuite offers Token Based Authentication. While similar, the required keys are different.

How to use

Unless you are customizing LedgerSync, you will always pass an instantiated client to an object (e.g. an operation). The object will handle using the client as needed.

Gotchas

Oauth 2.0

Clients store the authentication details for the ledger. Given that Oauth 2.0 tokens can refresh during a request, these clients will handle saving credentials back to the client instance. Typically (though some clients offer more automated solutions), you will want to save any changes back to your database. You can use client.ledger_attributes_to_save to retrieve a hash of which attributes to save. Your code to do so could look like the following:

1
2
3
4
# Assuming `client` is defined as an instance of a ledger Client class
client.ledger_attributes_to_save.each do |attribute_to_save, value|
  # Store value
end

Related articles: