LoginSignup
1
0

More than 1 year has passed since last update.

Tableau CRMのセキュリティ述語について

Posted at

Tableau CRMでセキュリティ述語を実装する方法について記載します。

セキュリティ述語とは?

セキュリティ述語を使用すると一つのテーブル、ダッシュボードでもログインするユーザーによって見せる範囲を制限する「行レベルセキュリティ」が実現出来ます。セキュリティ述語ではフィルターではなくそもそもデータ自体が表示されなくなるので非常に高いセキュリティでデータを表示出来ます。
Tableau CRMでは行レベルのセキュリティを実装する方法が大きく2種類あります。

  • Salesforceのセキュリティを継承する
  • セキュリティ述語を実装する

Salesforceのセキュリティを継承する方法ではSalesforce側で設定されているロールベースセキュリティなどをそのままTableau CRM上でも適用します。

セキュリティ述語を使用するとSalesforceのセキュリティ設定とは別の条件でセキュリティを実装したり、外部から取り込みのデータにセキュリティを実装、また顧客やパートナーに対してデータ共有を行うExperience Cloud Analyticsなどでよく実装されます。

Salesforceのセキュリティの上でデータ配信を行うマルチテナントDBが実現出来ますね。
image.png

今回はSalesforceのデータではなくCSVファイルからUploadしたファイルを元にどのようにセキュリティ述語を設定していくのか説明します。

サンプルデータ

このようなデータを前提に話をします

製品 売上 担当者
AA 1000 Discovery
BB 2000 Astro
CC 3000 Astro
BB 2000 Discovery

担当者欄を元にログインユーザー名と一致するものだけ表示します。

データアップロード

データセットの画面で「セキュリティ述語」の設定があり、規定では”なし”になっています。
この状態ではTableau CRMにログイン出来るユーザーは4行全て見ることが出来ます。

image.png

API名の取得

こちらにフィルター条件を設定していきます。担当者で絞り込みを行いたいので、担当者のAPI名を確認します。
Salesforceから取得したデータセットの場合はSalesforceのAPI名が使えますが、CSVファイルベースのデータセットだとロード時に自動的に名前が振られます。

一度データセットを開いて「項目パネル」で「項目のAPI参照名を表示」をチェックするとAPI名が判明します。
担当者はColumn3ですので、フィルター条件はこちらを使います。

image.png

静的なセキュリティ述語

セキュリティ述語では文字列を指定することもできるので、”Discovery”担当者のデータだけを表示する設定を試します。

image.png

ユーザー情報を使用したセキュリティ述語

ユーザーオブジェクト情報を使用してセキュリティ述語を使うことも出来ます。

image.png

階層を持ったユーザー絞り込み

例えばマネージャーは自分の部下のデータは見えるようにしたいなど階層化したアクセス権限を実装したい場合はフィルターも複数項目用意します。

製品 売上 担当者 マネージャー
AA 1000 Discovery SalesManager
BB 2000 Astro SalesManager
CC 3000 Astro SalesManager
BB 2000 Discovery MarketingManager

この場合は担当者 or マネージャーに自分の名前があればアクセス可能と言う設定にします。
マネージャーのAPIはColumn4とすると

image.png

このように複数の条件をorで指定します。カラムと条件を階層分追加すれば幾らでも追加出来ます。

レシピ/データフローでの設定

これで実装可能になりましたが、日時処理などで定期的に更新されるデータセットの場合はレシピなどでデータを作成する際にセキュリティ述語を設定するのがベストプラクティスです。

image.png

レシピで言うと「出力」オペレーターの中でセキュリティ述語を指定することが出来ます。
image.png

セキュリティ述語についての詳細はデータセットの述語式の構文を御覧ください

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0