はじめに
みなさん、こんにちは。俊介です。
今回はAzure OpenAIをAPIを使ってWorkato経由で操作できるようカスタムコネクターをWorkato上で作成しました。
これを実装することで今までWorkatoで作成した業務のプロセスに生成AIを組み込む事ができ、さらなる業務の効率化が広がります。
簡単な例で言うと、SlackとAzure OpenAIを繋げることがで、本家ChatGPTのウェブアプリを開かなくてもSlackで生成AIに質問を投げれるようになります。
前提として
Azure OpenAI Serviceはセットアップ済みであること
Workato Connector SDKで実際に作成していく
Workato Connector SDKとは
Workatoで標準で用意していないConnectionを自身で作成することが出来ます。(Rubyで書いていくことになります。)
全体のブロック構成
それぞれのブロックの内容は後続で紹介します。
{ title: "カスタムコネクターの名前", connection: {"APIとの接続の確立に関わる情報を定義"}, test: "connectionキーと連携し、接続が正常に確立されたことを確認", object_definitions: {"入力項目や出力項目を定義。項目は、アクションやトリガーにおいて参照可"}, actions: {"コネクターに含まれるすべてのアクションの定義"} }
connectionブロック
connection: { fields: [ { name: "api_key", hint: "Azure OpenAIで作成したAPIキーを設定してください", label: "Api key" }, { name: "deployment_id", hint: "deployment-idか、engineを指定してください", }, { name: "openai_api_base", hint: "Azure OpenAI名を設定してください" } ], authorization: { type: "custom_auth", apply: lambda do |connection| headers("api-key": "#{connection["api_key"]}") end }, base_uri: lambda do |connection| "https://#{connection["openai_api_base"]}/openai/" end }
Azure OpenAI APIの認証方法は2つあります。
- API キー認証:api-key HTTP ヘッダーに API キーを含めてリクエストを投げる
- Azure Active Directory 認証(OAuth認証):ユーザーの資格情報を使用してリクエストを投げる
今回はAPIキーでの認証を採用しました。
▼Workato DebugのConnection画面
data:image/s3,"s3://crabby-images/1757d/1757de3e487e3c7c3c718edb05929eca8b842fe9" alt=""
▼Connectionに項目を埋める為のAzure AD側の設定確認画面
data:image/s3,"s3://crabby-images/edf03/edf032290c79795d334dad90249aaccda91be95c" alt=""
testブロック
test: lambda do |connection| post("deployments/#{connection["deployment_id"]}/chat/completions?api-version=2023-05-15"). payload( {messages:[{role: "system", content: "You are a helpful assistant."}]} ) end
▼testブロックまで書いたら認証が通るか「Connect」した結果
data:image/s3,"s3://crabby-images/22fdf/22fdfbec3b55f075e4dc7df25e3ace669a8269c5" alt=""
object_definitionsブロック
object_definitions: { ## Azure OpenAIのチャットをAPI経由で行うためのinput_fieldsを定義 create_chat_completion_input_fields: { fields: lambda do |_connection, object_definitions| [ { name: "messages", type: "array", of: "object", hint: "An array of messages to generate chat completions for", properties: [ { name: "role", default: "user", optional: false, hint: "either 'system', 'user', or 'assistant'" }, { name: "content", optional: false, hint: "The message to generate a chat completion for" } ] } ] end }, ## Azure OpenAIのチャットをAPI経由で行うためのoutput_fieldsを定義 create_chat_completion_output_fields: { fields: lambda do |_connection, object_definitions| [ { control_type: "text", label: "ID", type: "string", name: "id" }, { control_type: "text", label: "Object", type: "string", name: "object" }, { control_type: "number", label: "Created", parse_output: "float_conversion", type: "number", name: "created" }, { control_type: "text", label: "Model", type: "string", name: "model" }, { name: "choices", type: "array", of: "object", label: "Choices", properties: [ { control_type: "number", label: "Index", parse_output: "float_conversion", type: "number", name: "index" }, { control_type: "text", label: "Finish reason", type: "string", name: "finish_reason" }, { properties: [ { control_type: "text", label: "Role", type: "string", name: "role" }, { control_type: "text", label: "Content", type: "string", name: "content" } ], label: "Message", type: "object", name: "message" } ] }, { properties: [ { control_type: "number", label: "Completion tokens", parse_output: "float_conversion", type: "number", name: "completion_tokens" }, { control_type: "number", label: "Prompt tokens", parse_output: "float_conversion", type: "number", name: "prompt_tokens" }, { control_type: "number", label: "Total tokens", parse_output: "float_conversion", type: "number", name: "total_tokens" } ], label: "Usage", type: "object", name: "usage" } ] end } }
actionsブロック
actions: { ## Azure OpenAIのチャットをAPI経由で行うためのaction chat: { title: "Azure OpenAIにテキストを投げる", description: "ChatGPT および GPT-4 モデルを使用してチャット メッセージの補完を作成します。", input_fields: lambda do |object_definitions| object_definitions["create_chat_completion_input_fields"] end, execute: lambda do |connection, input| post("deployments/#{connection["deployment_id"]}/chat/completions?api-version=2023-05-15", input) end, output_fields: lambda do |object_definitions| object_definitions["create_chat_completion_output_fields"] end } }
▼Workato DebugのActions画面
data:image/s3,"s3://crabby-images/05a51/05a511f53c2a3dca9215306a283bdc10e2c83b59" alt=""
▼実際にDebugからテスト実行する時の画面
data:image/s3,"s3://crabby-images/72923/729239018f1dca667c8747c274c75c8c57d74d24" alt=""
▼テスト実行後のConsle画面に結果が返ってくる
data:image/s3,"s3://crabby-images/5deab/5deabd2ba89ddbd94b8221d60ac40ebe08d2eab7" alt=""
実際に使ってみた
作成したカスタムコネクターを実際にレシピに利用してみたいと思います。
流れは簡単です。
- SlackでApp Botをメンションして質問を投げます
- Workatoが発火し、フローが開始します
- Azure OpenAIにリクエストを投げます
- 返ってきたレスポンス結果をSlackに投稿させます
data:image/s3,"s3://crabby-images/2944c/2944c7b61cb3c119b7b51fd5e7ade66f0b17d34e" alt=""
例1
data:image/s3,"s3://crabby-images/200b8/200b8101c50d99424f24316fbeab5a526fc36307" alt=""
例2
data:image/s3,"s3://crabby-images/2b148/2b148da45b8916a6029d9e24e84091e7bd8f9b49" alt=""
おわりに
今回はWorkatoでもAzure OpenAIの操作を出来るようにカスタムコネクターを作成しました。
カスタムコネクターを作っておけば、Slackだけでなく、他アプリとの連携も簡単になるので、いろんな自動化にも組み込みやすくなると思います!
次のブログからは今回のカスタムコネクターを利用して、色々なSaaSと連携させてAzure OpenAIを活用した事例を紹介していきます。