API Clients

Overview

Jumpstart Pro includes a built-in API client generator. You can use it to create your own API clients for integrations with any API you would like.

As developers, it's easy to reach for Rubygems, but each dependency we add makes it harder to maintain your application. We've found that we need to fork most API Rubygems to fix bugs or implement API features that aren't supported yet in the library.

Now, our default is to build an API client ourselves. It's easy to maintain, doesn't break from external changes, and only implements the features we need. We've made this available to Jumpstart Pro users to more easily take advantage of building their own API clients.

To learn more about API Clients in Jumpstart Pro, check out the Net Http API Client from Scratch video on GoRails.

Creating API Clients

Run the API client Rails generator to create an API client.

rails g api_client OpenAi

This generates app/clients/open_ai_client.rb and a matching test file.

To implement API endpoints, you will define methods that make an HTTP request to the API endpoints. Here's an example using the Sendfox API:

class SendfoxClient < ApplicationClient
  BASE_URI = "https://api.sendfox.com/"

  def me
    get "/me"
  end

  def lists
    get "/lists"
  end

  def list(id)
    get "/lists/#{id}"
  end

  def create_list(name:)
    post "/lists", body: {name: name}
  end

  def remove_contact(list_id:, contact_id:)
    delete "/lists/#{list_id}/contacts/#{contact_id}"
  end

  def contacts(email: nil)
    if email
      get "/contacts?email=#{CGI.escape(email)}"
    else
      get "/contacts"
    end
  end

  def contact(id)
    get "/contacts/#{id}"
  end

  def create_contact(**params)
    post "/contacts", body: params
  end

  def unsubscribe(email:)
    patch "/unsubscribe", body: {email: email}
  end

  def campaigns
    get "/campaigns"
  end

  def campaign(id)
    get "/#{id}"
  end
end

ApplicationClient

ApplicationClient is the base class that API clients inherit from. It provides methods for get, post, patch, put, and delete. It also handles authorization using the Authorization header and parsing response bodies as JSON.

You can override these methods in your API client to match your API. For example, if you need to parse XML instead of JSON, override the parse_response method and use Nokogiri instead.

More features

Optionally pass the --url option to set the base URL

Optionally pass methods with index, show, create, update, destroy types

rails g api_client OpenAi completions:create --url https://api.openai.com