docs/python-sdk/fastmcp-server-auth-jwt_issuer.mdx
fastmcp.server.auth.jwt_issuerJWT token issuance and verification for FastMCP OAuth Proxy.
This module implements the token factory pattern for OAuth proxies, where the proxy issues its own JWT tokens to clients instead of forwarding upstream provider tokens. This maintains proper OAuth 2.0 token audience boundaries.
derive_jwt_key <sup><a href="https://github.com/PrefectHQ/fastmcp/blob/main/src/fastmcp/server/auth/jwt_issuer.py#L39" target="_blank"><Icon icon="github" style="width: 14px; height: 14px;" /></a></sup>derive_jwt_key() -> bytes
Derive JWT signing key from a high-entropy or low-entropy key material and server salt.
JWTIssuer <sup><a href="https://github.com/PrefectHQ/fastmcp/blob/main/src/fastmcp/server/auth/jwt_issuer.py#L79" target="_blank"><Icon icon="github" style="width: 14px; height: 14px;" /></a></sup>Issues and validates FastMCP-signed JWT tokens using HS256.
This issuer creates JWT tokens for MCP clients with proper audience claims, maintaining OAuth 2.0 token boundaries. Tokens are signed with HS256 using a key derived from the upstream client secret.
Methods:
issue_access_token <sup><a href="https://github.com/PrefectHQ/fastmcp/blob/main/src/fastmcp/server/auth/jwt_issuer.py#L105" target="_blank"><Icon icon="github" style="width: 14px; height: 14px;" /></a></sup>issue_access_token(self, client_id: str, scopes: list[str], jti: str, expires_in: int = 3600, upstream_claims: dict[str, Any] | None = None) -> str
Issue a minimal FastMCP access token.
FastMCP tokens are reference tokens containing only the minimal claims needed for validation and lookup. The JTI maps to the upstream token which contains actual user identity and authorization data.
Args:
client_id: MCP client IDscopes: Token scopesjti: Unique token identifier (maps to upstream token)expires_in: Token lifetime in secondsupstream_claims: Optional claims from upstream IdP token to includeReturns:
issue_refresh_token <sup><a href="https://github.com/PrefectHQ/fastmcp/blob/main/src/fastmcp/server/auth/jwt_issuer.py#L157" target="_blank"><Icon icon="github" style="width: 14px; height: 14px;" /></a></sup>issue_refresh_token(self, client_id: str, scopes: list[str], jti: str, expires_in: int, upstream_claims: dict[str, Any] | None = None) -> str
Issue a minimal FastMCP refresh token.
FastMCP refresh tokens are reference tokens containing only the minimal claims needed for validation and lookup. The JTI maps to the upstream token which contains actual user identity and authorization data.
Args:
client_id: MCP client IDscopes: Token scopesjti: Unique token identifier (maps to upstream token)expires_in: Token lifetime in seconds (should match upstream refresh expiry)upstream_claims: Optional claims from upstream IdP token to includeReturns:
verify_token <sup><a href="https://github.com/PrefectHQ/fastmcp/blob/main/src/fastmcp/server/auth/jwt_issuer.py#L210" target="_blank"><Icon icon="github" style="width: 14px; height: 14px;" /></a></sup>verify_token(self, token: str, expected_token_use: str = 'access') -> dict[str, Any]
Verify and decode a FastMCP token.
Validates JWT signature, expiration, issuer, audience, and token type.
Args:
token: JWT token to verifyexpected_token_use: Expected token type ("access" or "refresh").
Defaults to "access", which rejects refresh tokens.Returns:
Raises:
JoseError: If token is invalid, expired, or has wrong claims