Client library for Purple Auth
Project description
Purple Auth Client
An async python client for my "Purple Auth" microservice.
Routes Covered
initialization
from purple_auth_client import AuthClient
auth_client = AuthClient(
host="https://purpleauth.com",
app_id="37f9a26d-03c8-4b7c-86ad-132bb82e8e38",
api_key="[Key provided by purple auth portal]"
)
/otp/request/
Start otp authentication flow with server.
result = await auth_client.authenticate(
"test@example.com", flow="otp"
)
/otp/confirm/
Complete authentication with email and generated code.
result = await auth_client.submit_code("test@example.com", "12345678")
/token/verify/
Send idToken to server for verification.
result = await auth_client.verify_token_remote(token_submitted_by_client)
/token/refresh/
Request a new ID Token from the server using a refresh token
new_token = await auth_client.refresh(refresh_token_from_client)
/app/
Get more info about this app from the server.
info = await auth_client.app_info()
/magic/request/
Start authentication using magic link flow.
result = await auth_client.authenticate(
"test@example.com", flow="magic"
)
Local Verification
Verify and decode an ID Token on directly in the app without having to call out every time
result = await auth_client.verify(id_token_from_client)
# {"headers": {"alg": "ES256", "type": "JWT"}, "claims": {"sub": "user@email.com", "exp": "test@example.com"}
# etc.
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
Close
Hashes for purple_auth_client-1.0.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6655ab77837eee0f5990f2658433600696b54796c3979df1a071b8e4c5a3b0b7 |
|
MD5 | c3662ceb7fb44af3610086ef88c95a10 |
|
BLAKE2b-256 | f4b536c0e12839aba76ef4db5f46604e57d52e1ed89989bc5ce3e92f21f40c0f |