はじめに
ASTERIA WARP 1610リリースに伴い、CDataの Salesforce アダプターが新たに公開されています。
Salesforce へのアクセスは CData Software Inc. 社の提供する技術を利用して RDB のように SQL でアクセスする手段を提供します。
従って、ASTERIA 側で基本的な操作方法は一般的な RDB 系コンポーネントと同じですが、CData 固有の SQL ステートメントや利用できるデータモデルについて詳細は下記の CData 社のオンラインヘルプも参考にしてください。
・CData JDBC Driver for Salesforce のオンラインヘルプ
http://cdn.cdata.com/help/GFB/jdbc/
今回は Salesforce 側で登録されているドキュメントを SalesforceGet コンポーネント、SalesforceSQLCall コンポーネントを利用してローカルにダウンロードしてみたいと思います。
事前準備
セキュリティトークンの取得
Salesforce への接続するためにはセキュリティトークンが必要となります。
下記の手順でセキュリティトークンを取得することができます。
1.Salesforce.com の[私の設定]→[個人用]→[私のセキュリティトークンのリセット]を開きます。
2.[セキュリティトークンのリセット]をクリックします。トークンが E メールで送られます。
コネクションの作成
CData オプションのコネクションはデザイナー側で作成します。
インスペクタで接続設定情報を入力する際に、Salesforce アダプターでは最低限、下記のようなプロパティを設定することを推奨します。
- 接続名:コネクション名を設定します。
- ユーザー:ユーザー名を設定します。
- パスワード:パスワードを設定します。
- セキュリティトークン:事前準備で取得したセキュリティトークンを設定します。
- サンドボックスを使用:サンドボックスアカウントに接続するには「はい」と設定します。デフォルトは「いいえ」と設定されています。
コネクションのテスト
Salesforce アダプターのコネクションが作成されたら、コネクションの接続テストを実行してみましょう。
コネクションの接続テストが成功していることが確認できます。
フローの作成
Salesforce 側で登録されているドキュメント
先ずは、Salesforce 画面から登録されているドキュメントを確認してみましょう。
ご覧の通り、「Infoteria」フォルダに2つ、「CData」フォルダに2つのドキュメントがあります。
フローの構成
上記の4つのドキュメントを指定したローカルパスにフォルダーごとダウンロードするフローを作成してみましょう。
ダウンロード対象のドキュメント情報を SalesforceGet コンポーネントから取得し、SalesforceSQLCall コンポーネントを利用してローカルフォルダーにダウンロードした後に、そのリスト(ファイル名、ファイルの完全パス)を CSV ファイルに出力するフローとなります。
コンポーネントの設定内容
主に、SalesforceGet → マッパー → SalesforceSQLCall コンポーネントについて設定内容を確認してみます。
-
SalesforceGet コンポーネントの SQL ビルダー
- テーブルの結合:Document テーブル、Folder テーブル
- 表示項目:
- Document.Id:ドキュメントの一意の識別子
- Document.FolderId:ドキュメントのフォルダID
- Document.Name:ドキュメントの名前
- Folder.Name:ドキュメントのフォルダ名
- 条件:フォルダ名が「Infoteria」又は「CData」
-
マッパー1コンポーネント
SalesforceGet コンポーネントと SalesforceSQLCall コンポーネントの間に配置したマッパーコンポーネントの設定内容です。SalesforceGet コンポーネントから取得した情報を SalesforceSQLCall コンポーネントの SQL パラメーターにマッピングしています。
また、フォルダ名情報を利用し、Salesforce の各フォルダ名ごと保存されるように保存先のローカルパスを設定しています。ここでは、「C:¥Salesforce¥Infoteria」と「C:¥Salesforce¥CData」が保存先のパスになると思います。 -
SalesForceSQLCall コンポーネント
-
- 実行する処理:ストアド実行(結果なし)
- SQL文:「{ call DownloadDocument( ?Id?, ?Name?, ?Folderid?, ?LocalPath?, ?FileName?, ?FullPath?)}」
-
- Id:入力用。ダウンロードするドキュメントのID。
- Name:入力用。ダウンロードするドキュメントの名前
- FolderId:入力用。ダウンロードするドキュメントのフォルダID。
- LocalPath:入力用。ファイルの保存先のローカルパス。
- FileName:出力用。ダウンロードされたファイルの名前。
- FullPath:出力用。ダウンロードされたファイルの完全パス(名前を含む)。
-