コンテンツにスキップ

ADK 向け Google Cloud Pub/Sub ツール

Supported in ADKPython v1.22.0

PubSubToolset を使うと、エージェントは Google Cloud Pub/Sub サービスと連携して、メッセージの publish、pull、acknowledge を行えます。

前提条件

PubSubToolset を使用する前に、次を満たしてください:

  1. Google Cloud プロジェクトで Pub/Sub API を有効化する。
  2. 認証と認可: エージェントを実行するプリンシパル (例: ユーザー、サービスアカウント) が Pub/Sub 操作に必要な IAM 権限を持っていること。Pub/Sub ロールの詳細は Pub/Sub アクセス制御ドキュメント を参照してください。
  3. トピックまたはサブスクリプションを作成する: メッセージ publish 用に トピックを作成 し、受信用に サブスクリプションを作成 します。

使用方法

# Copyright 2025 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import asyncio
import os

from google.adk.agents import Agent
from google.adk.runners import Runner
from google.adk.sessions import InMemorySessionService
from google.adk.tools.pubsub.config import PubSubToolConfig
from google.adk.tools.pubsub.pubsub_credentials import PubSubCredentialsConfig
from google.adk.tools.pubsub.pubsub_toolset import PubSubToolset
from google.genai import types
import google.auth

# Define constants for this example agent
AGENT_NAME = "pubsub_agent"
APP_NAME = "pubsub_app"
USER_ID = "user1234"
SESSION_ID = "1234"
GEMINI_MODEL = "gemini-2.0-flash"

# Define Pub/Sub tool config.
# You can optionally set the project_id here, or let the agent infer it from context/user input.
tool_config = PubSubToolConfig(project_id=os.getenv("GOOGLE_CLOUD_PROJECT"))

# Uses externally-managed Application Default Credentials (ADC) by default.
# This decouples authentication from the agent / tool lifecycle.
# https://cloud.google.com/docs/authentication/provide-credentials-adc
application_default_credentials, _ = google.auth.default()
credentials_config = PubSubCredentialsConfig(
    credentials=application_default_credentials
)

# Instantiate a Pub/Sub toolset
pubsub_toolset = PubSubToolset(
    credentials_config=credentials_config, pubsub_tool_config=tool_config
)

# Agent Definition
pubsub_agent = Agent(
    model=GEMINI_MODEL,
    name=AGENT_NAME,
    description=(
        "Agent to publish, pull, and acknowledge messages from Google Cloud"
        " Pub/Sub."
    ),
    instruction="""\
        You are a cloud engineer agent with access to Google Cloud Pub/Sub tools.
        You can publish messages to topics, pull messages from subscriptions, and acknowledge messages.
    """,
    tools=[pubsub_toolset],
)

# Session and Runner
session_service = InMemorySessionService()
session = asyncio.run(
    session_service.create_session(
        app_name=APP_NAME, user_id=USER_ID, session_id=SESSION_ID
    )
)
runner = Runner(
    agent=pubsub_agent, app_name=APP_NAME, session_service=session_service
)


# Agent Interaction
def call_agent(query):
    """
    Helper function to call the agent with a query.
    """
    content = types.Content(role="user", parts=[types.Part(text=query)])
    events = runner.run(user_id=USER_ID, session_id=SESSION_ID, new_message=content)

    print("USER:", query)
    for event in events:
        if event.is_final_response():
            final_response = event.content.parts[0].text
            print("AGENT:", final_response)


call_agent("publish 'Hello World' to 'my-topic'")
call_agent("pull messages from 'my-subscription'")

ツール

PubSubToolset には次のツールが含まれます:

publish_message

Pub/Sub トピックにメッセージを publish します。

Parameter Type Description
topic_name str Pub/Sub トピック名 (例: projects/my-project/topics/my-topic)。
message str publish するメッセージ本文。
attributes dict[str, str] (任意) メッセージに付与する属性。
ordering_key str (任意) メッセージの ordering key。これを設定するとメッセージは順序どおりに publish されます。

pull_messages

Pub/Sub サブスクリプションからメッセージを pull します。

Parameter Type Description
subscription_name str Pub/Sub サブスクリプション名 (例: projects/my-project/subscriptions/my-sub)。
max_messages int (任意) pull するメッセージの最大件数。デフォルトは 1
auto_ack bool (任意) メッセージを自動で acknowledge するか。デフォルトは False

acknowledge_messages

Pub/Sub サブスクリプション上の 1 件以上のメッセージを acknowledge します。

Parameter Type Description
subscription_name str Pub/Sub サブスクリプション名 (例: projects/my-project/subscriptions/my-sub)。
ack_ids list[str] acknowledge する acknowledgment ID の一覧。