A library that provides Bedrock models id
Project description
Bedrock Models
A Python library that provides AWS Bedrock Foundation Model IDs with autocomplete support and utility functions for cross-region inference.
This library helps developer to easily use Bedrock foundation models without having to lookup the model id or the correct cris profile prefix to use. The list of models is checked and updated daily.
[!NOTE] This package is part of the Bedrock Models Monorepo. A TypeScript/JavaScript version is also available in the
packages/typescriptdirectory.
🌐 Browse Models Online
Explore all available Bedrock models with our interactive web interface. Search by model name, filter by region, and find CRIS-enabled models.
Features
- Type-safe model IDs: Access all Bedrock model IDs as Python constants with full autocomplete support
- Cross-region inference: Automatically generate CRIS (Cross-Region Inference Service) prefixed model IDs
- Region validation: Check model availability across AWS regions
- Auto-updated: Model IDs are automatically updated weekly from AWS Bedrock API
Installation
pip install bedrock-models
Quick Start
The following code is portable across regions without any change
import boto3
from bedrock_models import Models, cris_model_id, global_model_id
client = boto3.client('bedrock-runtime')
# Get model ID with autocomplete
model = Models.ANTHROPIC_CLAUDE_HAIKU_4_5_20251001
# The correct geo profile id is determined from the boto3 default region
# regional geo profile is preferred, and falls back to global profile
client.converse(modelId=cris_model_id(model), messages=[...])
# To force a global profile, if available in the region, use global_model_id
client.converse(modelId=global_model_id(model), messages=[...])
# Qwen example
client.converse(modelId=Models.QWEN_QWEN3_32B.cris("ap-southeast-1"), messages=[...])
Usage
Basic Model IDs
from bedrock_models import Models
# Access model IDs with autocomplete
model_id = Models.ANTHROPIC_CLAUDE_SONNET_4_5_20250929
# Returns: "anthropic.claude-sonnet-4-5-20250929-v1:0"
model_id = Models.AMAZON_NOVA_PRO
# Returns: "amazon.nova-pro-v1:0"
Cross-Region Inference (CRIS)
from bedrock_models import Models, cris_model_id
# Get CRIS model ID (automatically chooses geo or global based on availability)
cris_id = cris_model_id(
Models.ANTHROPIC_CLAUDE_SONNET_4_5_20250929,
region="us-east-1"
)
# Returns: "us.anthropic.claude-sonnet-4-5-20250929-v1:0" (geo CRIS if INFERENCE_PROFILE available)
# Or: "global.anthropic.claude-sonnet-4-5-20250929-v1:0" (if only GLOBAL available)
# Different region prefix (AP regions use "apac")
cris_id = cris_model_id(
Models.AMAZON_NOVA_PRO,
region="ap-south-1"
)
# Returns: "apac.amazon.nova-pro-v1:0"
# Auto-detect region from boto3 (if installed and configured)
# AWS_DEFAULT_REGION=us-west-2
import boto3
cris_id = cris_model_id(
Models.AMAZON_NOVA_PRO # region auto-detected from boto3
)
# Returns: "us.amazon.nova-pro-v1:0"
Check Model Availability
from bedrock_models import Models, is_model_available, get_available_regions
# Check if a model is available in a specific region
available = is_model_available(Models.AMAZON_NOVA_PRO, "us-west-2")
# Returns: True or False
# Auto-detect region from boto3 (if installed and configured)
available = is_model_available(Models.AMAZON_NOVA_PRO)
# Uses region from boto3 session
# Get all regions where a model is available
regions = get_available_regions(Models.ANTHROPIC_CLAUDE_SONNET_4_5_20250929)
# Returns: ['us-east-1', 'us-west-2', 'ap-south-1', ...]
Inference Profiles
from bedrock_models import (
Models,
cris_model_id,
global_model_id,
has_global_profile,
)
# Get CRIS model ID (automatically chooses geo or global based on availability)
model_id = cris_model_id(Models.ANTHROPIC_CLAUDE_SONNET_4_5_20250929, region="us-east-1")
# Returns: "us.anthropic.claude-sonnet-4-5-20250929-v1:0" (geo CRIS)
# Or: "global.anthropic.claude-sonnet-4-5-20250929-v1:0" (if only global available)
# Get global inference profile ID (if supported in region)
global_id = global_model_id(Models.AMAZON_NOVA_PRO, region="us-east-1")
# Returns: "global.amazon.nova-pro-v1:0"
# Raises ValueError if global profile not supported in region
# Check if a model has a global inference profile in a region
has_global = has_global_profile(
Models.ANTHROPIC_CLAUDE_SONNET_4_5_20250929,
"us-east-1"
)
# Returns: True or False
Development
Setup
# Install Poetry
curl -sSL https://install.python-poetry.org | python3 -
# Install dependencies
poetry install
# Run tests
poetry run pytest
Regenerate Model IDs
To update the model IDs from AWS Bedrock:
# Set AWS credentials
export AWS_ACCESS_KEY_ID=your_key
export AWS_SECRET_ACCESS_KEY=your_secret
# Generate model data from AWS
python utils/generate_models_json.py
# Generate Python class
python utils/generate_model_class.py
# Run tests
poetry run pytest
Required IAM Permissions
The AWS credentials need the following least-privilege IAM policy:
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "BedrockReadOnly",
"Effect": "Allow",
"Action": [
"bedrock:ListFoundationModels",
"bedrock:ListInferenceProfiles"
],
"Resource": "*"
},
{
"Sid": "EC2DescribeRegions",
"Effect": "Allow",
"Action": [
"ec2:DescribeRegions"
],
"Resource": "*"
}
]
}
Credits
This project uses the following open-source libraries and data in the github pages site:
- Leaflet: An open-source JavaScript library for mobile-friendly interactive maps. Copyright (c) 2010-2023, Volodymyr Agafonkin.
- OpenStreetMap: Map data © OpenStreetMap contributors.
License
MIT-0
Author
Massimiliano Angelino massi.ang@gmail.com
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 bedrock_models-0.1.82.tar.gz.
File metadata
- Download URL: bedrock_models-0.1.82.tar.gz
- Upload date:
- Size: 16.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3b05725eef3429f9ebf587a40836959ad1d0c29b3ee971b9ad5b981091b26cb1
|
|
| MD5 |
05a1e432e75b29075baa721a7c170049
|
|
| BLAKE2b-256 |
2c6b154cc7127c77013d17622193fee24339fa31e335766dac2fa56fc82a8f05
|
Provenance
The following attestation bundles were made for bedrock_models-0.1.82.tar.gz:
Publisher:
release.yml on mirai73/bedrock-models
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
bedrock_models-0.1.82.tar.gz -
Subject digest:
3b05725eef3429f9ebf587a40836959ad1d0c29b3ee971b9ad5b981091b26cb1 - Sigstore transparency entry: 1438868794
- Sigstore integration time:
-
Permalink:
mirai73/bedrock-models@1fe903bb382245702fd5047c57096170a70b2901 -
Branch / Tag:
refs/tags/v0.1.82 - Owner: https://github.com/mirai73
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@1fe903bb382245702fd5047c57096170a70b2901 -
Trigger Event:
push
-
Statement type:
File details
Details for the file bedrock_models-0.1.82-py3-none-any.whl.
File metadata
- Download URL: bedrock_models-0.1.82-py3-none-any.whl
- Upload date:
- Size: 17.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f0688fa7d16417840b481681ef7e103ca4dc543bc260400da3382eddfa7e9ae2
|
|
| MD5 |
78c5497cafe51429c820eeec1e885925
|
|
| BLAKE2b-256 |
d64f7c4debb5a3da7d1bf1dea27d583905c4a55892ee51f99c0eb722cd23028d
|
Provenance
The following attestation bundles were made for bedrock_models-0.1.82-py3-none-any.whl:
Publisher:
release.yml on mirai73/bedrock-models
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
bedrock_models-0.1.82-py3-none-any.whl -
Subject digest:
f0688fa7d16417840b481681ef7e103ca4dc543bc260400da3382eddfa7e9ae2 - Sigstore transparency entry: 1438868823
- Sigstore integration time:
-
Permalink:
mirai73/bedrock-models@1fe903bb382245702fd5047c57096170a70b2901 -
Branch / Tag:
refs/tags/v0.1.82 - Owner: https://github.com/mirai73
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@1fe903bb382245702fd5047c57096170a70b2901 -
Trigger Event:
push
-
Statement type: