VBScript
VBScript
Wasabi List Bucket Objects
See more Wasabi Examples
Demonstrates how to download and parse XML for the list of objects in a bucket.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 assumes the Chilkat HTTP API to have been previously unlocked.
' See Global Unlock Sample for sample code.
set http = CreateObject("Chilkat.Http")
' Insert your access key here:
http.AwsAccessKey = "access-key"
' Insert your secret key here:
http.AwsSecretKey = "secret-key"
' Use the endpoint matching the bucket's region.
http.AwsEndpoint = "s3.us-west-1.wasabisys.com"
bucketName = "chilkattest"
strXml = http.S3_ListBucketObjects(bucketName)
If (http.LastMethodSuccess <> 1) Then
outFile.WriteLine(http.LastErrorText)
WScript.Quit
End If
outFile.WriteLine("Response status code = " & http.LastStatus)
set xml = CreateObject("Chilkat.Xml")
success = xml.LoadXml(strXml)
If (success <> 1) Then
outFile.WriteLine(xml.LastErrorText)
WScript.Quit
End If
' If the response status code was not 200, then the XML response is not a
' listing of objects, but instead contains error information.
If (http.LastStatus <> 200) Then
outFile.WriteLine(xml.GetXml())
outFile.WriteLine("Failed.")
WScript.Quit
End If
' A sample response is shown below.
outFile.WriteLine(xml.GetXml())
outFile.WriteLine("----")
' Use this online tool to generate parsing code from sample XML:
' Generate Parsing Code from XML
' <?xml version="1.0" encoding="UTF-8"?>
' <ListBucketResult xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
' <Name>chilkattest</Name>
' <Prefix/>
' <Marker/>
' <MaxKeys>1000</MaxKeys>
' <IsTruncated>false</IsTruncated>
' <Contents>
' <Key>orchard.json</Key>
' <LastModified>2021-10-27T22:58:49.000Z</LastModified>
' <ETag>"303fb46cf341094fef6274b7789cd6aa"</ETag>
' <Size>22</Size>
' <Owner>
' <ID>1039F31570DBC320E89D391632FCA06FE6D10CBB2ADBD0BF6439BB1DA0C3FAD6</ID>
' <DisplayName>admin</DisplayName>
' </Owner>
' <StorageClass>STANDARD</StorageClass>
' </Contents>
' <Contents>
' <Key>seahorse.jpg</Key>
' <LastModified>2021-10-27T22:35:29.000Z</LastModified>
' <ETag>"a8551f0a5437f43a796fca7623ee9232"</ETag>
' <Size>24388</Size>
' <Owner>
' <ID>1039F31570DBC320E89D391632FCA06FE6D10CBB2ADBD0BF6439BB1DA0C3FAD6</ID>
' <DisplayName>admin</DisplayName>
' </Owner>
' <StorageClass>STANDARD</StorageClass>
' </Contents>
' <Contents>
' <Key>seahorse2.jpg</Key>
' <LastModified>2021-10-27T22:03:51.000Z</LastModified>
' <ETag>"a8551f0a5437f43a796fca7623ee9232"</ETag>
' <Size>24388</Size>
' <Owner>
' <ID>1039F31570DBC320E89D391632FCA06FE6D10CBB2ADBD0BF6439BB1DA0C3FAD6</ID>
' <DisplayName>admin</DisplayName>
' </Owner>
' <StorageClass>STANDARD</StorageClass>
' </Contents>
' </ListBucketResult>
ListBucketResult_xmlns = xml.GetAttrValue("xmlns")
Name = xml.GetChildContent("Name")
MaxKeys = xml.GetChildIntValue("MaxKeys")
IsTruncated = xml.GetChildContent("IsTruncated")
i = 0
count_i = xml.NumChildrenHavingTag("Contents")
Do While i < count_i
xml.I = i
Key = xml.GetChildContent("Contents[i]|Key")
LastModified = xml.GetChildContent("Contents[i]|LastModified")
ETag = xml.GetChildContent("Contents[i]|ETag")
SizeDecimalStr = xml.GetChildContent("Contents[i]|Size")
ID = xml.GetChildContent("Contents[i]|Owner|ID")
DisplayName = xml.GetChildContent("Contents[i]|Owner|DisplayName")
StorageClass = xml.GetChildContent("Contents[i]|StorageClass")
outFile.WriteLine(i & ": " & Key)
i = i + 1
Loop
outFile.Close