Skip to main content

A Tabular Helper API library that wraps common AWS services (DynamoDB, S3, SSM) with a typed, consistent interface built on boto3.

Project description

tha-aws-runner

CI

A Tabular Helper API library that wraps common AWS services (DynamoDB, S3, SSM) with a typed, consistent interface built on boto3.

Install

pip install tha-aws-runner

Quick start

from tha_aws_runner import ThaDdb, ThaS3, ThaSSM

# DynamoDB — batch fetch by partition key
ddb = ThaDdb(region="us-east-1")
records = ddb.fetch_by_pk("my_table", ["pk1", "pk2"], key_name="id", key_type="S")
# {"pk1": {"name": "Alice"}, "pk2": {"not_found": True}}

# DynamoDB — update a single attribute
result = ddb.update_by_pk("my_table", "pk1", "id", "S", "status", "S", "active")
# {"pk": "pk1", "status": "updated", "old": {...}}

# S3 — upload bytes or a local file (bucket+key or S3 URI)
s3 = ThaS3(region="us-east-1")
s3.upload_file("my-bucket", "data/file.csv", data=b"col1,col2\n1,2")
s3.upload_file("my-bucket", "data/file.csv", local_path="/tmp/file.csv")
s3.upload_file(uri="s3://my-bucket/data/file.csv", data=b"col1,col2\n1,2")

# S3 — download to memory or a local file (bucket+key or S3 URI)
result = s3.download_file("my-bucket", "data/file.csv")
# {"bucket": "my-bucket", "key": "data/file.csv", "status": "downloaded", "bytes": 13, "data": b"..."}
s3.download_file("my-bucket", "data/file.csv", local_path="/tmp/out.csv")
s3.download_file(uri="s3://my-bucket/data/file.csv", local_path="/tmp/out.csv")

# SSM — read a parameter
ssm = ThaSSM(region="us-east-1")
value = ssm.read_param("/my/app/secret", with_decryption=True)

API

ThaDdb

ThaDdb(*, status_cb=None, mode="app", region=None, profile=None)
Method Description
fetch_by_pk(table_name, partition_keys, *, fields=None, key_name=None, key_type=None, dynamodb=None) Batch-fetch items by partition key. Returns {table_name: {pk: record}} — a Python dict nested by table name then pk. Missing keys get {"not_found": True}.
update_by_pk(table_name, partition_key, key_name, key_type, update_attr, update_type, update_value, *, increment_attr=None, dynamodb=None) Update a single attribute with conditional check. Returns {"pk", "status", ...} where status is updated, skipped, or error.
batch_put(table_name, items, key_name, *, dynamodb=None) Write up to N items in 25-item chunks with retry. Returns {"written": N}.
delete_by_pk(table_name, partition_key, key_name, key_type, *, dynamodb=None) Delete one item with existence check. Returns {"pk", "status"}.

GSI (Global Secondary Index) support for ThaDdb is planned for a future version.

ThaS3

ThaS3(*, status_cb=None, mode="app", region=None, profile=None)
Method Description
upload_file(bucket=None, key=None, *, uri=None, local_path=None, data=None, encoding="utf-8", s3=None) Upload a local file, raw bytes, or a string to S3. Provide uri or both bucket+key. Provide exactly one of local_path or data. Strings are encoded using encoding. Returns {"bucket", "key", "status", "bytes"}.
download_file(bucket=None, key=None, *, uri=None, local_path=None, encoding=None, s3=None) Download an S3 object. Provide uri or both bucket+key. Without local_path, returns data in result["data"] as str (if encoding set) or bytes. With local_path, writes raw bytes to disk. Returns {"bucket", "key", "status", "bytes"}.

ThaSSM

ThaSSM(*, status_cb=None, mode="app", region=None, profile=None)
Method Description
read_param(path, *, with_decryption=False, ssm=None) Fetch a single SSM parameter value as a string.

All methods set self.rows to their return value.

mode="cli" enables tqdm progress bars. mode="app" calls status_cb(message) instead.

Helpers

from tha_aws_runner import AWSClients, current_identity, parse_assumed_role_arn, cli_auth_check

# Get all boto3 clients from one session
clients = AWSClients(region="us-east-1", profile="my-profile")
s3 = clients.s3()

# Check the current AWS identity
identity, account_id, role_name, session_name = current_identity(region="us-east-1")

# Guard a script to the expected account/role
if not cli_auth_check(account_id, role_name, "123456789012", "my_role"):
    raise SystemExit("Wrong AWS identity")

Alternatives

  • boto3 — the official AWS SDK; tha-aws-runner is a thin typed convenience layer on top of it
  • aioboto3 — async boto3 wrapper for async applications
  • pynamodb — ORM-style DynamoDB wrapper with model definitions
  • aws-lambda-powertools — utilities for Lambda functions including SSM parameter caching

tha-aws-runner is intentionally narrow: no ORM, no async, no Lambda-specific features — just a thin typed wrapper for the most common DynamoDB, S3, and SSM call patterns.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tha_aws_runner-0.1.1.tar.gz (80.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tha_aws_runner-0.1.1-py3-none-any.whl (11.1 kB view details)

Uploaded Python 3

File details

Details for the file tha_aws_runner-0.1.1.tar.gz.

File metadata

  • Download URL: tha_aws_runner-0.1.1.tar.gz
  • Upload date:
  • Size: 80.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tha_aws_runner-0.1.1.tar.gz
Algorithm Hash digest
SHA256 11a4ef6a99510b1a31c96a77909fbd081b9033086f812a27b8c4f76caa90a618
MD5 59b55bfd1f9b3b25bf97624ac360c305
BLAKE2b-256 fa03ab218d35e5360690597a9bc56c8bc524630a4a6a4bc283e19490f27a135a

See more details on using hashes here.

Provenance

The following attestation bundles were made for tha_aws_runner-0.1.1.tar.gz:

Publisher: publish.yml on tha-guy-nate/tha-aws-runner

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tha_aws_runner-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: tha_aws_runner-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 11.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tha_aws_runner-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2dc7923b17310181c6b72f30fac284950ecbbdabf99fa9528f7ac5e66c44fce5
MD5 974ecac40c423950c9255d01ca9fa9ae
BLAKE2b-256 9b229913083f30d7a77e473cbc35ccb54d0d63ed617c85fe63ce932e5f6ac65d

See more details on using hashes here.

Provenance

The following attestation bundles were made for tha_aws_runner-0.1.1-py3-none-any.whl:

Publisher: publish.yml on tha-guy-nate/tha-aws-runner

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page