Scalekit official Python SDK
Project description
Official Python SDK
Scalekit is the auth stack for AI apps - from human authentication to agent authorization. Build secure AI products faster with authentication for humans (SSO, passwordless, full-stack auth) and agents (MCP/APIs, delegated actions), all unified on one platform. This Python SDK enables both traditional B2B authentication and cutting-edge agentic workflows.
🤖 Agent-First Features
- 🔐 Agent Identity: Agents as first-class actors with human ownership and org context
- 🎯 MCP-Native OAuth 2.1: Purpose-built for Model Context Protocol with DCR/PKCE support
- ⏰ Ephemeral Credentials: Time-bound, task-based authorization (minutes, not days)
- 🔒 Token Vault: Per-user, per-tool token storage with rotation and progressive consent
- 👥 Human-in-the-Loop: Step-up authentication when risk crosses thresholds
- 📊 Immutable Audit: Track which user initiated, which agent acted, what resource was accessed
👨💼 Human Authentication
- 🔐 Enterprise SSO: Support for SAML and OIDC protocols
- 👥 SCIM Provisioning: Automated user provisioning and deprovisioning
- 🚀 Passwordless Authentication: Magic links, OTP, and modern auth flows
- 🏢 Multi-tenant Architecture: Organization-level authentication policies
- 📱 Social Logins: Support for popular social identity providers
- 🛡️ Full-Stack Auth: Complete IdP-of-record solution for B2B SaaS
- 🐍 Pythonic API: Clean, intuitive interface following Python conventions
Pre-requisites
- Sign up for a Scalekit account.
- Get your
env_url,client_idandclient_secretfrom the Scalekit dashboard.
Installation
Install Scalekit SDK using your preferred package manager.
pip install scalekit-sdk-python
Usage
from scalekit import ScalekitClient
sc = ScalekitClient(
env_url,
client_id,
client_secret
)
# Use the sc object to interact with the Scalekit API
auth_url = sc.get_authorization_url(
"https://acme-corp.com/redirect-uri",
state="state",
connection_id="con_123456789"
)
Minimum Requirements
To use the Scalekit Python SDK, you must have the following:
| Component | Version |
|---|---|
| Python | 3.8+ |
Tip: Although Python 3.8 meets the minimum requirement, using a more recent version (such as Python 3.9 or later) is advisable.
Examples - SSO with FastAPI
Below is a simple code sample that showcases how to implement Single Sign-on using Scalekit SDK
from fastapi import FastAPI, Request, Response
from scalekit import ScalekitClient
import uvicorn
app = FastAPI()
sc = ScalekitClient(
env_url,
client_id,
client_secret
)
redirect_uri = "http://localhost:8000/auth/callback"
@app.get("/auth/login")
async def auth_login(request: Request):
auth_url = sc.get_authorization_url(
redirect_uri,
state="state",
connection_id="con_123456789"
)
return Response(status_code=302, headers={"Location": auth_url})
@app.get("/auth/callback")
async def auth_callback(request: Request):
code = request.query_params.get("code")
token = sc.authenticate_with_code(
code,
redirect_uri
)
response = JSONResponse(content=token)
response.set_cookie("access_token", token["access_token"])
return response
if __name__ == "__main__":
uvicorn.run(app, port=8080)
📱 Example Apps
Explore fully functional sample applications built with popular Python frameworks and the Scalekit SDK:
| Framework | Repository | Description |
|---|---|---|
| FastAPI | scalekit-fastapi-example | Modern async Python API framework |
🔗 Helpful Links
📖 Quickstart Guides
- SSO Integration - Implement enterprise Single Sign-on
- Full Stack Auth - Complete authentication solution
- Passwordless Auth - Modern authentication flows
- Social Logins - Popular social identity providers
- Machine-to-Machine - API authentication
📚 Documentation & Reference
- API Reference - Complete API documentation
- Developer Kit - Tools and utilities
- API Authentication Guide - Secure API access
🛠️ Additional Resources
- Setup Guide - Initial platform configuration
- Code Examples - Ready-to-use code snippets
- Admin Portal Guide - Administrative interface
- Launch Checklist - Pre-production checklist
License
This project is licensed under the MIT license. See the LICENSE file for more information.
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 scalekit_sdk_python-2.6.0.tar.gz.
File metadata
- Download URL: scalekit_sdk_python-2.6.0.tar.gz
- Upload date:
- Size: 465.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c8122de01c2333af3cf7741246751fce47b75b5daffc396d0108e3bbcec28c15
|
|
| MD5 |
5cf67dcc6c0cb58360d644f5a2ba6125
|
|
| BLAKE2b-256 |
7b83755ba47fe80217fb1506a51f24366a8a16a2e58630dd60d5d10b4d524f32
|
File details
Details for the file scalekit_sdk_python-2.6.0-py3-none-any.whl.
File metadata
- Download URL: scalekit_sdk_python-2.6.0-py3-none-any.whl
- Upload date:
- Size: 494.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb62ad615b09fa0ba861f78fb4ea2536996534295a7e65dfd978abbe8200ac8d
|
|
| MD5 |
9fd1ad2a342afb120ae642d7423063d9
|
|
| BLAKE2b-256 |
a6306755966d47497a08e5ed85495701e5d9c5c36d69af1a40ad193e2fe00c55
|