// 1. Generate PKCE pair
pkce, _ := grantex.GeneratePKCE()
// 2. Include challenge in authorization request
authReq, _ := client.Authorize(ctx, grantex.AuthorizeParams{
AgentID: "agent-id",
PrincipalID: "user-123",
Scopes: []string{"read:email"},
CodeChallenge: pkce.CodeChallenge,
CodeChallengeMethod: pkce.CodeChallengeMethod,
})
// 3. Store verifier securely (session, database, etc.)
// ...
// 4. Include verifier when exchanging the code
tokenResp, _ := client.Tokens.Exchange(ctx, grantex.ExchangeTokenParams{
Code: "auth-code-from-callback",
AgentID: "agent-id",
CodeVerifier: pkce.CodeVerifier,
})