Skip to main content

Official NeutralAI Python SDK for masking sensitive prompt data before it reaches AI applications.

Project description

NeutralAI Python SDK

Package Status

Final public package name: neutralai-sdk.

Public PyPI publication is in progress. Do not show python -m pip install neutralai-sdk on public website pages until the release workflow has published the package and the registry verification step passes.

Install (local workspace)

pip install -e .

For async web services and batch workers, install the async extra:

pip install -e ".[async]"

After public PyPI publication is complete:

python -m pip install "neutralai-sdk[async]"

Usage (sync)

from neutralai_sdk import NeutralAIClient

client = NeutralAIClient(base_url="http://localhost:8001", api_key="test-key")
res = client.mask("My email is user@example.com", reversible=False)
print(res.masked_text)

Usage (async)

import asyncio
from neutralai_sdk import AsyncNeutralAIClient

async def main():
    async with AsyncNeutralAIClient(base_url="http://localhost:8001", api_key="test-key") as client:
        res = await client.mask("Call me at +90 555 123 45 67")
        print(res.masked_text)

asyncio.run(main())

The async client keeps one httpx.AsyncClient open for connection pooling and retries transient 408, 429, and 5xx responses by default.

Usage (async streaming)

import asyncio
from neutralai_sdk import AsyncNeutralAIClient

async def main():
    async with AsyncNeutralAIClient(
        base_url="http://localhost:8001",
        service_token="signed-service-token",
    ) as client:
        async for event in client.chat_stream(
            session_id="session-123",
            prompt="Summarize this text",
            provider="openai",
            model="gpt-4-turbo",
        ):
            if event.type == "token":
                print(event.token, end="")

asyncio.run(main())

Integration registry

The SDK includes a small dependency-free adapter registry for framework wrappers. The default registry exposes langchain, and teams can register their own adapters without adding optional framework dependencies to the core package.

from neutralai_sdk import NeutralAIClient, create_integration

client = NeutralAIClient(base_url="http://localhost:8001", agent_token="agent-token")
guard = create_integration("langchain", client, target_agent_id="agent-target")
safe_input = guard.sanitize_input({"input": "Email alice@example.com"})

Supported Endpoints

  • POST /v1/shield/mask
  • POST /v1/shield/unmask
  • POST /v1/agents/mask
  • POST /v1/chat/stream

POST /v1/shield/unmask requires tenant-scoped authentication via API key or service token and only restores reversible vault tokens that still match the stored scope and TTL.

Async Throughput

Use asyncio.gather with one shared AsyncNeutralAIClient to run many requests concurrently while reusing pooled connections:

async with AsyncNeutralAIClient(base_url="https://api.neutralai.co.uk", api_key="...") as client:
    results = await asyncio.gather(*(client.mask(prompt) for prompt in prompts))

In internal local benchmarks with mocked 100 ms network latency, 50 concurrent async requests complete about 10x faster than the same requests issued sequentially through the sync client because the async version overlaps network wait time.

To reproduce the local latency benchmark shape:

python sdk/python/examples/async_benchmark.py

Observability Hooks

You can pass observability_hook to capture SDK request lifecycle events:

  • request_start
  • request_success
  • request_error

Diagnostics are redacted by default:

  • API keys/tokens are reported as <REDACTED>
  • prompt/tokenized values are summarized as <REDACTED len=N>

License

MIT — see LICENSE. This SDK is a thin, dependency-light HTTP client for the NeutralAI Gateway API; all PII detection and masking happens server-side.

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

neutralai_sdk-0.1.0.tar.gz (11.1 kB view details)

Uploaded Source

Built Distribution

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

neutralai_sdk-0.1.0-py3-none-any.whl (10.6 kB view details)

Uploaded Python 3

File details

Details for the file neutralai_sdk-0.1.0.tar.gz.

File metadata

  • Download URL: neutralai_sdk-0.1.0.tar.gz
  • Upload date:
  • Size: 11.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for neutralai_sdk-0.1.0.tar.gz
Algorithm Hash digest
SHA256 9e431fadf79fb36f5c6c1be29a9398337077a0704f256495e1e22692e4aa0864
MD5 71fbe7fdf17ce12d152a2bfd7caab77a
BLAKE2b-256 b80526924cad09aa45fdebed36a75c2a2cff1916ab18401ed4811352433d9a39

See more details on using hashes here.

File details

Details for the file neutralai_sdk-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: neutralai_sdk-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 10.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for neutralai_sdk-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 decf738af773f8c3e5997a2436cdff341d544468426fc115b818f787a27c0fba
MD5 4b8b897e41eb22121eddaf759c8fc76d
BLAKE2b-256 d4d9eb1f2e4541e6f96e5c435ac3ab32043f65a37aa7e6a773f6eaf9242f8d7b

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