VBScript
VBScript
Get GMail Message Metadata
See more GMail REST API Examples
Demonstrates how to get the metadata for each message in a list of message IDs.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.
set http = CreateObject("Chilkat.Http")
http.AuthToken = "ACCESS_TOKEN"
http.Accept = "application/json"
' Let's say we have the following JSON containing a list of message ID's
' {
' "messages": [
' {
' "id": "1712bc1dc22da2a2",
' "threadId": "1712bc1dc22da2a2"
' },
' {
' "id": "1712b94fa2168040",
' "threadId": "1712b94fa2168040"
' },
' {
' "id": "1711e4bd96ded05e",
' "threadId": "1711e4bd96ded05e"
' },
' {
' "id": "1711de0d119e751e",
' "threadId": "1711de0d119e751e"
' },
' {
' "id": "1711c81a43050f59",
' "threadId": "1711c81a43050f59"
' },
' {
' "id": "1711c2c1516abce5",
' "threadId": "1711c2c1516abce5"
' },
' {
' "id": "1711c161e655c915",
' "threadId": "1711c161e655c915"
' },
' {
' "id": "171199c6e454558c",
' "threadId": "171199c6e454558c"
' },
' {
' "id": "17119474c8aa248e",
' "threadId": "17119474c8aa248e"
' }
' ],
' "nextPageToken": "16710921492249671162",
' "resultSizeEstimate": 309
' }
' Normally your program would have the above JSON in a string variable (obtained from a previous call to get
' a list of message IDs from a GMail mailbox). In this example, we'll load the JSON from a file.
set jsonMsgIds = CreateObject("Chilkat.JsonObject")
success = jsonMsgIds.LoadFile("qa_data/json/gmail_message_ids.json")
set resp = CreateObject("Chilkat.HttpResponse")
i = 0
count_i = jsonMsgIds.SizeOfArray("messages")
Do While i < count_i
jsonMsgIds.I = i
id = jsonMsgIds.StringOf("messages[i].id")
' Get the metadata for this message ID.
success = http.SetUrlVar("id",id)
success = http.HttpNoBody("GET","https://www.googleapis.com/gmail/v1/users/userId/messages/{$id}?format=metadata",resp)
If (success = 0) Then
outFile.WriteLine(http.LastErrorText)
WScript.Quit
End If
outFile.WriteLine("Response Status Code: " & resp.StatusCode)
set jsonResponse = CreateObject("Chilkat.JsonObject")
success = jsonResponse.Load(resp.BodyStr)
jsonResponse.EmitCompact = 0
outFile.WriteLine(jsonResponse.Emit())
If (resp.StatusCode <> 200) Then
outFile.WriteLine("Failed.")
WScript.Quit
End If
i = i + 1
Loop
' Use this online tool to generate parsing code from sample JSON:
' Generate Parsing Code from JSON
outFile.Close