Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Refactor]: Unary client #16

Merged
merged 3 commits into from
Feb 18, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
51 changes: 50 additions & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,56 @@ jobs:
files: ./coverage.xml
fail_ci_if_error: true
verbose: true


mock:
name: Test Mock Sample Validation
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
path: py-xline

- name: Checkout mock xline
uses: actions/checkout@v4
with:
repository: xline-kv/mock-xline
path: mock-xline

- name: Setup Python
uses: actions/setup-python@v4
with:
python-version: '3.10'

- name: Install Pip
run: sudo apt install pip

- name: Setup Go
uses: actions/setup-go@v4
with:
go-version: 1.21

- name: Generate API
run: |
cd py-xline
python3 -m pip install grpcio grpcio-tools
git submodule init
git submodule update
make

- name: Install Hatch
run: pip install hatch==1.7.0

- name: Start the cluster
run: |
cd mock-xline
./scripts/quick_start.sh

- name: Run tests
run: |
cd py-xline
hatch run test ./src/curp/ -v

commit:
name: Commit Message Validation
runs-on: ubuntu-latest
Expand Down
98 changes: 98 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,2 +1,100 @@
# py-xline

[![Apache 2.0 licensed][apache-badge]][apache-url]
[![codecov][cov-badge]][cov-url]

[apache-badge]: https://img.shields.io/badge/license-Apache--2.0-brightgreen
[apache-url]: https://github.com/datenlord/Xline/blob/master/LICENSE
[cov-badge]: https://codecov.io/gh/xline-kv/xline/branch/master/graph/badge.svg
[cov-url]: https://codecov.io/gh/xline-kv/go-xline

py-xline is an official xline client sdk, written in Python.

## Features

`py-xline` runs the CURP protocol on the client side for maximal performance.

## Supported APIs

- KV
- [x] Put
- [x] Range
- [x] Delete
- [x] Txn
- [x] Compact
- Auth
- [x] AuthEnable
- [x] AuthDisable
- [x] AuthStatus
- [x] Authenticate
- [x] UserAdd
- [x] UserAddWithOptions
- [x] UserGet
- [x] UserList
- [x] UserDelete
- [x] UserChangePassword
- [x] UserGrantRole
- [x] UserRevokeRole
- [x] RoleAdd
- [x] RoleGet
- [x] RoleList
- [x] RoleGrantPermission
- [x] RoleRevokePermission
- Lease
- [x] Grant
- [x] Revoke
- [x] KeepAlive
- [x] KeepAliveOnce
- [x] TimeToLive
- [x] Leases
- Watch
- [x] Watch
- Lock
- [x] Lock
- [x] Unlock
- Cluster
- [ ] MemberAdd
- [ ] MemberAddAsLearner
- [ ] MemberRemove
- [ ] MemberUpdate
- [ ] MemberList
- [ ] MemberPromote
- Maintenance
- [ ] Alarm
- [ ] Status
- [ ] Defragment
- [ ] Hash
- [x] Snapshot
- [ ] MoveLeader

## Installation

``` bash
pip install py-xline
```

## Quickstart

``` python
from py_xline import client

async def main():
curp_members = ["172.20.0.3:2379", "172.20.0.4:2379", "172.20.0.5:2379"]
cli = await client.Client.connect(curp_members)
kv_client = cli.kv_client

await kv_client.put(b"key", b"value")

res = await kv_client.range(b"key")

kv = res.kvs[0]
print(kv.key.decode(), kv.value.decode())
```

## Compatibility

We aim to maintain compatibility with each corresponding Xline version, and update this library with each new Xline release.

| py-xline | Xline |
| --- | --- |
| v0.1.0 | v0.6.1 |
2 changes: 1 addition & 1 deletion client/__about__.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,4 +4,4 @@

"""Xline clients"""

__version__ = "0.0.1"
__version__ = "0.1.0"
68 changes: 23 additions & 45 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,7 @@ readme = "README.md"
requires-python = ">=3.7"
license = "Apache-2.0"
keywords = []
authors = [
{ name = "LingKa", email = "[email protected]" },
]
authors = [{ name = "LingKa", email = "[email protected]" }]
classifiers = [
"Development Status :: 4 - Beta",
"Programming Language :: Python",
Expand All @@ -27,6 +25,7 @@ classifiers = [
dependencies = [
"grpcio==1.58.0",
"grpcio-tools==1.58.0",
"grpcio-status==1.58.0",
"pytest-asyncio",
"passlib",
]
Expand All @@ -40,47 +39,24 @@ Source = "https://github.com/xline-kv/py-xline"
path = "client/__about__.py"

[tool.hatch.envs.default]
dependencies = [
"coverage[toml]>=6.5",
"pytest",
]
dependencies = ["coverage[toml]>=6.5", "pytest"]
[tool.hatch.envs.default.scripts]
test = "pytest {args:tests}"
test-cov = "coverage run -m pytest {args:tests}"
cov-report = [
"- coverage combine",
"coverage report",
"coverage xml",
]
cov = [
"test-cov",
"cov-report",
]
cov-report = ["- coverage combine", "coverage report", "coverage xml"]
cov = ["test-cov", "cov-report"]

[[tool.hatch.envs.all.matrix]]
python = ["3.7", "3.8", "3.9", "3.10", "3.11"]

[tool.hatch.envs.lint]
detached = true
dependencies = [
"black>=23.1.0",
"mypy>=1.0.0",
"ruff>=0.0.243",
]
dependencies = ["black>=23.1.0", "mypy>=1.0.0", "ruff>=0.0.243"]
[tool.hatch.envs.lint.scripts]
typing = "mypy --install-types --non-interactive {args:client tests}"
style = [
"ruff {args:.}",
"black --check --diff {args:.}",
]
fmt = [
"black {args:.}",
"ruff --fix {args:.}",
"style",
]
all = [
"style",
]
style = ["ruff {args:.}", "black --check --diff {args:.}"]
fmt = ["black {args:.}", "ruff --fix {args:.}", "style"]
all = ["style"]

[tool.black]
target-version = ["py37"]
Expand Down Expand Up @@ -121,13 +97,21 @@ ignore = [
# Allow non-abstract empty methods in abstract base classes
"B027",
# Allow boolean positional values in function calls, like `dict.get(... True)`
"FBT001", "FBT002", "FBT003",
"FBT001",
"FBT002",
"FBT003",
# Ignore checks for possible passwords
"S105", "S106", "S107",
"S105",
"S106",
"S107",
# Ignore complexity
"C901", "PLR0911", "PLR0912", "PLR0913", "PLR0915",
"C901",
"PLR0911",
"PLR0912",
"PLR0913",
"PLR0915",
# Ignore import sort
"I001",
"I001",
# Allow verable shadow
"A003",
# Allow const use upercase
Expand All @@ -154,20 +138,14 @@ ban-relative-imports = "all"
source_pkgs = ["client", "tests"]
branch = true
parallel = true
omit = [
"client/__about__.py",
]
omit = ["client/__about__.py"]

[tool.coverage.paths]
py_xline = ["client"]
tests = ["tests"]

[tool.coverage.report]
exclude_lines = [
"no cov",
"if __name__ == .__main__.:",
"if TYPE_CHECKING:",
]
exclude_lines = ["no cov", "if __name__ == .__main__.:", "if TYPE_CHECKING:"]

[tool.hatch.build.targets.wheel]
packages = ["client"]
Empty file added src/__init__.py
Empty file.
5 changes: 5 additions & 0 deletions src/curp/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import sys

sys.path.append("./api/curp")

sys.path.append("./api/xline")
Loading
Loading