Python SDK for Polygres
Project description
Polygres Python SDK
The Polygres SDK is a retrieval client for a per-project Runtime API. It uses a Polygres API key and Runtime API URL; it does not open direct Postgres connections or expose database passwords.
Links:
- Documentation: https://docs.evokoa.com/polygres
- Polygres: https://polygres.com
- Evokoa: https://evokoa.com
- X: https://x.com/evokoa_ai
- Discord: https://discord.gg/GnHR8ezuwG
- Product Hunt: https://www.producthunt.com/@evokoa
Install
pip install polygres
Quick Start
Create a Polygres API key from your project Settings page. Find the Runtime API URL on your project Connect page. Use the Runtime API URL with the SDK, not the direct or pooled Postgres connection string.
from polygres import Polygres
client = Polygres(
api_key="POLYGRES_API_KEY",
runtime_url="POLYGRES_RUNTIME_URL",
)
project = client.project()
readiness = project.readiness()
print(readiness.graph, readiness.vector, readiness.hybrid)
connection = project.connection_info()
print(connection.direct_url_without_password)
print(connection.pooled_url_without_password)
connection_info() returns passwordless direct and pooled connection strings.
The SDK never returns the database password.
Query Chaining
Graph and hybrid calls need real row IDs from graph-registered tables. Do not
guess IDs such as doc_1 or cus_123 unless those rows actually exist in your
database. A safe pattern is to start with vector or text search, then use the
returned result as the graph start node.
embedding = [0.1] * 8 # Must match the configured vector dimensions.
vector_page = project.vector.search(
embedding,
config="documents_embedding",
limit=5,
)
top_doc = vector_page.results[0]
start = {
"schema": top_doc.schema,
"table": top_doc.table,
"id": top_doc.id,
}
graph_page = project.graph.expand(
start,
max_depth=2,
limit=10,
)
similar_page = project.vector.similar_to(
top_doc.id,
config="documents_embedding",
limit=5,
)
hybrid_page = project.hybrid.graph_first(
start,
embedding=embedding,
config="documents_embedding",
limit=10,
)
for result in hybrid_page.results:
print(result.id, result.score, result.vector_score, result.graph_score)
If a graph call returns Node not found, check that:
schema,table, andidrefer to a real row.- The table is registered in graph configuration.
- The graph has been rebuilt after adding or changing that row.
Readiness And Connection Info
readiness = project.readiness()
if readiness.vector["ready"]:
print("default vector config:", readiness.vector["default_config"])
connection = project.connection_info()
print(connection.direct_host)
print(connection.pooled_host)
Vector Retrieval
page = project.vector.search(
[0.1] * 8,
config="documents_embedding",
filters={"status": "published"},
min_similarity=0.75,
limit=10,
)
for result in page.results:
print(result.id, result.schema, result.table, result.score)
Find rows similar to an existing row:
page = project.vector.similar_to(
row_id="doc_security_01178",
config="documents_embedding",
limit=10,
)
Set include_values=True when you need returned embedding values:
page = project.vector.search(
[0.1] * 8,
config="documents_embedding",
include_values=True,
)
Text Retrieval
TSVector full-text search:
page = project.text.tsvector(
"refund policy",
config="documents_body_tsv",
filters={"status": "published"},
limit=10,
)
Fuzzy search:
page = project.text.fuzzy(
"acme corporation",
config="customer_name_fuzzy",
limit=10,
)
Text results expose id, schema, table, properties, score, and
similarity.
Graph Retrieval
Graph start nodes must identify real rows:
start = {"schema": "public", "table": "documents", "id": "doc_security_01178"}
Expand from a node:
page = project.graph.expand(
start,
max_depth=2,
direction="any",
filters={"status": "published"},
limit=20,
)
for result in page.results:
print(result.node.id, result.depth, result.graph_score)
Neighborhood is an alias-shaped traversal with radius:
page = project.graph.neighborhood(
start,
radius=2,
direction="any",
limit=20,
)
Related returns one-hop related nodes:
page = project.graph.related(
start,
direction="any",
limit=20,
)
Find paths between two nodes:
target = {"schema": "public", "table": "documents", "id": "doc_security_01744"}
path_response = project.graph.path(
start,
target,
max_depth=3,
)
print(path_response.paths)
Find connections across a chain of entities:
connection_response = project.graph.connection(
[start, target],
max_depth=3,
)
print(connection_response.connections)
GraphResult uses result.node.id. HybridResult exposes result.id
directly.
Hybrid Retrieval
Graph-first starts from a graph node, then blends graph context with vector similarity:
page = project.hybrid.graph_first(
start,
embedding=[0.1] * 8,
config="documents_embedding",
max_depth=2,
limit=10,
)
Vector-first starts with vector candidates, then expands graph context:
page = project.hybrid.vector_first(
[0.1] * 8,
config="documents_embedding",
vector_limit=20,
max_depth=1,
limit=10,
)
Joint combines a vector query with a graph start node:
page = project.hybrid.joint(
[0.1] * 8,
start,
config="documents_embedding",
vector_weight=0.7,
graph_weight=0.3,
max_depth=2,
limit=10,
)
Hybrid results expose id, schema, table, score, vector_score,
graph_score, distance, similarity, properties, and relationships.
Paging
Every list-style retrieval method returns a Page.
page = project.vector.search([0.1] * 8, config="documents_embedding", limit=25)
for result in page.results:
print(result.id)
if page.has_more:
next_page = project.vector.search(
[0.1] * 8,
config="documents_embedding",
limit=25,
cursor=page.next_cursor,
)
Use auto_paging_iter() to iterate through all pages:
page = project.text.tsvector(
"security incident",
config="documents_body_tsv",
limit=25,
)
for result in page.auto_paging_iter():
print(result.id, result.score)
Error Handling
from polygres import PolygresAPIError
try:
page = project.graph.expand(start, max_depth=2)
except PolygresAPIError as exc:
print(exc.status_code)
print(exc.code)
print(exc.request_id)
print(exc.details)
Common graph failures include Node not found when the requested start or
target row is not present in the graph projection.
Client Behavior
The SDK sends Authorization and User-Agent on every request. It does not
send X-Polygres-Project; the project identity is bound to the Runtime API URL.
The SDK supports retrieval against saved graph, vector, TSVector full-text, fuzzy text-search, and hybrid configurations. It does not expose dashboard-only setup mutations for graph/vector/text configuration, graph builds, or index reindexing.
The SDK is an HTTP client. It does not bundle direct Postgres drivers such as
asyncpg or psycopg, and it does not implement SQL editor script execution
locally. Future SQL editor SDK methods must call Polygres API routes instead of
opening database connections.
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 polygres-0.1.0.tar.gz.
File metadata
- Download URL: polygres-0.1.0.tar.gz
- Upload date:
- Size: 19.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8db0a3d501a856c4ca556d7c94aa798d0185f2bfccd9c4636d1b7e0d9cdf0452
|
|
| MD5 |
251721d6136be3e173a704e8ee13f2ba
|
|
| BLAKE2b-256 |
672488b3056c469af5bf89d2906fee10a405a5b9eaeeecb632a88a0a478b8773
|
Provenance
The following attestation bundles were made for polygres-0.1.0.tar.gz:
Publisher:
publish-python-sdk.yml on Evokoa/polygres-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
polygres-0.1.0.tar.gz -
Subject digest:
8db0a3d501a856c4ca556d7c94aa798d0185f2bfccd9c4636d1b7e0d9cdf0452 - Sigstore transparency entry: 1903384165
- Sigstore integration time:
-
Permalink:
Evokoa/polygres-sdk@64e02ee2ac5e5caef2fb73c93dc40bd0d322e008 -
Branch / Tag:
refs/tags/python-sdk-v0.1.0 - Owner: https://github.com/Evokoa
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-python-sdk.yml@64e02ee2ac5e5caef2fb73c93dc40bd0d322e008 -
Trigger Event:
push
-
Statement type:
File details
Details for the file polygres-0.1.0-py3-none-any.whl.
File metadata
- Download URL: polygres-0.1.0-py3-none-any.whl
- Upload date:
- Size: 15.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
83ce626ee8818970f755882dc57e454d401a6242b1272a80b6486335623c97e4
|
|
| MD5 |
efba367c7d374ee7cc74b90da6b05833
|
|
| BLAKE2b-256 |
ce265367003d15fe8b5c40837416130b48031231f2547eb7987d79d67abd9d4b
|
Provenance
The following attestation bundles were made for polygres-0.1.0-py3-none-any.whl:
Publisher:
publish-python-sdk.yml on Evokoa/polygres-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
polygres-0.1.0-py3-none-any.whl -
Subject digest:
83ce626ee8818970f755882dc57e454d401a6242b1272a80b6486335623c97e4 - Sigstore transparency entry: 1903384311
- Sigstore integration time:
-
Permalink:
Evokoa/polygres-sdk@64e02ee2ac5e5caef2fb73c93dc40bd0d322e008 -
Branch / Tag:
refs/tags/python-sdk-v0.1.0 - Owner: https://github.com/Evokoa
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-python-sdk.yml@64e02ee2ac5e5caef2fb73c93dc40bd0d322e008 -
Trigger Event:
push
-
Statement type: