VBScript
VBScript
Amazon Glacier Get Vault Access Policy
See more Amazon Glacier Examples
Demonstrates how to retrieve the access-policy subresource set on the vaultChilkat 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 rest = CreateObject("Chilkat.Rest")
' Connect to the Amazon AWS REST server in the desired region.
bTls = 1
port = 443
bAutoReconnect = 1
success = rest.Connect("glacier.us-west-2.amazonaws.com",port,bTls,bAutoReconnect)
' Provide AWS credentials.
set authAws = CreateObject("Chilkat.AuthAws")
authAws.AccessKey = "AWS_ACCESS_KEY"
authAws.SecretKey = "AWS_SECRET_KEY"
authAws.ServiceName = "glacier"
authAws.Region = "us-west-2"
success = rest.SetAuthAws(authAws)
' --------------------------------------------------------------------------
' Note: The above REST connection and setup of the AWS credentials
' can be done once. After connecting, any number of REST calls can be made.
' The "auto reconnect" property passed to rest.Connect indicates that if
' the connection is lost, a REST method call will automatically reconnect
' if needed.
' --------------------------------------------------------------------------
'
' For more information, see Glacier Get Vault Access Policy Reference Documentation
'
success = rest.AddHeader("x-amz-glacier-version","2012-06-01")
' Get the access policy for the "chilkat" vault.
set sbResponseBody = CreateObject("Chilkat.StringBuilder")
success = rest.FullRequestNoBodySb("GET","/AWS_ACCOUNT_ID/vaults/chilkat/access-policy",sbResponseBody)
If (success <> 1) Then
outFile.WriteLine(rest.LastErrorText)
WScript.Quit
End If
respStatusCode = rest.ResponseStatusCode
If (respStatusCode >= 400) Then
outFile.WriteLine("Response Status Code = " & respStatusCode)
outFile.WriteLine("Response Header:")
outFile.WriteLine(rest.ResponseHeader)
outFile.WriteLine("Response Body:")
outFile.WriteLine(sbResponseBody.GetAsString())
WScript.Quit
End If
' Success is indicated by a 200 response status.
outFile.WriteLine("response status code = " & respStatusCode)
set json = CreateObject("Chilkat.JsonObject")
success = json.LoadSb(sbResponseBody)
json.EmitCompact = 0
' Returns JSON such as this:
' {
' "Policy": "{\"Version\":\"2012-10-17\",\"Statement\":[{\"Sid\":\"Define-owner-access-rights\",\"Effect\":\"Allow\",\"Principal\":{\"AWS\":\"arn:aws:iam::9999999999999:root\"},\"Action\":\"glacier:DeleteArchive\",\"Resource\":\"arn:aws:glacier:us-west-2:9999999999999:vaults/chilkat\"}]}"
' }
' Unwrap...
set jsonPolicy = CreateObject("Chilkat.JsonObject")
success = jsonPolicy.Load(json.StringOf("Policy"))
jsonPolicy.EmitCompact = 0
outFile.WriteLine(jsonPolicy.Emit())
outFile.WriteLine("----")
' The jsonPolicy contains:
' {
' "Version": "2012-10-17",
' "Statement": [
' {
' "Sid": "Define-owner-access-rights",
' "Effect": "Allow",
' "Principal": {
' "AWS": "arn:aws:iam::9999999999999:root"
' },
' "Action": "glacier:DeleteArchive",
' "Resource": "arn:aws:glacier:us-west-2:9999999999999:vaults/chilkat"
' }
' ]
' }
'
' Use this online tool to generate parsing code from sample JSON:
' Generate Parsing Code from JSON
' To parse the above contents of jsonPolicy...
Version = jsonPolicy.StringOf("Version")
i = 0
count_i = jsonPolicy.SizeOfArray("Statement")
Do While i < count_i
jsonPolicy.I = i
Sid = jsonPolicy.StringOf("Statement[i].Sid")
Effect = jsonPolicy.StringOf("Statement[i].Effect")
PrincipalAWS = jsonPolicy.StringOf("Statement[i].Principal.AWS")
Action = jsonPolicy.StringOf("Statement[i].Action")
Resource = jsonPolicy.StringOf("Statement[i].Resource")
i = i + 1
Loop
outFile.Close