Skip to main content

Python client SDK for the MatrixOrigin MOI Platform

Project description

MOI Python SDK

Python client for the MatrixOrigin MOI Catalog Service, mirroring the feature set provided by the Go SDK (moi-go-sdk). It offers both a low-level RawClient (1:1 HTTP bindings) and a high-level SDKClient with productivity helpers for role/table workflows.

Installation

方式一:从 PyPI 安装(推荐)

如果包已发布到 PyPI,可以直接安装:

pip install moi-python-sdk

方式二:从 GitHub 直接安装

无需下载源码,直接从 GitHub 仓库安装:

pip install git+https://github.com/matrixorigin/moi-python-sdk.git

或者安装特定版本/分支:

# 安装特定分支
pip install git+https://github.com/matrixorigin/moi-python-sdk.git@main

# 安装特定标签版本
pip install git+https://github.com/matrixorigin/moi-python-sdk.git@v0.1.0

方式三:本地开发安装

如果需要修改源码或进行开发:

# 克隆仓库
git clone https://github.com/matrixorigin/moi-python-sdk.git
cd moi-python-sdk

# 安装依赖和包
pip install -r requirements.txt
pip install -e .  # 可编辑模式安装,修改代码后无需重新安装

Quick Start

from moi import RawClient, SDKClient, TablePrivInfo

raw = RawClient(
    base_url="https://api.example.com",
    api_key="your-api-key",
)

# Low-level call
catalog = raw.create_catalog({"name": "analytics", "description": "Prod catalog"})

# High-level helpers
sdk = SDKClient(raw)
role_id, created = sdk.create_table_role(
    role_name="analytics_reader",
    comment="Read-only access",
    table_privs=[
        TablePrivInfo(
            table_id=123,
            priv_codes=["DT8"],  # SELECT
        ),
    ],
)

Features

  • Full coverage of Catalog/Database/Table/Volume/File/Folder APIs
  • Detailed per-method references in docs/api_reference.md (EN) and docs/api_reference_zh.md (中文)
  • Connector workflows: local uploads, connector imports, preview
  • User/Role/Privilege management
  • GenAI, NL2SQL, Health, and Log endpoints
  • Streaming downloads via FileStream
  • High-level helpers for table role management and file-to-table import

Development

python -m venv .venv && source .venv/bin/activate
pip install -r requirements.txt

Code style follows standard pyproject-less tooling (feel free to add linters or tests). Contributions are welcome—please align new APIs with the Go SDK behavior to keep parity between implementations.

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

moi_python_sdk-0.1.0.dev0.tar.gz (41.4 kB view details)

Uploaded Source

Built Distribution

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

moi_python_sdk-0.1.0.dev0-py3-none-any.whl (29.5 kB view details)

Uploaded Python 3

File details

Details for the file moi_python_sdk-0.1.0.dev0.tar.gz.

File metadata

  • Download URL: moi_python_sdk-0.1.0.dev0.tar.gz
  • Upload date:
  • Size: 41.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.0

File hashes

Hashes for moi_python_sdk-0.1.0.dev0.tar.gz
Algorithm Hash digest
SHA256 8d3f580fbfca126ad747a581fc6cad271e118026cae0e4ab52bc796537a19fbb
MD5 f071663457dedc2cf80c1c6d8149360a
BLAKE2b-256 9c383d222b9b64eacdd9cd634bddbe40baccafe436e85481bd15b54c0333ab49

See more details on using hashes here.

File details

Details for the file moi_python_sdk-0.1.0.dev0-py3-none-any.whl.

File metadata

File hashes

Hashes for moi_python_sdk-0.1.0.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 c54d2b3ccbf4528d071947b32f4cac90115c660d36ee3ebaf3174570e325208e
MD5 2c19a36ad7a10da8f06d43a0430c7258
BLAKE2b-256 11788e33c7f010ba2a6fd6a8cae255e72c227cf6c664555ef697262e459605b8

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