Skip to main content

Asyncio grpclib SDK for afs_proxy/afslet

Project description

Python Async SDK (grpclib)

This SDK talks to afs_proxy / afslet using asyncio + grpclib. Generated protobuf modules are inside afs_sdk/api/....

Version

When imported from a git checkout, afs_sdk.__version__ is resolved from:

git describe --tags --long --always --dirty --match 'v*'

Example output:

>>> import afs_sdk
>>> afs_sdk.__version__
'v0.2.0-1-gabc1234-dirty'
>>> afs_sdk.get_version_info()
VersionInfo(version='v0.2.0-1-gabc1234-dirty', tag='v0.2.0', commit_sha='abc1234', distance=1, dirty=True)

When installed from a built distribution without .git metadata, it falls back to the package metadata version. PyPI release versions are derived from git tags via setuptools_scm.

Setup (uv)

cd python
~/.local/bin/uv sync

API

  • Low-level: AfsClient.raw_execute(requests: AsyncIterator[ExecuteRequest])
  • High-level: AfsClient.execute(request: ExecuteInput)
    • request is a single typed object (image, optional command, optional env, resources, and extra file entries)
    • env accepts either a dict[str, str] or a sequence of KEY=VALUE strings, and overrides image env on key conflict
    • set force_local_fetch=True to force local layer fetch on selected layerstore
    • response is AsyncIterator[ExecuteEvent]
  • Proxy status stream: AfsClient.status(include_layerstores=True, include_afslets=True)
    • returns AsyncIterator[ProxyStatusEvent]
  • Reconcile image replica: AfsClient.reconcile_image(request: ReconcileImageInput)
    • request: image/tag/platform/replica
    • response: ReconcileImageResult(image_key, current_replica, requested_replica, ensured)
  • Execute tar.gz output is parsed in streaming form into:
    • TarDirectory
    • TarSymlink
    • TarFilePart (chunked file data; no full-file buffering)
  • CPU-heavy tar.gz decode/untar is offloaded via executor:
    • pass tar_executor=... to AfsClient
    • default is an internal ThreadPoolExecutor(max_workers=1)

Extra file input types

ExtraFile.content supports:

  • bytes
  • AsyncIterator[bytes]

Example

import asyncio
from afs_sdk import AfsClient, ExecuteInput, ExtraFile

async def run():
    req = ExecuteInput(
        image="alpine",
        tag="latest",
        command=["/bin/sh", "-c", "echo ok >/tmp/ok.txt"],
        env={"FOO": "bar", "PATH": "/custom/bin"},
        cpu_cores=1,
        memory_mb=256,
        timeout_ms=2000,
        extra_entries=[
            ExtraFile(path="hello.txt", content=b"hello from sdk\n"),
        ],
    )

    async with AfsClient("127.0.0.1", 62051) as client:
        async for event in client.execute(req):
            print(type(event).__name__)

asyncio.run(run())

CLI-style demo:

PYTHONPATH=python ~/.local/bin/uv run python python/examples/execute_stream.py \
  --addr 127.0.0.1:62051 \
  --dir ./extra-dir \
  --env FOO=bar \
  --env PATH=/custom/bin \
  --image alpine --tag latest \
  -- /bin/sh -c 'echo ok >/tmp/ok.txt'

If command is omitted, AFS uses the image Entrypoint/Cmd defaults returned by discovery.

Reconcile image replica demo:

PYTHONPATH=python ~/.local/bin/uv run python python/examples/reconcile_image.py \
  --addr 127.0.0.1:62051 \
  --image alpine --tag latest --replica 0

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

afs_sdk-0.2.2.tar.gz (30.3 kB view details)

Uploaded Source

Built Distribution

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

afs_sdk-0.2.2-py3-none-any.whl (16.6 kB view details)

Uploaded Python 3

File details

Details for the file afs_sdk-0.2.2.tar.gz.

File metadata

  • Download URL: afs_sdk-0.2.2.tar.gz
  • Upload date:
  • Size: 30.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for afs_sdk-0.2.2.tar.gz
Algorithm Hash digest
SHA256 9edc1551e5182c28e3ca0eeb217784f5fe0aa96f47ef69130d8ad7a8a9b903f5
MD5 0af63d171c93d2fd50f6278e28d800ef
BLAKE2b-256 e6f9c576269e07629debc14de812d60aed7efca87edf975784f9d489db11f1c4

See more details on using hashes here.

Provenance

The following attestation bundles were made for afs_sdk-0.2.2.tar.gz:

Publisher: python-publish.yml on reyoung/afs

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

File details

Details for the file afs_sdk-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: afs_sdk-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 16.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for afs_sdk-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4ac5b2bc9cdadad086552ea17d409ba6884fb450104257a464cdebd392ba3cf4
MD5 e5d203a0e6bbd6b46f050f16010cd4e0
BLAKE2b-256 3f0259700e0b881bd98faa0740d29eba011b71587c46214d872582b2e9f8bcff

See more details on using hashes here.

Provenance

The following attestation bundles were made for afs_sdk-0.2.2-py3-none-any.whl:

Publisher: python-publish.yml on reyoung/afs

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