A Python client library for the Kroger Public API
Project description
🛒 Kroger Public API 🛍️ -- with Examples in Python 🐍
A comprehensive Python client library for the Kroger Public API, featuring robust token management, comprehensive examples, and easy-to-use interfaces for all available endpoints.
📺 Demo
Adding an item to your cart via an interactive Python script, and checking that it appears in your account:
https://github.com/user-attachments/assets/0079cbc7-5af0-473b-909a-d43508fe43d5
🚀 Quick Start
Installation
From PyPI (Recommended)
pip install kroger-api
From Source
git clone https://github.com/CupOfOwls/kroger-api.git
cd kroger-api
python3 -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
pip install -r requirements.txt
pip install -e .
Basic Usage
from kroger_api import KrogerAPI
from kroger_api.utils.env import load_and_validate_env, get_zip_code
# Env -- set in .env
load_and_validate_env(["KROGER_CLIENT_ID", "KROGER_CLIENT_SECRET"])
zip_code = get_zip_code(default="10001")
# Initialize the client
kroger = KrogerAPI()
# Get a client credentials token for public data
token_info = kroger.authorization.get_token_with_client_credentials("product.compact")
locations = kroger.location.search_locations(
zip_code=zip_code,
radius_in_miles=10,
limit=1
)
# Search for products
products = kroger.product.search_products(
term="milk",
location_id=locations["data"][0]["locationId"],
limit=5
)
print(f"Found {len(products['data'])} products!")
🔐 Getting Started with Credentials
1. Create a Kroger Developer Account
Visit the Kroger Developer Portal to:
- Create a developer account
- Register your application
- Get your
CLIENT_ID,CLIENT_SECRET, and set yourREDIRECT_URI
2. Set Up Environment Variables
Copy .env.example to .env and fill in your credentials:
# Kroger API Credentials
KROGER_CLIENT_ID=your_client_id_here
KROGER_CLIENT_SECRET=your_client_secret_here
KROGER_REDIRECT_URI=http://localhost:8000/callback
# Optional (Recommended): Your zip code for location-based searches
KROGER_USER_ZIP_CODE=90210
Important: Set your KROGER_REDIRECT_URI during app registration. While marked as optional in the form, the OAuth flow requires it.
3. First Run Authorization
The first time you run a script requiring user authentication, you'll be prompted to authorize your app through your web browser. You're granting permission to your own registered app, not to any third party.
🔄 Token Management
This library implements robust, automatic token management:
✨ Features
- Automatic token refresh - No manual token handling required
- Persistent storage - Tokens saved securely to avoid repeated logins
- Proactive validation - Tests tokens before use
- Reactive recovery - Automatically refreshes expired tokens during API calls
- PKCE Support - Enhanced OAuth security with Proof Key for Code Exchange
🔧 How it Works
Proactive Approach:
- Loads saved tokens and tests them with a lightweight API request
- Automatically refreshes if token is expired and refresh token is available
Reactive Approach:
- Makes API requests with current token
- On 401 Unauthorized errors, attempts token refresh
- Retries original request with new token
Token files (automatically managed, stored in project root):
.kroger_token_client_product.compact.json- Client credentials tokens.kroger_token_user.json- User authorization tokens
🔒 Enhanced Security with PKCE
This library supports PKCE (Proof Key for Code Exchange) for enhanced security in the OAuth flow:
from kroger_api import KrogerAPI
from kroger_api.utils import generate_pkce_parameters
# Generate PKCE parameters
pkce_params = generate_pkce_parameters()
# Initialize the client
kroger = KrogerAPI()
# Get authorization URL with PKCE
auth_url = kroger.authorization.get_authorization_url(
scope="cart.basic:write profile.compact",
state="random_state_value",
code_challenge=pkce_params['code_challenge'],
code_challenge_method=pkce_params['code_challenge_method']
)
# After user authorization and redirect, exchange code for token with verifier
token_info = kroger.authorization.get_token_with_authorization_code(
code="authorization_code_from_redirect",
code_verifier=pkce_params['code_verifier']
)
PKCE helps protect against authorization code interception attacks, particularly important for public clients or those using external tools to manage OAuth flows.
📚 Example Scripts
The examples/ directory contains comprehensive demonstrations:
| Script | Description | Authentication Required |
|---|---|---|
location_api_examples.py |
Search stores, get details about locations, chains, and departments | Client credentials |
product_api_examples.py |
Search products, get details, filter by various criteria | Client credentials |
cart_api_examples.py |
Add items to user's cart, full shopping workflow | User authorization |
identity_api_examples.py |
Get user profile information | User authorization |
oauth_flow.py |
Complete OAuth2 authorization code flow example | User authorization |
token_refresh_example.py |
Demonstrates automatic token refresh functionality | Both |
authorization_api_examples.py |
All authorization endpoints and flows | Both |
clear_tokens.py |
Utility to delete all saved token files | None |
🏃♂️ Running Examples
# Make sure your .env file is configured first!
# Public API examples (no user login required)
python examples/location_api_examples.py
python examples/product_api_examples.py
# User-specific examples (requires browser login)
python examples/cart_api_examples.py
python examples/identity_api_examples.py
python examples/oauth_flow.py
# Utility scripts
python examples/clear_tokens.py # Clear saved tokens
Here's a quick demo of browsing via the Product API with examples/product_api_examples.py:
🏪 Kroger Public API Information
API Versions & Rate Limits
| API | Version | Rate Limit | Notes |
|---|---|---|---|
| Authorization | 1.0.13 | No specific limit | Token management |
| Products | 1.2.4 | 10,000 calls/day | Search and product details |
| Locations | 1.2.2 | 1,600 calls/day per endpoint | Store locations and details |
| Cart | 1.2.3 | 5,000 calls/day | Add/manage cart items |
| Identity | 1.2.3 | 5,000 calls/day | User profile information |
Note: Rate limits are enforced per endpoint, not per operation. You can distribute calls across operations using the same endpoint as needed.
🔑 Available Scopes
When requesting user authorization, you can specify these scopes:
product.compact- Read product informationcart.basic:write- Add items to cartprofile.compact- Read user profile information
📖 API Documentation
For complete API documentation, visit:
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
📄 License
This project is licensed under the MIT License - see the LICENSE file for details.
⚠️ Disclaimer
This is an unofficial Python client for the Kroger Public API. It is not affiliated with, endorsed by, or sponsored by Kroger.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file kroger_api-0.2.0.tar.gz.
File metadata
- Download URL: kroger_api-0.2.0.tar.gz
- Upload date:
- Size: 2.0 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a6734c6768fe1a27b36052e120da45cef4788ac6246a2f621ab4e9f5513c0d57
|
|
| MD5 |
a6e997b8b8761fb215b7a3adea70747d
|
|
| BLAKE2b-256 |
1658f3ae148c033a4389285c4eb294e1762bab1c3ddca8f705f4220c5b047d5b
|
File details
Details for the file kroger_api-0.2.0-py3-none-any.whl.
File metadata
- Download URL: kroger_api-0.2.0-py3-none-any.whl
- Upload date:
- Size: 22.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
11c7ecb9c9b668f1b09213e23024b1161f75a99fde08176ce08d46e174662368
|
|
| MD5 |
4e4aac4458b93af6b083e202a06f8127
|
|
| BLAKE2b-256 |
ec1ea9f74deef55959cf478f754a3527399812d3f95d12ee0e17b4a83c4e521b
|