• Mensagens
  • Agentes Gerenciados
  • Administração
Search...
⌘K
Organização
API de AdministraçãoWorkspaces
Autenticação
Visão geralWorkload Identity FederationReferência de WIF
Monitoramento
API de Uso e CustoAPI de Limites de TaxaAPI de Análise do Claude Code
Dados e conformidade
Residência de dadosAPI e retenção de dados
API de Conformidade
Visão geralObter acessoFeed de AtividadesChats, arquivos e projetosOrganizações, usuários, funções e gruposProjetar sua integraçãoErrosPerguntas frequentes
Log in
Referência de WIF
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...

Solutions

  • AI agents
  • Code modernization
  • Coding
  • Customer support
  • Education
  • Financial services
  • Government
  • Life sciences

Partners

  • Amazon Bedrock
  • Google Cloud's Vertex AI

Learn

  • Blog
  • Courses
  • Use cases
  • Connectors
  • Customer stories
  • Engineering at Anthropic
  • Events
  • Powered by Claude
  • Service partners
  • Startups program

Company

  • Anthropic
  • Careers
  • Economic Futures
  • Research
  • News
  • Responsible Scaling Policy
  • Security and compliance
  • Transparency

Learn

  • Blog
  • Courses
  • Use cases
  • Connectors
  • Customer stories
  • Engineering at Anthropic
  • Events
  • Powered by Claude
  • Service partners
  • Startups program

Help and security

  • Availability
  • Status
  • Support
  • Discord

Terms and policies

  • Privacy policy
  • Responsible disclosure policy
  • Terms of service: Commercial
  • Terms of service: Consumer
  • Usage policy
Administração/Autenticação

Referência de WIF

Variáveis de ambiente, regras de validação, configuração de perfil e referência de erros para Workload Identity Federation.

Esta página reúne as superfícies de configuração, restrições de validação e mapeamentos de erros para Workload Identity Federation. Para tutoriais de configuração, consulte os guias de provedores.

Requisição de troca de token

POST /v1/oauth/token aceita um corpo JSON usando o grant jwt-bearer da RFC 7523. Os SDKs constroem essa requisição para você a partir das variáveis de ambiente; os exemplos de cURL em cada guia de provedor mostram o corpo bruto.

CampoObrigatórioDescrição
grant_typeSimSempre urn:ietf:params:oauth:grant-type:jwt-bearer.
assertionSimO JWT OIDC emitido pelo seu provedor de identidade.
federation_rule_idSimID com tag (fdrl_...) da regra de federação a ser avaliada.
organization_idSimUUID da sua organização Anthropic.
service_account_idSimID com tag (svac_...) da conta de serviço de destino.
workspace_idCondicionalID com tag (wrkspc_...) do workspace ao qual o token emitido será restrito, ou o literal default para o workspace padrão da organização. Obrigatório quando a regra está habilitada para mais de um workspace. Quando omitido, o servidor seleciona o único workspace habilitado da regra.

Resposta da troca de token

POST /v1/oauth/token retorna uma resposta de token OAuth 2.0 padrão (RFC 6749 §5.1):

CampoTipoDescrição
access_tokenstringO token Anthropic de curta duração, com prefixo sk-ant-oat01-.... Passe-o como Authorization: Bearer <token>.
token_typestringSempre Bearer.
expires_inintegerSegundos até o token expirar.
scopestringO escopo OAuth concedido pela regra correspondente.

Variáveis de ambiente

O SDK lê essas variáveis para realizar uma troca de token federada sem argumentos de construtor.

VariávelObrigatóriaDescriçãoExemplo
ANTHROPIC_FEDERATION_RULE_IDSimID com tag da regra de federação a ser avaliada.fdrl_...
ANTHROPIC_ORGANIZATION_IDSimUUID da sua organização Anthropic. Encontre-o no Claude Console em Settings > Organization.00000000-0000-0000-0000-000000000000
ANTHROPIC_IDENTITY_TOKEN_FILEUma entre _TOKEN_FILE ou _TOKENCaminho no sistema de arquivos para o JWT emitido pelo seu "identity provider" (provedor de identidade), ou IdP. O SDK relê esse arquivo a cada troca para que tokens projetados que rotacionam em disco estejam sempre atualizados./var/run/secrets/anthropic.com/token

