VBScript
VBScript
Automatically Refresh Token for 401 Unauthorized
See more Google Calendar Examples
Demonstrates how to automatically refresh an access token (without user interaction) when the token expires and a 401 Unauthorized response is received.Chilkat VBScript Downloads
Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)
success = 0
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
tokenFilePath = "qa_data/tokens/googleCalendar.json"
' Get our current access token.
set jsonToken = CreateObject("Chilkat.JsonObject")
success = jsonToken.LoadFile(tokenFilePath)
If (jsonToken.HasMember("access_token") = 0) Then
outFile.WriteLine("No access token found.")
WScript.Quit
End If
set http = CreateObject("Chilkat.Http")
http.AuthToken = jsonToken.StringOf("access_token")
jsonResponse = http.QuickGetStr("https://www.googleapis.com/calendar/v3/users/me/calendarList")
If (http.LastMethodSuccess <> 1) Then
If (http.LastStatus <> 401) Then
outFile.WriteLine(http.LastErrorText)
outFile.WriteLine("----")
outFile.WriteLine(http.LastResponseBody)
WScript.Quit
End If
' The access token must've expired.
' Refresh the access token and then retry the request.
set oauth2 = CreateObject("Chilkat.OAuth2")
oauth2.TokenEndpoint = "https://www.googleapis.com/oauth2/v4/token"
' Replace these with actual values.
oauth2.ClientId = "GOOGLE-CLIENT-ID"
oauth2.ClientSecret = "GOOGLE-CLIENT-SECRET"
' Get the "refresh_token"
oauth2.RefreshToken = jsonToken.StringOf("refresh_token")
' Send the HTTP POST to refresh the access token..
success = oauth2.RefreshAccessToken()
If (success <> 1) Then
outFile.WriteLine(oauth2.LastErrorText)
WScript.Quit
End If
' The response contains a new access token, but we must keep
' our existing refresh token for when we need to refresh again in the future.
success = jsonToken.UpdateString("access_token",oauth2.AccessToken)
' Save the new JSON access token response to a file.
set sbJson = CreateObject("Chilkat.StringBuilder")
jsonToken.EmitCompact = 0
success = jsonToken.EmitSb(sbJson)
success = sbJson.WriteFile(tokenFilePath,"utf-8",0)
outFile.WriteLine("OAuth2 authorization granted!")
outFile.WriteLine("New Access Token = " & oauth2.AccessToken)
' re-try the original request.
http.AuthToken = oauth2.AccessToken
jsonResponse = http.QuickGetStr("https://www.googleapis.com/calendar/v3/users/me/calendarList")
If (http.LastMethodSuccess <> 1) Then
outFile.WriteLine(http.LastErrorText)
WScript.Quit
End If
End If
outFile.WriteLine(jsonResponse)
outFile.WriteLine("-----------------------------")
outFile.Close