Tcl
Tcl
Banco Inter OAuth2 Client Credentials
Generate an OAuth2 access token needed to consume the Inter APIs.Chilkat Tcl Downloads
load ./chilkat.dll
set success 0
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
set http [new_CkHttp]
# First load the certificate and private key, and set as the HTTP object's client certificate.
set cert [new_CkCert]
set success [CkCert_LoadFromFile $cert "<nome arquivo certificado>.crt"]
if {$success == 0} then {
puts [CkCert_lastErrorText $cert]
delete_CkHttp $http
delete_CkCert $cert
exit
}
set bdPrivKey [new_CkBinData]
set success [CkBinData_LoadFile $bdPrivKey "<nome arquivo chave privada>.key"]
if {$success == 0} then {
puts "Failed to load <nome"
delete_CkHttp $http
delete_CkCert $cert
delete_CkBinData $bdPrivKey
exit
}
set privKey [new_CkPrivateKey]
set success [CkPrivateKey_LoadAnyFormat $privKey $bdPrivKey ""]
if {$success == 0} then {
puts [CkPrivateKey_lastErrorText $privKey]
delete_CkHttp $http
delete_CkCert $cert
delete_CkBinData $bdPrivKey
delete_CkPrivateKey $privKey
exit
}
set success [CkCert_SetPrivateKey $cert $privKey]
if {$success == 0} then {
puts [CkCert_lastErrorText $cert]
delete_CkHttp $http
delete_CkCert $cert
delete_CkBinData $bdPrivKey
delete_CkPrivateKey $privKey
exit
}
set success [CkHttp_SetSslClientCert $http $cert]
if {$success == 0} then {
puts [CkHttp_lastErrorText $http]
delete_CkHttp $http
delete_CkCert $cert
delete_CkBinData $bdPrivKey
delete_CkPrivateKey $privKey
exit
}
set req [new_CkHttpRequest]
CkHttpRequest_put_HttpVerb $req "POST"
CkHttpRequest_put_Path $req "/oauth/v2/token"
CkHttpRequest_put_ContentType $req "application/x-www-form-urlencoded"
CkHttpRequest_AddParam $req "grant_type" "client_credentials"
# Requested scopes in OAuth2 are typically SPACE separated.
CkHttpRequest_AddParam $req "scope" "boleto-cobranca.read boleto-cobranca.write"
CkHttpRequest_AddHeader $req "accept" "application/json"
set resp [new_CkHttpResponse]
set success [CkHttp_HttpReq $http "https://cdpj.partners.bancointer.com.br/oauth/v2/token" $req $resp]
if {$success == 0} then {
puts [CkHttp_lastErrorText $http]
delete_CkHttp $http
delete_CkCert $cert
delete_CkBinData $bdPrivKey
delete_CkPrivateKey $privKey
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
exit
}
set jResp [new_CkJsonObject]
CkHttpResponse_GetBodyJson $resp $jResp
CkJsonObject_put_EmitCompact $jResp 0
puts "Response Body:"
puts [CkJsonObject_emit $jResp]
set respStatusCode [CkHttpResponse_get_StatusCode $resp]
puts "Response Status Code = $respStatusCode"
if {$respStatusCode >= 400} then {
puts "Response Header:"
puts [CkHttpResponse_header $resp]
puts "Failed."
delete_CkHttp $http
delete_CkCert $cert
delete_CkBinData $bdPrivKey
delete_CkPrivateKey $privKey
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
delete_CkJsonObject $jResp
exit
}
set success [CkJsonObject_WriteFile $jResp "qa_data/tokens/banco_inter_client_credentials.json"]
if {$success == 0} then {
puts "Failed to save JSON access token file."
delete_CkHttp $http
delete_CkCert $cert
delete_CkBinData $bdPrivKey
delete_CkPrivateKey $privKey
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
delete_CkJsonObject $jResp
exit
}
puts "Success."
delete_CkHttp $http
delete_CkCert $cert
delete_CkBinData $bdPrivKey
delete_CkPrivateKey $privKey
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
delete_CkJsonObject $jResp