O caminho de federação via variáveis de ambiente diretas é ativado apenas quando ANTHROPIC_FEDERATION_RULE_ID, ANTHROPIC_ORGANIZATION_ID, ANTHROPIC_SERVICE_ACCOUNT_ID e uma entre ANTHROPIC_IDENTITY_TOKEN_FILE ou ANTHROPIC_IDENTITY_TOKEN estão todas definidas. ANTHROPIC_WORKSPACE_ID é lida junto, mas não condiciona a ativação.

Uma variável definida como string vazia ainda ocupa seu lugar na cadeia de precedência de credenciais. Se ANTHROPIC_API_KEY="" for exportada, o SDK seleciona o caminho de chave de API com uma chave vazia em vez de prosseguir para a federação. Remova a definição de variáveis de credencial não utilizadas em vez de deixá-las em branco.

Precedência de credenciais

O SDK resolve credenciais nesta ordem. A primeira fonte que produz uma credencial vence.

OrdemFonteObservações
1Argumento do construtor (api_key=, auth_token=, credentials=)Sempre sobrepõe todo o resto.
2ANTHROPIC_API_KEY ou ANTHROPIC_AUTH_TOKENOculta completamente a federação. Remova a definição dessas variáveis ao migrar de chaves de API.
3ANTHROPIC_PROFILECarrega <config_dir>/configs/<name>.json. Um perfil nomeado ausente é um erro, não uma passagem para a próxima fonte.
4Variáveis de ambiente de federaçãoANTHROPIC_FEDERATION_RULE_ID + ANTHROPIC_ORGANIZATION_ID + + .

Quando um perfil é carregado, as variáveis de ambiente preenchem quaisquer campos que o perfil omite, mas nunca sobrepõem campos que o perfil define explicitamente. Por exemplo, ANTHROPIC_WORKSPACE_ID preenche workspace_id apenas quando o perfil ativo não o define.

Arquivo de configuração de perfil

Um perfil é um arquivo de configuração nomeado que tanto o SDK quanto a CLI ant leem. Perfis permitem que você distribua parâmetros de federação com sua imagem de contêiner ou alterne entre ambientes sem alterar código.

Diretório de configuração

O SDK localiza o diretório de configuração nesta ordem:

  1. $ANTHROPIC_CONFIG_DIR
  2. ~/.config/anthropic no Linux e macOS
  3. %APPDATA%\Anthropic no Windows

Perfil ativo

O nome do perfil ativo é resolvido nesta ordem:

  1. $ANTHROPIC_PROFILE
  2. O conteúdo de <config_dir>/active_config (um arquivo de uma linha escrito por ant profile activate <name>)
  3. O nome literal default

O Claude Code e o Claude Agent SDK respeitam essa mesma ordem de resolução, portanto um perfil de federação configurado aqui também autentica essas ferramentas sem configuração adicional.

Layout de arquivos

CaminhoConteúdoSensibilidade
<config_dir>/configs/<profile>.jsonversion, o bloco authentication, organization_id, workspace_id e base_url.Não secreto. Seguro para commit ou para incluir em uma imagem.
<config_dir>/credentials/<profile>.jsonversion, o access_token em cache, expires_at e (para login interativo) refresh_token.Secreto. Escrito pelo SDK com modo 0600.

Tanto o arquivo de configuração quanto o arquivo de credenciais carregam um campo string version de nível superior no formato major.minor (atualmente "1.0"). O SDK escreve esse campo automaticamente para que versões futuras possam detectar e migrar formatos mais antigos; omita-o ao criar uma configuração manualmente e o SDK tratará o arquivo como a versão atual.

Exemplo de perfil de federação

configs/production.json
{
  "version": "1.0",
  "authentication": {
    "type": "oidc_federation",
    "federation_rule_id": "fdrl_...",
    "service_account_id": "svac_...",
    "identity_token": {
      "source": "file",
      "path": "/var/run/secrets/anthropic.com/token"
    }
  },
  "organization_id": "00000000-0000-0000-0000-000000000000",
  "workspace_id": "wrkspc_...",
  "base_url": "https://api.anthropic.com"
}

