Skip to content
Last updated

Renovando seu Access Token (Essencial para Acesso Contínuo) 🔑

Realizadas as etapas 1 e 2, agora você precisará compreender como utilizar o refresh_token. O access_token é uma credencial temporária, projetada para expirar após 1 hora. Para garantir que sua integração continue funcionando sem interrupções e sem precisar passar por todo o processo de autorização novamente, o protocolo OAuth 2.0 oferece um mecanismo de renovação usando o refresh_token.


Como realizar?

Quando seu access_token expirar (após o tempo informado em expires_in — tempo em segundos), você deve renová-lo:

curl --location 'https://auth.contaazul.com/oauth2/token' \
--header 'Authorization: Basic BASE64(SEU_CLIENT_ID:SEU_CLIENT_SECRET)' \
--header 'Content-Type: application/x-www-form-urlencoded' \
--data-urlencode 'refresh_token=REFRESH_TOKEN_GERADO' \
--data-urlencode 'grant_type=refresh_token'

Exemplo de resposta

{
  "access_token": "NOVO_ACCESS_TOKEN",
  "expires_in": 3600,
  "refresh_token": "NOVO_REFRESH_TOKEN",
  "token_type": "Bearer"
}

⚠️ Atenção

Sempre guarde o novo refresh_token, pois ele muda após cada renovação.

Com o cURL acima, você observará os parâmetros que informam ao servidor de autorização sobre sua solicitação:

ParâmetrosValorValor Fixo?FinalidadeDescrição
grant_typerefresh_tokenSimIndica que você está solicitando um novo access_token usando um refresh_token
client_idDisponível nos detalhes da sua integração no Portal do DesenvolvedorNãoIdentificador único do aplicativo
client_secretDisponível nos detalhes da sua integração no Portal do DesenvolvedorNãoIdentificador que comprova a identidade do aplicativo
AuthorizationBasic BASE64(client_id:client_secre)NãoEste é um cabeçalho HTTP necessário. Ele contém seu client_id e client_secret combinados (client_id:client_secret) e codificados em Base64Para mais detalhes sobre a codificação em Base64, consulte o guia FAQ desta documentação
REFRESH_TOKEN_GERADOrefresh_token obtido na etapa anterior do fluxo OAuth 2.0NãoPermite que sua aplicação obtenha um novo access_token após o token original expirarÉ crucial que o refresh_token seja exatamente o mesmo recebido na etapa anterior