Skip to content

google-agentic-commerce/AP2

Agent Payments Protocol (AP2)

Apache License Ask DeepWiki

Agent Payments Protocol Graphic

This repository contains code samples and demos of the Agent Payments Protocol.

Intro to AP2 Video

A2A Intro Video

About the Samples

These samples use Agent Development Kit (ADK) and Gemini 2.5 Flash.

The Agent Payments Protocol doesn't require the use of either. While these were used in the samples, you're free to use any tools you prefer to build your agents.

Navigating the Repository

The samples directory contains a collection of curated scenarios meant to demonstrate the key components of the Agent Payments Protocol.

The scenarios can be found in the samples/android/scenarios and samples/python/scenarios directories.

Each scenario contains:

  • a README.md file describing the scenario and instructions for running it.
  • a run.sh script to simplify the process of running the scenario locally.

This demonstration features various agents and servers, with most source code located in samples/python/src. Scenarios that use an Android app as the shopping assistant have their source code in samples/android.

Quickstart

Prerequisites

  • Python 3.10 or higher
  • uv package manager

Setup

You can authenticate using either a Google API Key or Vertex AI.

For either method, you can set the required credentials as environment variables in your shell or place them in a .env file at the root of your project.

Option 1: Google API Key (Recommended for development)

  1. Obtain a Google API key from Google AI Studio.

  2. Set the GOOGLE_API_KEY environment variable.

    • As an environment variable:

      export GOOGLE_API_KEY='your_key'
    • In a .env file:

      GOOGLE_API_KEY='your_key'

Option 2: Vertex AI (Recommended for production)

  1. Configure your environment to use Vertex AI.

    • As environment variables:

      export GOOGLE_GENAI_USE_VERTEXAI=true
      export GOOGLE_CLOUD_PROJECT='your-project-id'
      export GOOGLE_CLOUD_LOCATION='global' # or your preferred region
    • In a .env file:

      GOOGLE_GENAI_USE_VERTEXAI=true
      GOOGLE_CLOUD_PROJECT='your-project-id'
      GOOGLE_CLOUD_LOCATION='global'
  2. Authenticate your application.

    • Using the gcloud CLI:

      gcloud auth application-default login
    • Using a Service Account:

      export GOOGLE_APPLICATION_CREDENTIALS='/path/to/your/service-account-key.json'

How to Run a Scenario

To run a specific scenario, follow the instructions in its README.md. It will generally follow this pattern:

  1. Navigate to the root of the repository.

    cd AP2
  2. Run the run script to install dependencies & start the agents.

    bash samples/python/scenarios/your-scenario-name/run.sh
  3. Navigate to the Shopping Agent URL and begin engaging.

Installing the AP2 Types Package

The protocol's core objects are defined in the src/ap2/types directory. A PyPI package will be published at a later time. Until then, you can install the types package directly using this command:

uv pip install git+https://github.com/google-agentic-commerce/AP2.git@main