Ruby でDrift のデータ連携アプリを構築

古川えりか
古川えりか
コンテンツスペシャリスト
Ruby でODBC 経由でDrift に接続して、モダンなクラウド連携アプリを開発。

CData ODBC Driver for API を使うと、簡単にRuby アプリケーションにリアルタイムDrift のデータを連携・統合できます。 この記事では、Drift のデータにリアルタイムに連携するRuby アプリケーションを構築して、クエリを実行し、結果を表示してみます。

CData ODBC ドライバとは?

CData ODBC ドライバは、以下のような特徴を持ったリアルタイムデータ連携ソリューションです。

  1. Drift をはじめとする、CRM、MA、会計ツールなど多様なカテゴリの270種類以上のSaaS / オンプレミスデータソースに対応
  2. 多様なアプリケーション、ツールにDrift のデータを連携
  3. ノーコードでの手軽な接続設定
  4. 標準 SQL での柔軟なデータ読み込み・書き込み

CData ODBC ドライバでは、1.データソースとしてDrift の接続を設定、2.Ruby 側でODBC Driver との接続を設定、という2つのステップだけでデータソースに接続できます。以下に具体的な設定手順を説明します。

CData ODBC ドライバのインストールとDrift への接続設定

まずは、本記事右側のサイドバーからAPI ODBC Driver の無償トライアルをダウンロード・インストールしてください。30日間無償で、製品版の全機能が使用できます。

通常はCData ODBC ドライバのインストール後にODBC DSN 接続ウィザードが立ち上がり、設定を行うことができます。 もしODBC DSN 接続が未済の場合には、Microsoft ODBC データソースアドミニストレータでODBC DSN を作成および設定することができます。

まず、Profile 接続プロパティをディスク上のDrift プロファイルの場所に設定します(例:C:\profiles\Drift.apip)。次に、ProfileSettings 接続プロパティをDrift の接続文字列に設定します(以下を参照)。

Drift API プロファイル設定

Drift はOAuth ベースの認証を使用します。

まず、https://dev.drift.com でアプリケーションを登録する必要があります。アプリにはclient ID とclient secret が割り当てられます。OAuthClientId およびOAuthClientSecret プロパティを介して、これらを接続文字列に設定します。OAuth アプリケーションの設定の詳細については、https://devdocs.drift.com/docs/ を参照してください。

ProfileSettings 接続プロパティに以下のオプションを設定すると、接続できるようになります。

  • AuthScheme:OAuth に設定します。
  • OAuthClientId:アプリ設定で指定されたClient Id に設定します。
  • OAuthClientSecret:アプリ設定で指定されたClient Secret に設定します。
  • CallbackURL:アプリ設定で指定したRedirect URI に設定します。
  • InitiateOAuth:GETANDREFRESH に設定します。InitiateOAuth を使用して、OAuthAccessToken を取得するプロセスを管理できます。

Ruby および必要なGem のインストール

Ruby をまだインストールしていない場合は、Ruby インストールページを参考にインストールしてください。 Ruby をインストールしたら、次にruby-dbi、dbd-odbc、ruby-odbc gems をインストールします。

gem install dbi
gem install dbd-odbc
gem install ruby-odbc

Drift のデータに連携するRuby アプリケーションの作成

Ruby ファイル (例: APISelect.rb) を作成し、テキストエディタで開きます。ファイルに次のコードをコピーします:

#connect to the DSN
require 'DBI'
cnxn = DBI.connect('DBI:ODBC:CData API Source','','')

#execute a SELECT query and store the result set
resultSet = cnxn.execute("SELECT Id, DisplayName FROM Contacts WHERE LastName = 'Stark'")

#display the names of the columns
resultSet.column_names.each do |name|
  print name, "\t"
end
puts

#display the results
while row = resultSet.fetch do
  (0..resultSet.column_names.size - 1).each do |n|
    print row[n], "\t"
  end
  puts
end
resultSet.finish

#close the connection
cnxn.disconnect if cnxn

これで、Ruby からDrift のデータへ接続できるようになります。簡単にコマンドラインからファイルを叩いて接続を確認してみましょう。

ruby APISelect.rb

Drift からRuby へのデータ連携には、ぜひCData ODBC ドライバをご利用ください

このようにCData ODBC ドライバと併用することで、270を超えるSaaS、NoSQL データをコーディングなしで扱うことができます。30日の無償評価版が利用できますので、ぜひ自社で使っているクラウドサービスやNoSQL と合わせて活用してみてください。

CData ODBC ドライバは日本のユーザー向けに、UI の日本語化、ドキュメントの日本語化、日本語でのテクニカルサポートを提供しています。

はじめる準備はできましたか?

API Driver で Drift のライブデータに接続

Drift に接続 お問い合わせ