(sessions())
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.
package hello.world;
import com.clerk.backend_api.Clerk;
import com.clerk.backend_api.models.errors.ClerkErrors;
import com.clerk.backend_api.models.operations.GetSessionListRequest;
import com.clerk.backend_api.models.operations.GetSessionListResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws ClerkErrors, Exception {
Clerk sdk = Clerk.builder()
.bearerAuth("<YOUR_BEARER_TOKEN_HERE>")
.build();
GetSessionListRequest req = GetSessionListRequest.builder()
.build();
GetSessionListResponse res = sdk.sessions().list()
.request(req)
.call();
if (res.sessionList().isPresent()) {
// handle response
}
}
}
Parameter |
Type |
Required |
Description |
request |
GetSessionListRequest |
✔️ |
The request object to use for the request. |
GetSessionListResponse
Error Type |
Status Code |
Content Type |
models/errors/ClerkErrors |
400, 401, 422 |
application/json |
models/errors/SDKError |
4XX, 5XX |
*/* |
Create a new active session for the provided user ID.
This operation is intended only for use in testing, and is not available for production instances. If you are looking to generate a user session from the backend,
we recommend using the Sign-in Tokens resource instead.
package hello.world;
import com.clerk.backend_api.Clerk;
import com.clerk.backend_api.models.errors.ClerkErrors;
import com.clerk.backend_api.models.operations.CreateSessionRequestBody;
import com.clerk.backend_api.models.operations.CreateSessionResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws ClerkErrors, Exception {
Clerk sdk = Clerk.builder()
.bearerAuth("<YOUR_BEARER_TOKEN_HERE>")
.build();
CreateSessionRequestBody req = CreateSessionRequestBody.builder()
.userId("<id>")
.build();
CreateSessionResponse res = sdk.sessions().create()
.request(req)
.call();
if (res.session().isPresent()) {
// handle response
}
}
}
CreateSessionResponse
Error Type |
Status Code |
Content Type |
models/errors/ClerkErrors |
400, 401, 404, 422 |
application/json |
models/errors/SDKError |
4XX, 5XX |
*/* |
Retrieve the details of a session
package hello.world;
import com.clerk.backend_api.Clerk;
import com.clerk.backend_api.models.errors.ClerkErrors;
import com.clerk.backend_api.models.operations.GetSessionResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws ClerkErrors, Exception {
Clerk sdk = Clerk.builder()
.bearerAuth("<YOUR_BEARER_TOKEN_HERE>")
.build();
GetSessionResponse res = sdk.sessions().get()
.sessionId("<id>")
.call();
if (res.session().isPresent()) {
// handle response
}
}
}
Parameter |
Type |
Required |
Description |
sessionId |
String |
✔️ |
The ID of the session |
GetSessionResponse
Error Type |
Status Code |
Content Type |
models/errors/ClerkErrors |
400, 401, 404 |
application/json |
models/errors/SDKError |
4XX, 5XX |
*/* |
Refreshes a session by creating a new session token. A 401 is returned when there
are validation errors, which signals the SDKs to fallback to the handshake flow.
package hello.world;
import com.clerk.backend_api.Clerk;
import com.clerk.backend_api.models.errors.ClerkErrors;
import com.clerk.backend_api.models.operations.RefreshSessionRequestBody;
import com.clerk.backend_api.models.operations.RefreshSessionResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws ClerkErrors, Exception {
Clerk sdk = Clerk.builder()
.bearerAuth("<YOUR_BEARER_TOKEN_HERE>")
.build();
RefreshSessionResponse res = sdk.sessions().refresh()
.sessionId("<id>")
.requestBody(RefreshSessionRequestBody.builder()
.expiredToken("<value>")
.refreshToken("<value>")
.requestOrigin("<value>")
.build())
.call();
if (res.sessionRefresh().isPresent()) {
// handle response
}
}
}
RefreshSessionResponse
Error Type |
Status Code |
Content Type |
models/errors/ClerkErrors |
400, 401 |
application/json |
models/errors/SDKError |
4XX, 5XX |
*/* |
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.
package hello.world;
import com.clerk.backend_api.Clerk;
import com.clerk.backend_api.models.errors.ClerkErrors;
import com.clerk.backend_api.models.operations.RevokeSessionResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws ClerkErrors, Exception {
Clerk sdk = Clerk.builder()
.bearerAuth("<YOUR_BEARER_TOKEN_HERE>")
.build();
RevokeSessionResponse res = sdk.sessions().revoke()
.sessionId("<id>")
.call();
if (res.session().isPresent()) {
// handle response
}
}
}
Parameter |
Type |
Required |
Description |
sessionId |
String |
✔️ |
The ID of the session |
RevokeSessionResponse
Error Type |
Status Code |
Content Type |
models/errors/ClerkErrors |
400, 401, 404 |
application/json |
models/errors/SDKError |
4XX, 5XX |
*/* |
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.
package hello.world;
import com.clerk.backend_api.Clerk;
import com.clerk.backend_api.models.errors.ClerkErrors;
import com.clerk.backend_api.models.operations.VerifySessionRequestBody;
import com.clerk.backend_api.models.operations.VerifySessionResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws ClerkErrors, Exception {
Clerk sdk = Clerk.builder()
.bearerAuth("<YOUR_BEARER_TOKEN_HERE>")
.build();
VerifySessionResponse res = sdk.sessions().verify()
.sessionId("<id>")
.requestBody(VerifySessionRequestBody.builder()
.build())
.call();
if (res.session().isPresent()) {
// handle response
}
}
}
VerifySessionResponse
Error Type |
Status Code |
Content Type |
models/errors/ClerkErrors |
400, 401, 404, 410 |
application/json |
models/errors/SDKError |
4XX, 5XX |
*/* |
Creates a session JSON Web Token (JWT) based on a session.
package hello.world;
import com.clerk.backend_api.Clerk;
import com.clerk.backend_api.models.errors.ClerkErrors;
import com.clerk.backend_api.models.operations.CreateSessionTokenRequestBody;
import com.clerk.backend_api.models.operations.CreateSessionTokenResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws ClerkErrors, Exception {
Clerk sdk = Clerk.builder()
.bearerAuth("<YOUR_BEARER_TOKEN_HERE>")
.build();
CreateSessionTokenResponse res = sdk.sessions().createToken()
.sessionId("<id>")
.requestBody(CreateSessionTokenRequestBody.builder()
.build())
.call();
if (res.object().isPresent()) {
// handle response
}
}
}
CreateSessionTokenResponse
Error Type |
Status Code |
Content Type |
models/errors/ClerkErrors |
401, 404 |
application/json |
models/errors/SDKError |
4XX, 5XX |
*/* |
Creates a JSON Web Token(JWT) based on a session and a JWT Template name defined for your instance
package hello.world;
import com.clerk.backend_api.Clerk;
import com.clerk.backend_api.models.errors.ClerkErrors;
import com.clerk.backend_api.models.operations.CreateSessionTokenFromTemplateRequestBody;
import com.clerk.backend_api.models.operations.CreateSessionTokenFromTemplateResponse;
import java.lang.Exception;
public class Application {
public static void main(String[] args) throws ClerkErrors, Exception {
Clerk sdk = Clerk.builder()
.bearerAuth("<YOUR_BEARER_TOKEN_HERE>")
.build();
CreateSessionTokenFromTemplateResponse res = sdk.sessions().createTokenFromTemplate()
.sessionId("<id>")
.templateName("<value>")
.requestBody(CreateSessionTokenFromTemplateRequestBody.builder()
.build())
.call();
if (res.object().isPresent()) {
// handle response
}
}
}
CreateSessionTokenFromTemplateResponse
Error Type |
Status Code |
Content Type |
models/errors/ClerkErrors |
401, 404 |
application/json |
models/errors/SDKError |
4XX, 5XX |
*/* |