この記事の概要
セールスフォースでレコードに添付ファイルがついているかどうかがリストビューから分かるといいな、と思った事ありますよね?
やり方を探してみると、APEXでの開発が必要という記述が見つかります。
しかし、コードなんて書けない!!
という人(僕のことです)の為に、
フローで何とかできないか、やってみました。
残念ながらファイルの添付をトリガにしたレコードトリガフローは作れないようなので、
毎晩実行されるスケジュールトリガフローで
添付した翌日にはチェックボックスがtrueになるというものを作りました。
なんか簡単なようで結構大作になってしまったので、
もしかしたらもっとシンプルな方法があるかもしれません。
また僕はこれの応用で
SVFcloudで帳票ファイルに添付画像を出力するために必要なコンテンツドキュメントIDを
自動でテキスト項目に記入するフローを使っています。
途中でレコードを取得しているのでこれも殆ど同じように作れます。
添付ファイルのリレーションってどうなってるのか
セールスフォースの添付ファイルは下の図のようなオブジェクトで構成されています。
添付されるオブジェクトに直接添付ファイルオブジェクトのリレーションがあるわけではなく、
間にコンテンツドキュメントリンクという連結オブジェクトを持つ、いわゆる多対多のリレーションになっています。
厄介なのはコンテンツドキュメントリンクには作成日の項目が無い事です。
なので、今回のフローでは
前日に作成されたコンテンツドキュメントのレコードを取得して、
そこからコンテンツドキュメントリンクのレコードを辿って、
添付されるオブジェクトのレコードを見つけて「添付ファイルの有無」チェックボックスをtrueにします。
フローの全体像
- 前日に作成されたコンテンツドキュメントのレコードを取得
- 取得したコンテンツドキュメントレコードの子レコードであるコンテンツドキュメントリンクをコレクション変数に割り当て
- リンク先の添付元レコードを取得
- 1レコードに複数ファイルが添付されている場合に重複しないようにしながら、添付元レコードをコレクション変数に割り当て(この時に添付ファイルチェックボックス項目をtrueにする)
- コレクション変数に基づいて添付元レコードを更新
と、なります。
割とめんどくさいのが複数ファイル添付のチェックです。
しかしこれをやっておかないとレコード更新時にエラーが出ます。
おかげで多重ループも使う羽目に。
あと、細かい説明を省いていますが適宜必要な変数を作成してください。
中身
前日に作成されたコンテンツドキュメントのレコードを取得
とりあえず、毎晩動くようにしておきます。
コンテンツドキュメントオブジェクトで前日以降に作られたレコードをすべて取得します。(前日は数式で作っておきます)
取得したコンテンツドキュメントレコードの子レコードであるコンテンツドキュメントリンクをコレクション変数に割り当て
取得したレコードでループします。
コンテンツドキュメントリンクオブジェクトのレコードを取得します。
条件はこのレコードの親になるコンテンツドキュメントIDがループしているレコードのIDと一致しているものです。
取得したレコードをコレクション変数に割り当てます。
このループを回して、コンテンツドキュメントリンクのコレクション変数を前日作成されたもので満たします。
リンク先の添付元レコードを取得
作成したコンテンツドキュメントリンクのコレクション変数でループします。
添付されるオブジェクトのレコードを取得します。
条件はカスタムオブジェクトIDがループしているレコードの「リンク済みエンティティID」と一致するものです。
レコードが取得できたかどうかを確認します。
(今思ったけどもしかしたらこれ要らないかも。)
1レコードに複数ファイルが添付されている場合に重複しないようにしながら、添付元レコードをコレクション変数に割り当て(この時に添付ファイルチェックボックス項目をtrueにする)
コレクション変数でループします。このコレクション変数は最終的に更新する対象となる添付されるオブジェクトのレコードコレクションです。
さっき取得した添付されているレコードがループしているレコードとIDが一致するかどうかを確認します。
上記の分岐で重複するとされた場合にBoolean変数をTrueにします。この変数は予め別途作成しておいてください。
このループで、総当たりで重複するレコードがないか確認をしていき、一つでも重複があればBoolean変数で記録するようになっています。
で、Boolean変数がTrueかどうかで重複がある(つまり同一レコードに添付されている二つ目以降の添付ファイル)事を確認します。
重複が無い場合は単一レコード変数に割り当てます。この時に添付ファイルの有無項目のチェックボックスをtrueにしておきます。
で、単一レコード変数をコレクション変数に追加します。
また重複確認に使用するのでBoolean変数をFalseに戻しておきます。
コレクション変数に基づいて添付元レコードを更新
最終的に更新すべきレコードコレクション変数が空っぽでないかどうか、つまり前日に何も添付されなかったかどうかを確認します。
これをやらないと空でレコード更新するとエラーが出ます。
月曜日に出勤してきたらエラーのメールが来てると凹みますよね。
最後にコレクション変数を基にレコード更新して終わりです。
最後に
もっとクールな方法があるような気もしますが、
今の僕にできるのはこんな感じです。
特に、ループの中でレコードを取得しないで済む方法があればいいなと思ってるんですが、
どうしたらいいんでしょうね。