Skip to content

Latest commit

 

History

History
321 lines (210 loc) · 24.3 KB

README.md

File metadata and controls

321 lines (210 loc) · 24.3 KB

Sessions

(sessions)

Overview

The Session object is an abstraction over an HTTP session. It models the period of information exchange between a user and the server. Sessions are created when a user successfully goes through the sign in or sign up flows. https://clerk.com/docs/reference/clerkjs/session

Available Operations

list

Returns a list of all sessions. The sessions are returned sorted by creation date, with the newest sessions appearing first. Deprecation Notice (2024-01-01): All parameters were initially considered optional, however moving forward at least one of client_id or user_id parameters should be provided.

Example Usage

import clerk_backend_api
from clerk_backend_api import Clerk

with Clerk(
    bearer_auth="<YOUR_BEARER_TOKEN_HERE>",
) as clerk:

    res = clerk.sessions.list(client_id="client_123", user_id="user_456", status=clerk_backend_api.QueryParamStatus.ACTIVE, limit=20, offset=10)

    assert res is not None

    # Handle response
    print(res)

Parameters

Parameter Type Required Description Example
client_id Optional[str] List sessions for the given client client_123
user_id Optional[str] List sessions for the given user user_456
status Optional[models.QueryParamStatus] Filter sessions by the provided status active
limit Optional[int] Applies a limit to the number of results returned.
Can be used for paginating the results together with offset.
20
offset Optional[int] Skip the first offset results when paginating.
Needs to be an integer greater or equal to zero.
To be used in conjunction with limit.
10
retries Optional[utils.RetryConfig] Configuration to override the default retry behavior of the client.

Response

List[models.Session]

Errors

Error Type Status Code Content Type
models.ClerkErrors 400, 401, 422 application/json
models.SDKError 4XX, 5XX */*

create_session

Create a new active session for the provided user ID.

This operation is only available for Clerk Development instances.

Example Usage

from clerk_backend_api import Clerk

with Clerk(
    bearer_auth="<YOUR_BEARER_TOKEN_HERE>",
) as clerk:

    res = clerk.sessions.create_session(request={
        "user_id": "<id>",
    })

    assert res is not None

    # Handle response
    print(res)

Parameters

Parameter Type Required Description
request models.CreateSessionRequestBody ✔️ The request object to use for the request.
retries Optional[utils.RetryConfig] Configuration to override the default retry behavior of the client.

Response

models.Session

Errors

Error Type Status Code Content Type
models.ClerkErrors 400, 401, 404, 422 application/json
models.SDKError 4XX, 5XX */*

get

Retrieve the details of a session

Example Usage

from clerk_backend_api import Clerk

with Clerk(
    bearer_auth="<YOUR_BEARER_TOKEN_HERE>",
) as clerk:

    res = clerk.sessions.get(session_id="sess_1234567890abcdef")

    assert res is not None

    # Handle response
    print(res)

Parameters

Parameter Type Required Description Example
session_id str ✔️ The ID of the session sess_1234567890abcdef
retries Optional[utils.RetryConfig] Configuration to override the default retry behavior of the client.

Response

models.Session

Errors

Error Type Status Code Content Type
models.ClerkErrors 400, 401, 404 application/json
models.SDKError 4XX, 5XX */*

revoke

Sets the status of a session as "revoked", which is an unauthenticated state. In multi-session mode, a revoked session will still be returned along with its client object, however the user will need to sign in again.

Example Usage

from clerk_backend_api import Clerk

with Clerk(
    bearer_auth="<YOUR_BEARER_TOKEN_HERE>",
) as clerk:

    res = clerk.sessions.revoke(session_id="sess_1234567890abcdef")

    assert res is not None

    # Handle response
    print(res)

Parameters

Parameter Type Required Description Example
session_id str ✔️ The ID of the session sess_1234567890abcdef
retries Optional[utils.RetryConfig] Configuration to override the default retry behavior of the client.

Response

models.Session

Errors

Error Type Status Code Content Type
models.ClerkErrors 400, 401, 404 application/json
models.SDKError 4XX, 5XX */*

