Sample code for 30+ languages & platforms
Tcl

UPS OAuth2 Client Credentials

See more UPS Examples

Get an OAuth2 access token for the UPS REST API using the client credentials flow (no interactivity with a web browser required).

Chilkat Tcl Downloads

Tcl

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]

# Implements the following CURL command:

# curl -i -X POST \
#   -u 2498righ8wr6aihe98rt8rhowirtyw9er6twe80rtywrehrt:nerf254578uh8rgt7y3h57358ouyth387h8h53h6yyh80hh578per9y7u5ruyuy4 \
#   https://wwwcie.ups.com/security/v1/oauth/token \
#   -H 'Content-Type: application/x-www-form-urlencoded' \
#   -H 'x-merchant-id: 7B3027' \
#   -d grant_type=client_credentials

# Use the following online tool to generate HTTP code from a CURL command
# Convert a cURL Command to HTTP Source Code

CkHttp_put_BasicAuth $http 1
CkHttp_put_Login $http "2498righ8wr6aihe98rt8rhowirtyw9er6twe80rtywrehrt"
CkHttp_put_Password $http "nerf254578uh8rgt7y3h57358ouyth387h8h53h6yyh80hh578per9y7u5ruyuy4"

set req [new_CkHttpRequest]

CkHttpRequest_AddParam $req "grant_type" "client_credentials"

CkHttpRequest_AddHeader $req "x-merchant-id" "7B3027"

CkHttpRequest_put_HttpVerb $req "POST"
CkHttpRequest_put_ContentType $req "application/x-www-form-urlencoded"

set resp [new_CkHttpResponse]

set success [CkHttp_HttpReq $http "https://wwwcie.ups.com/security/v1/oauth/token" $req $resp]
if {$success == 0} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkHttp $http
    delete_CkHttpRequest $req
    delete_CkHttpResponse $resp
    exit
}

set sbResponseBody [new_CkStringBuilder]

CkHttpResponse_GetBodySb $resp $sbResponseBody

set jResp [new_CkJsonObject]

CkJsonObject_LoadSb $jResp $sbResponseBody
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_CkHttpRequest $req
    delete_CkHttpResponse $resp
    delete_CkStringBuilder $sbResponseBody
    delete_CkJsonObject $jResp
    exit
}

# Save the OAuth2 access token for other examples to use.
CkJsonObject_WriteFile $jResp "qa_data/tokens/ups_oauth2_token.json"

# If successful, the OAuth2 access token JSON looks like this:

# {
#   "token_type": "Bearer",
#   "issued_at": "1686911985606",
#   "client_id": "2498righ8wr6aihe98rt8rhowirtyw9er6twe80rtywrehrt",
#   "access_token": "eyJraW......R2sbqrY",
#   "expires_in": "14399",
#   "status": "approved"
# }

set token_type [CkJsonObject_stringOf $jResp "token_type"]
set issued_at [CkJsonObject_stringOf $jResp "issued_at"]
set client_id [CkJsonObject_stringOf $jResp "client_id"]
set access_token [CkJsonObject_stringOf $jResp "access_token"]
set expires_in [CkJsonObject_stringOf $jResp "expires_in"]
set status [CkJsonObject_stringOf $jResp "status"]

delete_CkHttp $http
delete_CkHttpRequest $req
delete_CkHttpResponse $resp
delete_CkStringBuilder $sbResponseBody
delete_CkJsonObject $jResp