Skip to main content

Lepak: a lightweight and generic Alibaba Cloud OpenAPI client inspired by Boto3.

Project description

Lepak

Lepak is a lightweight, generic Alibaba Cloud OpenAPI client inspired by Boto3.

Chinese documentation: see README_CN.md.

Why Lepak

Compared with official Alibaba Cloud SDKs, Lepak focuses on low-friction integration:

  • One unified client for RPC-style services.
  • Plain dict request parameters instead of service-specific request classes.
  • Sync-first API with optional async support.

Installation

pip install lepak

Example 1: Basic Usage

import lepak

client = lepak.client(
    service_name="ecs",
    version="2014-05-26",
    access_key_id="your-ak",
    access_key_secret="your-sk",
    region_id="cn-hangzhou",
)

response = client.call(
    action="DescribeInstances",
    params={"PageSize": 10},
)

print(response)

Example 2: Official SDK Comparison

Lepak:

import lepak

client = lepak.client("ecs", "2014-05-26", "your-ak", "your-sk", "cn-hangzhou")
result = client.call("DescribeInstances", {"PageSize": 10})
print(result)

Official SDK (same action, more setup and product-specific models):

from alibabacloud_ecs20140526.client import Client as EcsClient
from alibabacloud_tea_openapi import models as open_api_models
from alibabacloud_ecs20140526 import models as ecs_models

config = open_api_models.Config(
    access_key_id="your-ak",
    access_key_secret="your-sk",
)
config.endpoint = "ecs.cn-hangzhou.aliyuncs.com"

client = EcsClient(config)
request = ecs_models.DescribeInstancesRequest(region_id="cn-hangzhou", page_size=10)
response = client.describe_instances(request)
print(response.body.to_map())

Example 3: Async Usage

import asyncio
import lepak

async def main():
    client = lepak.client(
        service_name="slb",
        version="2014-05-15",
        region_id="us-east-1",
    )
    result = await client.acall("DescribeLoadBalancers", {"PageSize": 2})
    print(result)

asyncio.run(main())

Example 4: RuntimeOptions Usage

import lepak
from alibabacloud_tea_util.models import RuntimeOptions

client = lepak.client("ecs", "2014-05-26", "your-ak", "your-sk", "cn-hangzhou")
runtime = RuntimeOptions(
    read_timeout=10000,
    connect_timeout=5000,
    autoretry=True,
    max_attempts=3,
)

result = client.call("DescribeInstances", {"PageSize": 5}, runtime=runtime)
print(result)

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

lepak-0.1.2.tar.gz (3.8 kB view details)

Uploaded Source

Built Distribution

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

lepak-0.1.2-py3-none-any.whl (3.9 kB view details)

Uploaded Python 3

File details

Details for the file lepak-0.1.2.tar.gz.

File metadata

  • Download URL: lepak-0.1.2.tar.gz
  • Upload date:
  • Size: 3.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for lepak-0.1.2.tar.gz
Algorithm Hash digest
SHA256 77d3524f7105eb510e98ff8c800785b39b66f1fad2beb5df6609855c04c14182
MD5 8702b2f490c9608b45c93df3652be324
BLAKE2b-256 7f78d536cc8d2cfe4d6631802593fc77934100a3272c28c328734aec71cfe249

See more details on using hashes here.

File details

Details for the file lepak-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: lepak-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 3.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for lepak-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 70e4f3f50620eb18c1ddd9ef423d2ad0ced82d5f988c9991e405614923ec3728
MD5 478c8597e2f8e5d60b3ec8a9b7838716
BLAKE2b-256 be51b1c9045a4779ba1069e6df7273122948df7f667b01b4659d1a23fdc1b5fb

See more details on using hashes here.

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