An API for Gimlet
One thing on our minds, even before we launched, has been a way for Gimlet to work with other software. We’ve always wanted to make it easy for you to bring data in and out of Gimlet — it’s your data, after all. In the programming world, this feature is called an API, or “Application Programming Interface,” and it’s a way to let people write their own programs for adding and retrieving data. However, we’ve always had other, higher priorities than building it. That is, until now…
We’re very excited to announce that as of today, Gimlet has an official API! Technical details are online, and we have documentation and examples in PHP and Ruby available for you to check out.
How Do I Use the API?
You’ll need an API Key for your Gimlet user account and some familiarity with basic programming. The API is RESTful, so it doesn’t mandate any particular programming language be used. Just choose a language with a simple HTTP library that supports common HTTP methods like GET and POST.
If you don’t have a favorite programming language, try Ruby, and use the Ruby examples in our API repository.
Generate an API Key
Our Gimlet API uses HTTP Basic Authentication, requiring your email address and a password (an API key) to access your account data. Account administrators can generate API keys for users.
To create an API Key:
- Sign into Gimlet and choose the “Account” tab
- Click on the “Branches” link (near the top)
- Select the “Users” option
- Click on any email address
- Press the “Generate key” button
After the button is pressed, you’ll see your key, which is a random hexadecimal string. Use this string as your password, along with your email address to access the API endpoints.
Make an API Call
Currently, the main API features we provide are adding and retrieving question data, with some added queries to get data about your branches and stats categories. In the future, we’ll add API support for report data and user management.
Ruby Example - List questions
# Ruby Example | |
require 'date' | |
require 'faraday' | |
require 'json' | |
# Required API Variables | |
domain = 'your_domain' | |
email = 'your_email_address' | |
api_key = 'your_api_key' | |
site_id = 'your_site_id' | |
# Report Dates | |
today = Date.today | |
thirty_days_ago = today - 30 | |
# URL and Path | |
url = "https://#{domain}.gimlet.us" | |
path = "/api/v1/sites/#{site_id}/questions.json?start_date=#{thirty_days_ago.to_s}&end_date=#{today.to_s}" | |
# New connection with base URL and path | |
conn = Faraday.new(url: url) # New connection with base URL | |
conn.basic_auth(email, api_key) # Set the authentication header | |
response = conn.get(path) # GET API request | |
# Do what you need with the data | |
results = JSON.parse(response.body) |
API Use Cases
How could you use this? You could import sessions from your chat program (for example, LibraryH3lp) into Gimlet and do reporting in one place. Or, if you have a dashboard that aggregated information about all your library services, you could have data export from Gimlet into it on a daily basis. Maybe you could even create a little webform to add transactions to Gimlet even faster.
The possibilities are only up to your imagination.
Feedback Welcome
Lastly, please let us know how you decide to use the API. We’d love to see any examples of how it helps your organization. Feedback and suggestions are super important, too.
And as always: Thank you for using Gimlet!
Cheers!
– Nate for Gimlet HQ