FusionAuth
    • Home
    • Categories
    • Recent
    • Popular
    • Pricing
    • Contact us
    • Docs
    • Login

    Restricting Users to a Single Active Session in FusionAuth

    Scheduled Pinned Locked Moved Unsolved
    Q&A
    1
    2
    818
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • W
      wesley
      last edited by

      We found that a single user can have multiple active sessions simultaneously, meaning a user can log in multiple times. Is there a configuration in FusionAuth to restrict users to a single active session?

      W 1 Reply Last reply Reply Quote 0
      • W
        wesley @wesley
        last edited by wesley

        Currently, FusionAuth does not have native support for limiting users to a single session. However, this can be achieved programmatically using API calls.

        Steps to Restrict to a Single Active Session:

        1. User Logs In:
          Upon a successful login, you will receive a new JWT for the session.

        Retrieve Existing JWTs:
        Use the GET /api/jwt/refresh endpoint to fetch all active JWTs for the user:

        GET /api/jwt/refresh?userId={userId}
        
        1. Documentation: Retrieve JWTs

        Revoke Other Sessions:
        Loop through the retrieved JWTs and revoke all tokens except for the one associated with the most recent login. Use the DELETE /api/jwt/refresh endpoint to revoke each token:

        DELETE /api/jwt/refresh?token={token}
        
        1. Documentation: Revoke JWT

        Considerations:

        • This approach assumes the most recent login session is the one you want to keep active.
        • It requires handling session management programmatically on your end.

        Feature Request:

        There is an open request for native session-limiting functionality in FusionAuth. If this feature is important to your use case, you can upvote the request on GitHub:
        GitHub Issue #1363

        1 Reply Last reply Reply Quote 0
        • W wesley has marked this topic as solved on
        • W wesley has marked this topic as unsolved on
        • First post
          Last post