Node.js で Pushbullet のデータを MySQL データベースとしてクエリ

Jerod Johnson
Jerod Johnson
Director, Technology Evangelism
Node.js からPushbullet のデータに対して MySQL クエリを実行する方法を紹介します。

Pushbullet 用の ODBC Driver の SQL Gateway を使用すると、MySQL インターフェース経由でPushbullet のデータをクエリできます。以下の手順に従って、SQL Gateway の MySQL リモーティングサービスを起動し、Node.js からクエリを開始してください。

Pushbullet のデータに接続

まだ行っていない場合は、データソース名(DSN)で必要な接続プロパティの値を指定してください。組み込みの Microsoft ODBC データソースアドミニストレーターを使用して DSN を設定できます。これはドライバーインストールの最後のステップでもあります。Microsoft ODBC データソースアドミニストレーターを使用して DSN を作成・設定する方法については、ヘルプドキュメントの「はじめに」の章を参照してください。

API キー認証の設定

Pushbullet はトークンベースの認証(Access Token)を使用します。Access Token を取得するには、以下のステップで進めます:

  1. https://www.pushbullet.com で Pushbullet アカウントにログインします
  2. Settings > Account に移動します
  3. 「Create Access Token」をクリックします
  4. 生成されたトークンをコピーします

Access Token を取得したら、以下の接続プロパティを設定します:

  • AuthScheme:APIKey に設定します。
ProfileSettings 接続プロパティには以下を設定します:
  • APIKey:Pushbullet の Access Token に設定します。

接続文字列の例

Profile=C:\profiles\Pushbullet.apip;ProfileSettings='APIKey=your_access_token;';AuthScheme=APIKey;

Pushbullet への接続

認証を設定すると、Pushbullet に接続して、Users、Pushes、Devices、Chats、Subscriptions、Channels などの利用可能なテーブルからデータをクエリできます。

SQL Gateway を設定

SQL Gateway 概要を参照して、Pushbullet のデータ を仮想 MySQL データベースとして接続を設定してください。クライアントからの MySQL リクエストをリッスンする MySQL リモーティングサービスを設定します。サービスは SQL Gateway UI で設定できます。

SQL Gateway で MySQL リモーティングサービスを作成(Salesforce の例)

Node.js から Pushbullet をクエリ

以下の例では、mysql モジュールを使用して Pushbullet への接続を定義し、クエリを実行する方法を示しています。以下の情報が必要です。

  • ホスト名またはアドレス、およびポート:MySQL リモーティングサービスが MySQL 接続をリッスンしているマシンとポート
  • ユーザー名パスワード:SQL Gateway の Users タブで認証したユーザーのユーザー名とパスワード
  • データベース名:MySQL リモーティングサービス用に設定した DSN

以下のコードでPushbullet のデータに接続し、クエリの実行を開始できます。

var mysql      = require('mysql');
var connection = mysql.createConnection({
  host     : 'localhost',
  database : 'CData API Sys',
  port	   : '3306',
  user     : 'mysql_user',
  password : 'test'
});
connection.connect();
connection.query('SELECT * FROM Users', function(err, rows, fields) {
  if (err) throw err;
  console.log(rows);
});

connection.end();

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

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

Pushbullet に接続