Se authentication.identity_token for omitido, o SDK recorre a ANTHROPIC_IDENTITY_TOKEN_FILE ou ANTHROPIC_IDENTITY_TOKEN do ambiente.

Escopos OAuth

O oauth_scope que você define em uma regra de federação determina quais endpoints da API do Claude o token de acesso emitido pode chamar.

EscopoConcede acesso a
workspace:developerTodos os endpoints não administrativos da API do Claude no workspace da regra: Messages (incluindo streaming e contagem de tokens), Models, Managed Agents e suas sessões, Files e Skills. Isso corresponde ao acesso que uma chave de API emitida para o mesmo workspace tem.
org:manage_tunnelsA API de túneis MCP: listar e obter túneis, registrar e arquivar certificados de CA, revelar e rotacionar o token do túnel e arquivar túneis. O modal de criação de túnel do Console fixa esse escopo quando você cria uma regra a partir dele.

Uma requisição a um endpoint fora do escopo do token retorna HTTP 403. Escopos mais granulares (por recurso, ou leitura versus escrita) não estão disponíveis atualmente.

Regras de validação

A Anthropic aplica essas restrições quando você cria ou atualiza emissores e regras, e ao verificar um JWT recebido no momento da troca.

Campos de recurso

CampoRestrição
name de emissor, regra e conta de serviçoDeve corresponder a ^[a-z0-9-]+$, comprimento de 1 a 255 caracteres.
workspace_idOpcional. O workspace (wrkspc_...) cuja cota, faturamento e limites de taxa se aplicam aos tokens emitidos sob essa regra. Deve ser um workspace na mesma organização, e a conta de serviço de destino deve ser membro desse workspace. Pode ser omitido para regras configuradas para apenas um workspace.
token_lifetime_secondsInteiro entre 60 e 86400 (1 minuto a 24 horas). Padrão 3600. Valores fora desse intervalo são rejeitados no momento da requisição. Consulte Tempo de vida e atualização do token.

Campos de URL

Os campos issuer_url, jwks.discovery_base e jwks.url são validados:

RestriçãoDetalhe
EsquemaDeve ser https.
PortaDeve ser 443 (explícita ou padrão).
HostDeve ser um nome de host DNS público do seu provedor OIDC. Deve resolver para endereços IP públicos; literais de IP não são aceitos.

Falhas de validação de URL retornam 400 invalid_request_error com o nome do campo como prefixo na mensagem de erro (por exemplo, issuer_url: url must use https scheme).

As restrições de URL se aplicam apenas a URLs que a Anthropic acessa. Nos modos de JWKS explicit_url e inline, e no modo discovery quando jwks.discovery_base está definido, o issuer_url é comparado com a claim iss do JWT como string e nunca é acessado, portanto pode referenciar um hostname interno ou porta não padrão.

Verificação de JWT

RestriçãoDetalhe
Tamanho máximoO JWT em assertion deve ter no máximo 16 KiB.
Algoritmo de assinaturaApenas algoritmos assimétricos (famílias RSA e ECDSA: ES256, ES384, ES512, RS256, RS384, RS512, PS256, PS384, PS512) são aceitos. HMAC (HS256, HS384, HS512) e none são rejeitados.
ID da chaveO cabeçalho do JWT deve conter um kid que corresponda a uma chave no JWKS do emissor. Tokens sem kid são rejeitados.
Claims obrigatóriassub deve estar presente. iat deve estar presente e não estar no futuro. exp deve estar presente e estar no futuro.
Tempo de vida máximoO tempo de vida do token ( menos ) não deve exceder o máximo configurado do emissor (1 hora por padrão, configurável para cada emissor no Claude Console).

Semântica de correspondência de regras

O bloco match de uma regra de federação determina se um JWT recebido é aceito. Todos os campos preenchidos são avaliados com semântica AND: o JWT deve satisfazer todos os matchers preenchidos. Pelo menos um entre subject_prefix, claims ou condition deve estar definido; um bloco match que contém apenas audience (ou nenhum matcher) é rejeitado. Isso protege contra regras que aceitariam todos os tokens de um emissor.

