A strongly typed Python client for Synthient. Supports asynchronous and synchronous requests to the Synthient API.
MacOS/Linux
pip3 install synthientpyWindows
pip install synthientpyCheck synthientpy/models for the available fields in the response object.
Client and AsyncClient have the following methods:
class Client:
def __init__(
self,
api_key: str,
default_timeout: int = DEFAULT_TIMEOUT,
proxy: Optional[str] = None,
) -> None: ...
def lookup(self, token: str) -> LookupResponse: ...
def visits(self, session: str) -> VisitsResponse: ...
def delete(self, token: str) -> DeleteResponse: ...import synthientpy as synthient
client = synthient.Client(
api_key=os.getenv("SYNTHIENT_API_KEY"),
)
token = "..."
visitor_info = client.lookup(token)
print(visitor_info)import asyncio
import synthientpy as synthient
async def main():
client = synthient.AsyncClient(
api_key=os.getenv("SYNTHIENT_API_KEY"),
)
token = "..."
visitor_info = await client.lookup(token)
print(visitor_info)
asyncio.run(main())In addition to the client, there are helper functions that can be used to interact with the Synthient API.
def verify_token(lookup: LookupResponse, token_type: TokenType) -> bool: ...
def determine_action(lookup: LookupResponse, token_type: TokenType) -> str: ...Verify token checks if the token is valid and if the server should reject or accept it. Determine action checks if the token is valid and returns the action that should be taken based on the token type.
class ActionType(str, Enum):
"""Translates the risk level into an action to take.
ALLOW - Allow the visitor to continue.
REDIRECT - Redirect the visitor to a different page. Or have them perform another form of verification.
BLOCK - Block the visitor from accessing
"""
ALLOW = 0
REDIRECT = 1
BLOCK = 2Full documentation of the fields and their types can be found in the Synthient API documentation. You can also find all the types in the synthientpy.models module.
For any issues or feature requests, please open an issue on the GitHub repository