PureBasic
PureBasic
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 PureBasic Downloads
IncludeFile "CkSocket.pb"
IncludeFile "CkAuthGoogle.pb"
IncludeFile "CkPfx.pb"
Procedure ChilkatExample()
success.i = 0
; This example requires the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.
gAuth.i = CkAuthGoogle::ckCreate()
If gAuth.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
pfx.i = CkPfx::ckCreate()
If pfx.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success = CkPfx::ckLoadPfxFile(pfx,"qa_data/googleApi/ChilkatTest-5ba79ce39459.p12","notasecret")
If success <> 1
Debug CkPfx::ckLastErrorText(pfx)
CkAuthGoogle::ckDispose(gAuth)
CkPfx::ckDispose(pfx)
ProcedureReturn
EndIf
success = CkAuthGoogle::ckSetP12(gAuth,pfx)
If success <> 1
Debug CkAuthGoogle::ckLastErrorText(gAuth)
CkAuthGoogle::ckDispose(gAuth)
CkPfx::ckDispose(pfx)
ProcedureReturn
EndIf
; Choose a scope.
CkAuthGoogle::setCkScope(gAuth, "https://www.googleapis.com/auth/drive")
; Request an access token that is valid for this many seconds.
CkAuthGoogle::setCkExpireNumSeconds(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::setCkSubEmailAddress(gAuth, "support@chilkatcloud.com")
CkAuthGoogle::setCkEmailAddress(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.
tlsSock.i = CkSocket::ckCreate()
If tlsSock.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success = CkSocket::ckConnect(tlsSock,"www.googleapis.com",443,1,5000)
If success <> 1
Debug CkSocket::ckLastErrorText(tlsSock)
CkAuthGoogle::ckDispose(gAuth)
CkPfx::ckDispose(pfx)
CkSocket::ckDispose(tlsSock)
ProcedureReturn
EndIf
; Send the request to obtain the access token.
success = CkAuthGoogle::ckObtainAccessToken(gAuth,tlsSock)
If success <> 1
Debug CkAuthGoogle::ckLastErrorText(gAuth)
CkAuthGoogle::ckDispose(gAuth)
CkPfx::ckDispose(pfx)
CkSocket::ckDispose(tlsSock)
ProcedureReturn
EndIf
; Examine the access token:
Debug "Access Token: " + CkAuthGoogle::ckAccessToken(gAuth)
CkAuthGoogle::ckDispose(gAuth)
CkPfx::ckDispose(pfx)
CkSocket::ckDispose(tlsSock)
ProcedureReturn
EndProcedure