この記事は クラウドワークスアドベントカレンダー2019 14日目の記事です。
昨日は @ac_kimura による 「人事の思い出でも語ろうか。」 でした。
クラウドワークスでマネジメントをしてる @oura です。最近はほとんどコードを書いてないですが、まれに クラウドテック 1 というサービス のインフラを触ったりしてます。そしてエンジニアリングブログへの投稿も実に約3年ぶり、、ということでお手柔らかにお願いします!
本記事のタイトルはもはや何番煎じかわからないのですが、主にワークフローの使い方の詳細というよりも、試してみての考察や設定におけるポイントなどを中心に取り上げているため、エンジニアはもちろんですが、エンジニアでない方にも参考にしてもらえれると幸いです。 特に、この Slack のワークフローについて目にしたことはあるけど、どういったサービスか分からず手を付けてなかったという方や、はたまた Slack を使ってて業務改善に興味があるといった方には是非読み進めていただき、導入の判断に活かしてもらえればと思います! :)
Slack ワークフローの使いどころは?
まずは公式のアナウンス、 ワークフロービルダーが新登場 : Slack で簡単にタスクを合理化 の冒頭をのぞいてみましょう。
協力してプロジェクトを進めるには、リアルタイムで適切な担当者に適切な情報を届けることが欠かせません。にもかかわらず、申請を行ったり、進捗状況を尋ねたり、チームメンバーに関連情報を伝えたりといった手続きは手間のかかるものばかり。これがプロセス全体のボトルネックとなることもままあります。
ワークフローの解決したい課題は、 人と人とのコラボレーション部分
だということがわかります。
上記文中にもいくつか例がありますが、続いて ワークフローの例 を見てみますと、この一覧からも、何かをトリガーとして一気通貫で処理を完了させるといった類いのものではないことが見てとれます。
- 共有チャンネル横断のニーズを調整する (Coordinate needs across Shared Channels)
- 繰り返しの進捗共有をシンプルに (Simplify recurring progress updates)
- チームメンバーに感謝する (Make it easy to give team shoutouts)
- 新規チャンネルメンバーの自動オンボーディング (Automatically onboard new channel members)
- 適切なチームへの素早いリクエスト (Quickly field requests for your team)
- チームを超えた情報共有を簡単に (Make information sharing across teams easier)
- インシデントレポートをリアルタイムで収集 (Collect incident reports in real time)
※ 執筆時点(2019/12/8)で日本語訳されてないので筆者が勝手に訳してます。
ワークフローについて
改めてですが、 ワークフロー
について Wikipedia から引用します。
ワークフロー(英: workflow)は、リソース(資源)を体系的に組織化した反復可能な業務活動のパターンである。ワークフローは、物質の加工、サービスの提供、情報の処理など、何らかの具体的意図をもって設計される。ワークフローは、例えば、操作の列、個人またはグループの定まった作業、従業員の組織、複数の機械の機構などで表現しうる。2
このワークフローをナレッジマネジメントにおける SECI モデル に当てはめて考えると、 以下のような関係になると考えられます。
-
連結化(Combination)
: ワークフローの設計 -
内面化(Internalization)
: ワークフロービルダーでワークフローを構築し、実際に組織内で継続的に使われるようになるまで
組織運営をしていく中では、ここの内面化の難しさによく突き当たります。たとえ素晴らしいワークフローをつくっても、それが運用に根付かなかったり、根付いても時間の経過とともに廃れていったりします。みなさんも身に覚えがありませんでしょうか...? ;)
Slack のワークフローは、 Slack 上のコミュニケーションに自然と馴染むかたちで実行できるのがうれしいポイントですね。
Slack のワークフローを活用するには
Slack のワークフローを活用するには、何より、組織のメンバーがワークフローを使う文化を徐々に醸成していく必要がありそうです。というのも、ワークフローのトリガーとなるアクションメニューは通常使わなくても困るものでもないので、ワークフローを使う文化がないとそもそも存在さえ気づいてもらえなさそうだからです。
最初は情報共有の簡単なフォーマットなどを作成、展開して徐々に普及していったところで業務へも取り込んでいくというシナリオで進めてみましょう。
例えば、以下のようなシンプルな朝会用のフォーマットはどうでしょう?
アクションメニューが表示されるチャンネルやフォームの中身、フォームに入力した内容の出力先とフォーマットを設定するだけなので、ほとんど時間を要しません。この中で一番時間がかかるのは出力フォーマットの装飾でしょうか。
ワークフロー設計時に工夫・注意が必要になりそうなこと
以下に、筆者がワークフローを実際に試してみた中で、気づいた工夫や注意が必要なポイントを挙げてみました。実際に試されないと伝わりにくいところがありそうですので、実際に試された後にまた読み返してみるとよいかもしれません。
- 情報が流れていくため、証跡が必要な場合はSlack外のメディアに残すよう促しましょう。
- 複雑な Slack のワークフローは設計をドキュメントとして残しましょう。ドキュメントがないと全体像を掴むのが困難なケースが発生し得えます。またドキュメント化しておくことで、ふりかえりや見直しに活用できます。
- ワークフローの流れの途中、時間を要する処理がある場合はワークフローを2つにわけると良いでしょう。そして1つめのワークフロー内で、2つめのワークフローを実行する流れを伝えておきます。
- 条件文を組めないので、場合分けが発生するポイントでワークフローを一度終わりとし、その後どのワークフローを実行するのか実行者に委ねると良いでしょう。
最後に
このワークフロー機能、最初に触れた際は高機能な BotKit3 などのチャットBotと比較してしまい、機能が不十分では?という印象をもったのですが、コンセプトを読み込んだときにその活かし方をようやく理解できました。そして、テクノロジー的に目新しいところは正直なかったのですが、目の付けどころが素晴らしいなと改めて感じました。
筆者は今後、社内でこのドキュメントを全社に周知し、興味を持った方向けにワークショップを開催ししてこの興味深いソリューションを展開していければと目論んでいます。
また、この記事をご覧になったみなさんへ!どういう使われ方をされていくのか興味がありますので、事例ができましたら、是非教えてください。最後まで読んでいただきありがとうございました!
-
【PR】クラウドワークスの運用する、エンジニア、デザイナーさんを中心にお仕事を紹介するサービスです。ご興味ありましたらまずはご登録を! ↩
-
今年の頭あたりに Microsoft さんに買収されたニュースで驚きました。 ↩