MatcherTipoSemântica
subject_prefixstringCorrespondência exata com a claim sub do JWT. Um * no final torna-a uma correspondência de prefixo (o valor de sub deve começar com os caracteres antes do *). Sensível a maiúsculas e minúsculas.
audiencestringA claim aud do JWT deve conter essa string exata. Quando aud é um array, qualquer elemento que corresponda exatamente satisfaz a verificação.
claimsmap<string, string>Cada chave é um nome de claim de nível superior e cada valor é o valor de string exato exigido. Para claims aninhadas, numéricas, booleanas ou complexas como listas e mapas, use condition com uma expressão CEL.

Ambiente de avaliação CEL

A expressão condition tem acesso a uma única variável:

VariávelTipoConteúdo
claimsmapO conjunto completo de claims decodificadas do JWT. Objetos aninhados são acessíveis como mapas aninhados.

Exemplo:

claims.sub.startsWith("repo:acme-corp/") && claims.ref in ["refs/heads/main", "refs/heads/release"]

Condições CEL são limites de segurança. Uma expressão que avalia como true para mais entradas do que o pretendido concede acesso mais amplo do que o pretendido. Prefira os matchers estáticos quando eles expressarem sua restrição.

Erros

Erros de troca de token

POST /v1/oauth/token retorna erros no formato de erro padrão da API. O SDK encapsula falhas de troca em um FederationExchangeError tipado (ou equivalente na linguagem) que expõe o status HTTP, o corpo da resposta e o request_id.

StatusErroCausaResolução
400invalid_requestfederation_rule_id está malformado ou um campo obrigatório da requisição está ausente.Verifique o ID fdrl_ e se o corpo da requisição inclui todos os campos obrigatórios.
400invalid_requestworkspace_id_required: a regra de federação está habilitada para mais de um workspace e a requisição omite workspace_id.Defina ANTHROPIC_WORKSPACE_ID (ou o campo workspace_id no corpo de uma requisição bruta) com o ID wrkspc_... ao qual você quer que o token seja restrito. Consulte Requisição de troca de token.
400

Todas as falhas invalid_grant retornam HTTP 400; a causa específica é registrada apenas no lado do servidor e não é exposta na resposta.

Falhas comuns do lado do SDK

SintomaCausaResolução
O SDK reporta "no credentials" em vez de fazer a trocaUma entre ANTHROPIC_FEDERATION_RULE_ID, ANTHROPIC_ORGANIZATION_ID, ANTHROPIC_SERVICE_ACCOUNT_ID ou ANTHROPIC_IDENTITY_TOKEN[_FILE] não está definida e nenhum perfil está ativo.Defina todas as quatro variáveis ou configure um perfil.
O SDK autentica com uma chave de API em vez de federarANTHROPIC_API_KEY ou ANTHROPIC_AUTH_TOKEN está definida e vence na precedência.Remova a definição da variável de chave ou token.
FileNotFoundError na primeira requisiçãoO caminho em ANTHROPIC_IDENTITY_TOKEN_FILE não existe. O SDK abre o arquivo de forma lazy no momento da troca.Confirme que o volume de token projetado está montado e que o caminho corresponde.
A troca de token é bem-sucedida, mas uma requisição à API do Claude retorna 403

Solucionar problemas de uma troca com falha

Uma resposta 400 invalid_grant é intencionalmente opaca; a causa específica é registrada apenas no lado do servidor.

Comece pela página de histórico de autenticação no Claude Console. Tentativas de troca recentes exibem o emissor e a regra que foram avaliados, as claims do JWT que foram inspecionadas e qual etapa de validação falhou, o que geralmente dispensa as verificações a seguir.

Se você ainda precisar depurar a partir do próprio JWT, siga estas verificações em ordem:

Modos de origem do JWKS

Quando você registra um emissor de federação, o campo jwks controla como a Anthropic obtém as chaves públicas usadas para verificar assinaturas de JWT desse emissor. É uma união discriminada com chave em type:

