Improve your QuickBooks/Ruby integration experience with the quickbooks-ruby-base gem
Code from screencast and tutorial is available on Github.
Real-world to gem
I was recently able to wrap up a pattern from my QuickBooks/Ruby consulting into a gem. The gem complements and extends the quickbooks-ruby gem. Let's see how.
- First, install the gem along with
quickbooks-ruby
. - Now you need to configure the persistent locations of the Intuit OAuth connection.
- For example, if you are storing the token, secret, and company_id like this:
-
account = Account.find(1) account.qb_token account.qb_secret account.company_id
- Your config file might look like this.
- Next, I am going fire up the
rails console
to further demonstrate. - To create a
quickbooks-ruby
service takes only one line of code. - There is a
qr_model
method that generates and initializes a quickbooks-ruby model, which are long to type out by hand. - You can pass as many arguments to the model as it takes.
- Lastly, the
show
method will return a "smart" array, customers in this example. -
"Smart" because the DESC
value returned adapts to which service is being shown. For example, if its the invoice service calling show, then thedoc_number
is displayed forDESC
(for customer service itsdisplay_name
). - The show method saves you from having type the following below and it is most useful for console usage.
- You can also pass the same options you would to the
quickbooks-ruby
query method e.g.
data:image/s3,"s3://crabby-images/46e59/46e5985ab8e2406a3f4efa6b70ac2d215bd4f8e6" alt=""
bundle install
.data:image/s3,"s3://crabby-images/28dfc/28dfc567097b4630e9f4adbc5bddbc7f2e9a0389" alt=""
config/initializers/quickbooks.rb
.data:image/s3,"s3://crabby-images/4300b/4300b69a9976d13cab4589045715b242841480be" alt=""
service
method is available off the base object so you can quickly access query
, create
, and update
.data:image/s3,"s3://crabby-images/23c69/23c692a74784c6c7251eb74e0b585d8245c9f2f3" alt=""
data:image/s3,"s3://crabby-images/b58f8/b58f8991b8a27bc22f2ce18f1323e7cf09b708b9" alt=""
data:image/s3,"s3://crabby-images/7005d/7005dac767e628d8e3c2641fdd895cf109eb00be" alt=""
data:image/s3,"s3://crabby-images/30517/305176fdb0d86dbab41e470677a8a5f3a6a04f59" alt=""
email_address
model.$ base.service.query.entities.map{ |e| "ID: #{e.id} DESC: #{e.display_name}" }
$ base.show(page: 1, per_page: 150)
The
show
alone method is worth installing the gem.
Contributing
I want to keep the gem light weight but I would love to see pull requests coming from your QuickBooks/Ruby integration experiences. You can see the making of this gem in this 4 part series.
- Pushed on 04/21/2014 by Christian
- QuickBooks Integration Consulting