n8nのAIエージェント機能を用いて、Slack・GWSと連携する手順をまとめました。
普段コードなどに触れていない方向けに説明を記載しています。
ステップ①:Slackとn8nの連携
利用するツール
n8n:https://n8n.io/
Slack
GoogleWorkspace(個人も可)
上記の3つのツールを組み合わせ、エージェントを作成します。Googleとの連携は一瞬で終わりますが、初期設定のSlackとn8nの連携がやや大変に感じるかもしれません。ですので、手順をしっかりと案内しますね。
n8nのアカウントを開設する
n8nのページにアクセスしてアカウントを開設します。14日は無料トライアル(上限あり)で利用可能です。ローカルで動かす方法もありますが、難しいので興味のある方は調べてみていただけると。
最終的に完成するエージェントは以下のようになります。何よりも見た目がカッコイイ。
まずはSlackと連携する
最初のステップを追加からSlackを選択します。なんか物騒な日本語が映っているのはブラウザ翻訳を使っているからです(本当は全て英語)アクションを「Slackに新しいメッセージが投稿されたとき」にします。
設定画面が表示されています。
僕の場合はすでに連携済みですが、まずは認証設定を行いましょう。
すると以下のような画面が表示されます。
この時点で、抵抗感のある方はいるかもしれませんが大丈夫です、解説します。アクセストークンと呼ばれている「鍵」を入れてやる必要があります。
人で言うところの家の鍵みたいなものです。誰でも彼でもSlackに入ってこられたら困りますからね。n8nの場合には「ドキュメント」などのリンクが貼られているので、すぐに参照できます。
Slackのアプリページに移動してアプリを作成します。注意点は管理者でないとアプリが作成できないので、アラートが出た場合は管理者に相談するか自分個人で開設したSlackアカウントを使いましょう。
「ゼロから」を選びます。
アプリ名と接続するワークスペースを指定します。
Slackアプリの権限設定
左のメニューの「OAuthと権限」からSlackアプリケーションに対する権限を付与します。実際に付与した権限は下記の通りです。「アプリホーム」からアプリに名前とユーザー名を付けます。これをしないとSlackにアプリインストールができません。
OAuthと権限からアプリインストールを実施、許可ボタンを押します。
うまくいくとSlackのAppタブに該当のアプリが追加されます。
OAuthと認証に戻り、OAuthトークンをコピーします。機密情報なので、ネットへの公開や他人への共有はしないようにしましょう。
n8nに戻り、Slackとの連携フローのアクセストークンに先ほどのトークンをコピペして保存します。
その際に、SlackトリガーのWebhookURLをクリックしてコピーします。これのアドレスでSlack側からn8nにデータの受け渡しを行います。n8nはテストと本番でWebhookURLが異なりますが、まずはテストURLをコピーします。
Slackアプリに戻り、OAuthと権限のリダイレクトURLに先ほどコピーしたURLを添付します。
続けて「イベント・サブスクリプション」メニューのRequest URLに同じくコピーしたURLを追加。ボットイベントにアプリメンションやmessege:groupを追加します。※この画面だけは、翻訳画面で保存するとエラーになるため英語表記にしています。
最終的にはn8nで以下のようにSlackとの連携設定を実施します。対象となるチャンネルはID指定でも、リストから選ぶでもOKです。トリガーは「ボット/アプリの言及(メンション)」にしておきましょう
続けて「テストステップ」をクリックするとテストモードになります。Slack上から追加したアプリをメンションしましょう(チャンネルにアプリが参加していない場合は招待します)
例えば、以下のように入力すると
ちゃんと情報として反映されていますね。これでSlackとn8nの連携が完了しました。続けて、AIエージェントのベースを構築します。
AIエージェントの中枢を構築する
続けてSlackの次の項目に「フィードを編集」を追加します。Slackから飛んできたデータのうち、メッセージデータを部分のみを抽出します。画面左の入力の「文章」をドラッグして、右のtext項目にセットします。
続けて「AIエージェント」の項目をセットします。その上で、まずはモデルを設定します。今回は「OpenAIチャットモデル」を選択します。
以下のように利用するモデルを選択します。今回はOpenAIで選択していますが、geminiやClaudeなど利用しているモデルをセットしましょう。
連携にあたり、OpenAIのAPIキーが必要になります。公式サイトからログインしてAPIプラットフォームからAPIキーを発行します(こちらのページ)※発行に当たってはクレジットカードの登録が必要です。発行したAPIキーは先ほどのSlack認証と同じように、GPTの認証欄にセットします。
AIエージェント欄ではプロンプトを設定できます。プロンプトは後述するものを参考に構築していただければと思います。
ツール(道具)から連携対象のアプリケーションを選択します。今回はGoogleカレンダーとタスクです。認証はGoogleアカウントにログインするだけですので省略しますが、クリックするだけで完了します。
Googleカレンダーの連携項目は下記のように設定しています。カレンダーは自分のカレンダーを指定、その上で日付は「モデルによって自動的に定義される」=生成AIで判断するようにしています。
最後にアウトプット先のSlackを設定します。認証は先ほど完了しているので、アウトプットを設定していきましょう。
アウトプットでは、生成AIから帰ってきた回答データをドラッグして、「メッセージテキスト」に配置します。その際に、Slackのスレッドtsをタイムスタンプとして指定しておくとスレッドにちゃんと返信してくれるようになります。