jwks.typeFormato de jwksComportamentoUse quando
discovery (padrão){ "type": "discovery", "discovery_base": "https://..." } (discovery_base é opcional; defina-o quando a URL de discovery diferir de issuer_url)A Anthropic busca <discovery_base or issuer_url>/.well-known/openid-configuration, lê jwks_uri do documento de discovery e busca o JWKS a partir dele.Seu IdP serve um documento de discovery OIDC padrão na internet pública. A maioria dos provedores gerenciados (EKS, GKE, Cloud Run, GitHub Actions, Entra ID) suporta isso.
explicit_url{ "type": "explicit_url", "url": "https://..." }A Anthropic busca o JWKS diretamente de url. O é usado apenas para comparação de string com a claim do JWT e nunca é acessado.

A união discriminada torna os campos complementares mutuamente exclusivos por construção. Tanto discovery quanto explicit_url também aceitam uma string opcional ca_cert_pem para emissores que servem TLS a partir de uma CA privada.

Rotação de chaves e cache

Nos modos discovery e explicit_url, a Anthropic armazena em cache o JWKS buscado. Se seu provedor de identidade publicar uma nova chave de assinatura e imediatamente começar a assinar tokens com ela, trocas que apresentam esses tokens podem falhar com erro de assinatura por até um minuto enquanto o cache é atualizado.

Para evitar essa janela, publique uma nova chave de assinatura no JWKS pelo menos 15 minutos antes de seu provedor de identidade começar a assinar tokens com ela, e mantenha a chave substituída no JWKS até que os tokens assinados por ela tenham expirado. Provedores de identidade gerenciados normalmente seguem essa disciplina por conta própria. Se você opera seu próprio emissor (um cluster Kubernetes autogerenciado, um provedor de discovery OIDC SPIRE ou um servidor de autorização personalizado do Okta com cadência de rotação configurada), confirme que sua política de rotação publica novas chaves antes do primeiro uso.

No modo inline não há atualização automática de chaves. Quando seu provedor de identidade rotaciona suas chaves de assinatura, você deve atualizar a configuração do emissor com o novo JWKS ou todas as trocas de token falharão na verificação de assinatura.

Was this page helpful?

  • Requisição de troca de token
  • Resposta da troca de token
  • Variáveis de ambiente
  • Precedência de credenciais
  • Arquivo de configuração de perfil
  • Diretório de configuração
  • Perfil ativo
  • Layout de arquivos
  • Exemplo de perfil de federação
  • Escopos OAuth
  • Regras de validação
  • Campos de recurso
  • Campos de URL
  • Verificação de JWT
  • Semântica de correspondência de regras
  • Ambiente de avaliação CEL
  • Erros
  • Erros de troca de token
  • Falhas comuns do lado do SDK
  • Solucionar problemas de uma troca com falha
  • Modos de origem do JWKS
  • Rotação de chaves e cache
