Python client for Symfonia WebAPI (sync + threading).
Project description
SymfWebAPI
Pythonowa biblioteka kliencka do Symfonia WebAPI w architekturze sync-first: z typowanymi modelami, wygenerowanymi kontrolerami, wsparciem dla threading i opcjonalnym trybem JSON-only.
Instalacja
pip install SymfWebAPI
Szybki start
from SymfWebAPI import ClientConfig, WebAPI, build_sync_client
config = ClientConfig(
domain="host:9000",
application_key="00000000-0000-0000-0000-000000000000",
device_name="integration-client",
)
with build_sync_client(config) as api:
resp = WebAPI.Interface.Products.Interfaces.IProductsController.Get(
api,
salePrices=False,
)
products = resp.unwrap()
print(len(products))
Tryb JSON-only
Biblioteka wspiera oficjalny tryb pracy bez mapowania do modeli Pydantic.
Masz dwie ścieżki:
- niskopoziomową:
api.request_json(...)alboenvelope.json(), - wygenerowane metody kontrolerów z flagą
validate=False.
To jest przydatne, gdy:
- integrujesz się z niestabilnymi lub nieidealnymi danymi produkcyjnymi,
- chcesz szybko zdiagnozować payload z WebAPI,
- robisz migracje i chcesz odczytać tylko kilka pól bez kosztu walidacji Pydantic,
- benchmarkujesz lub przetwarzasz duże listy rekordów.
Przy validate=False wygenerowane metody nadal zachowują podpowiedzi IDE dla kształtu JSON przez stuby .pyi.
Tryb validate=False działa spójnie po obu stronach:
- response side: omija walidację odpowiedzi i zwraca surowy JSON,
- request side: dla endpointów z body pozwala wysłać surowy
dict/list/ JSON-serializable payload bez modelu Pydantic.
Przy validate=True endpointy z modelowym body nadal oczekują modelu Pydantic.
Najwygodniejsza ścieżka w aktualnej bibliotece to wywołanie wygenerowanej metody kontrolera z validate=False.
Przykład z wygenerowaną metodą kontrolera:
from SymfWebAPI import ClientConfig, WebAPI, build_sync_client
config = ClientConfig(
domain="host:9000",
application_key="00000000-0000-0000-0000-000000000000",
device_name="json-only-client",
)
with build_sync_client(config) as api:
resp = WebAPI.Interface.Products.Interfaces.IProductsController.GetPagedDocument(
api,
page=1,
size=10,
orderBy=WebAPI.Interface.Enums.enumOrderByType.Asc,
validate=False,
)
page = resp.unwrap()
print(page["Data"][0]["Code"])
Przykład niskopoziomowy:
with build_sync_client(config) as api:
products = api.request_json(
"GET",
"/api/Products",
params={"salePrices": False},
)
print(len(products))
Przykład write-pathu bez Pydantic:
with build_sync_client(config) as api:
created = WebAPI.Interface.Products.Interfaces.IProductsController.AddNew(
api,
product={
"Code": "P-RAW-001",
"Name": "Produkt z raw JSON",
"Active": True,
},
validate=False,
).unwrap()
print(created["Code"])
Przykład gotowego skryptu:
examples/get_products_json_only.pyexamples/add_product_json_only.py(zabezpieczony przed przypadkowym write)
Dokumentacja
- Omówienie biblioteki:
docs/overview.md - Przykłady:
examples/
Benchmark bez sekretów
Przykład benchmarku znajduje się w:
examples/benchmark_order_details.py
Przykład pracy bez modeli Pydantic:
examples/get_products_json_only.pyexamples/add_product_json_only.py(write-pathvalidate=False, domyślnie zablokowany)
Konfiguracja przez zmienne środowiskowe:
SYMFWEBAPI_DOMAINSYMFWEBAPI_APP_KEYSYMFWEBAPI_DEVICE_NAME(opcjonalnie)SYMFWEBAPI_HTTPS(opcjonalnie, np.true/false)SYMFWEBAPI_SANITIZE_NUL(opcjonalnie, usuwaNUL/\u0000z odpowiedzi)SYMFWEBAPI_BENCHMARK_PHYSICAL_CORES(opcjonalnie, ręcznie ustawia liczbę fizycznych rdzeni dla benchmarku)
Benchmark działa w trybach:
syncsync-rawthreadingthreading-raw
Przy braku --thread-workers-list skrypt automatycznie dorzuca test dla liczby fizycznych rdzeni i liczby logicznych wątków, jeśli da się je rozróżnić.
Wersjonowanie
Wersja paczki ma format X.I.WM.Wm, np. 2.0.26.10:
X- major SDK,I- iteracja SDK dla tej samej wersji WebAPI.WM.Wm- docelowa wersja Symfonia WebAPI.
Licencja
BSD-3-Clause.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file symfwebapi-2.0.26.20.tar.gz.
File metadata
- Download URL: symfwebapi-2.0.26.20.tar.gz
- Upload date:
- Size: 249.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1f4eeee8f72845054cf8ce20c6912079f3cea74b6717bfa8c17b9c074b6bdcdf
|
|
| MD5 |
73892ef35e488e2998ea21f1dce906b0
|
|
| BLAKE2b-256 |
cf6ee05e8ee8e963a2ccb4a22bf16c237540368bde1ecd58252c89c58e8c5c5d
|
Provenance
The following attestation bundles were made for symfwebapi-2.0.26.20.tar.gz:
Publisher:
public-ci-release.yml on maku2903/symf-webapi-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
symfwebapi-2.0.26.20.tar.gz -
Subject digest:
1f4eeee8f72845054cf8ce20c6912079f3cea74b6717bfa8c17b9c074b6bdcdf - Sigstore transparency entry: 1203787274
- Sigstore integration time:
-
Permalink:
maku2903/symf-webapi-py@5c4210256332d008667d5a2809a1031e783169b0 -
Branch / Tag:
refs/tags/v2.0.26.20 - Owner: https://github.com/maku2903
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
public-ci-release.yml@5c4210256332d008667d5a2809a1031e783169b0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file symfwebapi-2.0.26.20-py3-none-any.whl.
File metadata
- Download URL: symfwebapi-2.0.26.20-py3-none-any.whl
- Upload date:
- Size: 502.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1780723720da7b60680dd113b9a8110708f31cd702ddd2a1917594619f25c21b
|
|
| MD5 |
f9a7000e4c043e00e76be3ca151b0486
|
|
| BLAKE2b-256 |
7c706f134f1b3c849f8eda9790b369c1868589ab070a597871ea33551fa9919f
|
Provenance
The following attestation bundles were made for symfwebapi-2.0.26.20-py3-none-any.whl:
Publisher:
public-ci-release.yml on maku2903/symf-webapi-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
symfwebapi-2.0.26.20-py3-none-any.whl -
Subject digest:
1780723720da7b60680dd113b9a8110708f31cd702ddd2a1917594619f25c21b - Sigstore transparency entry: 1203787298
- Sigstore integration time:
-
Permalink:
maku2903/symf-webapi-py@5c4210256332d008667d5a2809a1031e783169b0 -
Branch / Tag:
refs/tags/v2.0.26.20 - Owner: https://github.com/maku2903
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
public-ci-release.yml@5c4210256332d008667d5a2809a1031e783169b0 -
Trigger Event:
push
-
Statement type: