0.01
No commit activity in last 3 years
No release in over 3 years
Ruby client for the Booker API - https://developers.booker.com
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 1.10
~> 1.0.2
~> 3.0
>= 0.7.0

Runtime

>= 0.14
>= 1.5, <= 2.5
>= 0
 Project Readme

Booker Ruby Client

Codeship Status for HireFrederick/booker_ruby

Client for the Booker API. See https://developers.booker.com for method-level documentation.

Important: As of version 2.0 of this gem, support for API v4 methods has been removed. Use of v4 APIs should be migrated to the equivalent v4.1 or v5 methods available as part of Booker's new Developer Portal.

Setup

Add the gem to your Gemfile:

gem 'booker_ruby', '~> 3.3.3'

Configuration may be specified via the environment or when initializing Booker::Client:

Configuring via environment variables:

BOOKER_CLIENT_ID = YOUR_CLIENT_ID
BOOKER_CLIENT_SECRET = YOUR_CLIENT_SECRET
BOOKER_API_SUBSCRIPTION_KEY = YOUR API SUBSCRIPTION KEY
BOOKER_API_BASE_URL = https://api.booker.com # Defaults to https://api-staging.booker.com
BOOKER_DEFAULT_PAGE_SIZE = 10 # Default
BOOKER_API_DEBUG = false # Set to true to print request details to the log

To ease development, the gem points to Booker's API Sandbox at apicurrent-app.booker.ninja by default. For production, you must set BOOKER_API_BASE_URL to https://api.booker.com.

Errors

The booker_ruby gem provides a myriad of methods with useful error information on its Booker::Error. These include: message, error, description, url, request, and response.

Using Booker::Client

A client subclass is available for each API:

Authentication

The client supports both refresh token and client credentials authorization flows. If a refresh_token is provided or auth_with_client_credentials is set to true, the client will attempt to request a new access token as needed.

If your API subscription permits, an access token and refresh token for a specific merchant may be retrieved via OAuth. The Booker OmniAuth Gem provides an OmniAuth strategy to make this easy for Rails/Rack-based apps.

Access token scopes:

  • An access token scope may be provided to instruct the client what type of token should be requested. You most likely want to use the public (default) or merchant scope depending on your use case.
# Use Booker::V41::Booking to look up a location's details

client = Booker::V41::Customer.new(
  temp_access_token: 'MY TOKEN',
  refresh_token: 'MY REFRESH TOKEN'
)

location = client.location(id: 45678)

location.ID
# => 45678

location.BusinessName
# => 'My Booker Spa'

# Get available services

services = client.treatments(location_id: location.ID)

# etc..

Here's an example of a client instantiated to use client_credentials auth flow:

client = Booker::V41::Customer.new(
      client_id: 'your client id',
      client_secret: 'your client secret',
      api_subscription_key: 'your api subscription key',
      auth_with_client_credentials: true,
      access_token_scope: 'merchant'
)

If you want to get location specific authentication you can add the following client options: { location_id: 'the booker location id' }

If you want to store the temp_access_token, you can add the token_store and token_store_callback_method client options:

module IStoreTempAccessToken
  def self.store_temp_access_token_method(token, expires_at)
    # => store token and expires at if you want
  end
  
  def get_stored_temp_access_token
    # => get stored token
  end
end

client = Booker::V41::Booking.new(
  temp_access_token: IStoreTempAccessToken.get_stored_temp_access_token,
  refresh_token: 'MY REFRESH TOKEN',
  token_store: IStoreTempAccessToken,
  token_store_callback_method: :store_temp_access_token_method,     
)

Available Methods

For available methods, see the API documentation at https://developers.booker.com

  • If an API you want to use has not been added to this gem, please contribute via a Pull Request!

Handling dates and times

  • Booker's v5 API is timezone-aware. This gem will parse returned Dates and Times for you and they remain in the offset provided by Booker.
  • Booker's v4.1 API is not timezone-aware, so this gem will convert any date-time values from Booker into your current timezone offset per the thread-local Time.zone.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/HireFrederick/booker_ruby.

License

The gem is available as open source under the terms of the MIT License.