ANTHROPIC_IDENTITY_TOKENUma entre _TOKEN_FILE ou _TOKENO JWT literal como string. Use quando sua plataforma injeta o token como variável de ambiente em vez de arquivo.eyJhbGciOiJSUzI1NiIs...
ANTHROPIC_SERVICE_ACCOUNT_IDSimID com tag da conta de serviço Anthropic de destino em nome da qual o token de acesso emitido atua.svac_...
ANTHROPIC_WORKSPACE_IDCondicionalID com tag do workspace ao qual o token emitido será restrito, ou o literal default. Obrigatório quando a regra de federação está habilitada para mais de um workspace; opcional quando a regra está vinculada a um único workspace. O token emitido é restrito a esse workspace no momento da troca, portanto alternar entre workspaces requer uma nova troca.wrkspc_...
ANTHROPIC_PROFILENãoNome de um perfil de configuração a ser carregado. Tem precedência sobre as variáveis de ambiente de federação nesta tabela.staging-profile
ANTHROPIC_SERVICE_ACCOUNT_ID
ANTHROPIC_IDENTITY_TOKEN[_FILE]
5Perfil ativoResolvido a partir de <config_dir>/active_config, com fallback para um perfil chamado default.
exp
iat
Desvio de relógioUma tolerância de 30 segundos é aplicada a exp, nbf e iat.
conditionstring (CEL)Uma expressão CEL que deve avaliar como true.
invalid_grant
A claim iss do JWT não é exatamente igual ao issuer_url registrado.
Compare byte a byte, incluindo barras finais e esquema: jq -rR 'split(".")[1] | gsub("-";"+") | gsub("_";"/") | @base64d | fromjson | .iss' <<< "$JWT".
400invalid_grantA busca do JWKS falhou, o JWKS está desatualizado ou o JWT foi assinado com uma chave que não está no JWKS.Para o modo inline, atualize o emissor com as chaves rotacionadas. Para discovery e explicit_url, confirme que o endpoint JWKS está acessível na porta 443; se o emissor rotacionou recentemente sua chave de assinatura, consulte Rotação de chaves e cache.
400invalid_grantA claim exp do JWT está no passado (além da janela de tolerância de 30 segundos).Confirme que seu provedor de identidade está projetando um token atualizado e que o SDK está relendo o arquivo de token.
400invalid_grantO JWT foi verificado, mas suas claims não satisfazem o bloco match da regra.Decodifique o JWT e compare cada claim com a regra. subject_prefix é sensível a maiúsculas e minúsculas. audience requer correspondência exata de elemento.
400invalid_grantO federation_rule_id não existe, está arquivado ou o JWT não está autorizado para ele (consolidado para evitar enumeração).Confirme o ID da regra no Claude Console e que a regra não foi arquivada.
O escopo do token emitido não concede acesso a esse endpoint.
Verifique o oauth_scope da regra em Escopos OAuth.
A autenticação falha com credencial vaziaUma variável de ambiente de credencial está exportada, mas definida como string vazia. Valores vazios ainda vencem em seu lugar de precedência.Remova a definição da variável com unset VAR em vez de VAR="".
  1. 1

    Decodifique o JWT

    Decodifique a assertion que você enviou para poder comparar cada claim com a configuração do seu emissor e da regra:

    cURL
    jq -rR 'split(".")[1] | gsub("-";"+") | gsub("_";"/") | @base64d | fromjson' <<< "$JWT"
  2. 2

    Verifique se iss corresponde ao emissor

    A claim iss decodificada deve ser igual ao issuer_url registrado byte a byte, incluindo esquema, porta e qualquer barra final. Uma diferença em um único caractere faz a verificação falhar.

  3. 3

    Verifique se aud corresponde à regra

    A claim aud decodificada deve conter o valor audience da regra como correspondência exata. Quando aud é um array, um elemento deve corresponder exatamente.

  4. 4

    Verifique sub e cada entrada de claims

    Compare sub com o subject_prefix da regra (sensível a maiúsculas e minúsculas; um * no final é uma correspondência de prefixo, qualquer outra coisa é exata). Compare cada chave no mapa claims da regra com a claim de nível superior de mesmo nome.

  5. 5

    Verifique exp, nbf e iat

    exp deve estar no futuro e nbf/iat devem estar no passado, dentro da janela de tolerância de 30 segundos. Se o relógio do host da carga de trabalho tiver desviado, um token que de outra forma seria válido é rejeitado.

  6. 6

    Verifique a acessibilidade do JWKS

    Para o modo discovery, busque <jwks.discovery_base or issuer_url>/.well-known/openid-configuration via HTTPS público na porta 443 e confirme que jwks_uri resolve. Para explicit_url, busque a URL do JWKS diretamente. Para inline, confirme que a chave de assinatura do emissor não foi rotacionada desde que você registrou as chaves.

    Se o emissor rotacionou sua chave de assinatura e imediatamente começou a assinar com ela, as trocas podem falhar por até um minuto enquanto o cache de JWKS da Anthropic é atualizado. Consulte Rotação de chaves e cache.

issuer_url
iss
Seu IdP não serve um documento de discovery, ou o discovery é apenas interno mas o JWKS é acessível publicamente.
inline{ "type": "inline", "keys": [...] }Você fornece o array de objetos JWK inline (o array keys do documento JWKS, não o objeto wrapper). A Anthropic não faz nenhuma requisição externa. O issuer_url é usado apenas para comparação de iss.Ambientes air-gapped, clusters Kubernetes autogerenciados com URLs de emissor internas ao cluster, ou quando você quer controle explícito sobre a rotação de chaves.