Sample code for 30+ languages & platforms
Tcl

Get a Google Drive Access Token using a .p12 Private Key

See more Google Drive Examples

Demonstrates how to get a Google Drive API access token using a .p12 private key.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

set gAuth [new_CkAuthGoogle]

set pfx [new_CkPfx]

set success [CkPfx_LoadPfxFile $pfx "qa_data/googleApi/ChilkatTest-5ba79ce39459.p12" "notasecret"]
if {$success != 1} then {
    puts [CkPfx_lastErrorText $pfx]
    delete_CkAuthGoogle $gAuth
    delete_CkPfx $pfx
    exit
}

set success [CkAuthGoogle_SetP12 $gAuth $pfx]
if {$success != 1} then {
    puts [CkAuthGoogle_lastErrorText $gAuth]
    delete_CkAuthGoogle $gAuth
    delete_CkPfx $pfx
    exit
}

# Choose a scope.
CkAuthGoogle_put_Scope $gAuth "https://www.googleapis.com/auth/drive"

# Request an access token that is valid for this many seconds.
CkAuthGoogle_put_ExpireNumSeconds $gAuth 3600

# If the application is requesting delegated access:
# The email address of the user for which the application is requesting delegated access,
# then set the email address here. (Otherwise leave it empty.)
CkAuthGoogle_put_SubEmailAddress $gAuth "support@chilkatcloud.com"

CkAuthGoogle_put_EmailAddress $gAuth "597922945226-00rb0ppfg0snd9jo6bhvd4v17jtj2d3a@developer.gserviceaccount.com"

# Connect to www.googleapis.com using TLS (TLS 1.2 is the default.)
# The Chilkat socket object is used so that the connection can be established
# through proxies or an SSH tunnel if desired.
set tlsSock [new_CkSocket]

set success [CkSocket_Connect $tlsSock "www.googleapis.com" 443 1 5000]
if {$success != 1} then {
    puts [CkSocket_lastErrorText $tlsSock]
    delete_CkAuthGoogle $gAuth
    delete_CkPfx $pfx
    delete_CkSocket $tlsSock
    exit
}

# Send the request to obtain the access token.
set success [CkAuthGoogle_ObtainAccessToken $gAuth $tlsSock]
if {$success != 1} then {
    puts [CkAuthGoogle_lastErrorText $gAuth]
    delete_CkAuthGoogle $gAuth
    delete_CkPfx $pfx
    delete_CkSocket $tlsSock
    exit
}

# Examine the access token:
puts "Access Token: [CkAuthGoogle_accessToken $gAuth]"

delete_CkAuthGoogle $gAuth
delete_CkPfx $pfx
delete_CkSocket $tlsSock