verify

Returns the session if it is authenticated, otherwise returns an error. WARNING: This endpoint is deprecated and will be removed in future versions. We strongly recommend switching to networkless verification using short-lived session tokens, which is implemented transparently in all recent SDK versions (e.g. NodeJS SDK). For more details on how networkless verification works, refer to our Session Tokens documentation.

⚠️ DEPRECATED: This will be removed in a future release, please migrate away from it as soon as possible.

Example Usage

from clerk_backend_api import Clerk

with Clerk(
    bearer_auth="<YOUR_BEARER_TOKEN_HERE>",
) as clerk:

    res = clerk.sessions.verify(session_id="sess_w8q4g9s60j28fghv00f3", token="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzZXNzaW9uX2lkIjoic2Vzc193OHF4ZzZzNm9qMjhmZ2h2MDBmMyIsImlhdCI6MTU4MjY0OTg2Mn0.J4KP2L6bEZ6YccHFW4E2vKbOLw_mmO0gF_GNRw-wtLM")

    assert res is not None

    # Handle response
    print(res)

Parameters

Parameter Type Required Description Example
session_id str ✔️ The ID of the session sess_w8q4g9s60j28fghv00f3
token Optional[str] The JWT that is sent via the __session cookie from your frontend.
Note: this JWT must be associated with the supplied session ID.
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzZXNzaW9uX2lkIjoic2Vzc193OHF4ZzZzNm9qMjhmZ2h2MDBmMyIsImlhdCI6MTU4MjY0OTg2Mn0.J4KP2L6bEZ6YccHFW4E2vKbOLw_mmO0gF_GNRw-wtLM
retries Optional[utils.RetryConfig] Configuration to override the default retry behavior of the client.

Response

models.Session

Errors

Error Type Status Code Content Type
models.ClerkErrors 400, 401, 404, 410 application/json
models.SDKError 4XX, 5XX */*

create_session_token

Creates a session JSON Web Token (JWT) based on a session.

Example Usage

from clerk_backend_api import Clerk

with Clerk(
    bearer_auth="<YOUR_BEARER_TOKEN_HERE>",
) as clerk:

    res = clerk.sessions.create_session_token(session_id="<id>", expires_in_seconds=6005.84)

    assert res is not None

    # Handle response
    print(res)

Parameters

Parameter Type Required Description
session_id str ✔️ The ID of the session
expires_in_seconds OptionalNullable[float] Use this parameter to override the default session token lifetime.
retries Optional[utils.RetryConfig] Configuration to override the default retry behavior of the client.

Response

models.CreateSessionTokenResponseBody

Errors

Error Type Status Code Content Type
models.ClerkErrors 401, 404 application/json
models.SDKError 4XX, 5XX */*

create_token_from_template

Creates a JSON Web Token(JWT) based on a session and a JWT Template name defined for your instance

Example Usage

from clerk_backend_api import Clerk

with Clerk(
    bearer_auth="<YOUR_BEARER_TOKEN_HERE>",
) as clerk:

    res = clerk.sessions.create_token_from_template(session_id="ses_123abcd4567", template_name="custom_hasura", expires_in_seconds=2299.84)

    assert res is not None

    # Handle response
    print(res)

Parameters

Parameter Type Required Description Example
session_id str ✔️ The ID of the session ses_123abcd4567
template_name str ✔️ The name of the JWT Template defined in your instance (e.g. custom_hasura). custom_hasura
expires_in_seconds OptionalNullable[float] Use this parameter to override the JWT token lifetime.
retries Optional[utils.RetryConfig] Configuration to override the default retry behavior of the client.

Response

models.CreateSessionTokenFromTemplateResponseBody

Errors

Error Type Status Code Content Type
models.ClerkErrors 401, 404 application/json
models.SDKError 4XX, 5XX */*