Classic ASP
Classic ASP
AWS Secrets Manager - List Matching Secrets
See more Secrets Examples
List secrets in the AWS Secrets Manager matching one or more wildcarded names for app, service, domain, and username.Note: This example requires Chilkat v10.1.0 or later.
Chilkat Classic ASP Downloads
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
' The bootstrap secret will contain the following information:
' AWS Region
' AWS Access Key
' AWS Secret Key
' See following examples for setting up a bootstrap secret in memory,
' or in the local manager (Windows Credentials Manager or Apple Keychain)
' Setup Bootstrap Secret in Local Manager
' Setup Bootstrap Secret in Memory
set bootstrap = Server.CreateObject("Chilkat.Secrets")
' Set the location of the bootstrap secret.
' Can be "local_manager" or "memory", depending on how you setup the bootstrap secret.
' ---------------------------------------------------------------------------------------------
' If your operating system is NOT Windows or MacOS/iOS, then change "local_manager" to "memory"
' You can also, if desired, use "memory" on Windows and MacOS/iOS if your bootstrap secret was previously setup in memory.
' ---------------------------------------------------------------------------------------------
bootstrap.Location = "local_manager"
' Specify the bootstrap secret to be used.
set bsId = Server.CreateObject("Chilkat.JsonObject")
success = bsId.UpdateString("appName","AWS")
success = bsId.UpdateString("service","Example")
success = bsId.UpdateString("username","Joe")
' ----------------------------------------------------
set secrets = Server.CreateObject("Chilkat.Secrets")
' Setup for the AWS Secrets Manager
secrets.Location = "aws_secrets_manager"
success = secrets.SetBootstrapSecret(bsId,bootstrap)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( secrets.LastErrorText) & "</pre>"
Response.End
End If
' Set wildcarded or exact values for appName, service, domain, and username.
' Omit any members where anything is allowed to match, or alternatively specify "*" to match anything.
set jsonMatch = Server.CreateObject("Chilkat.JsonObject")
success = jsonMatch.UpdateString("appName","Test*")
' The following lines can be omitted. Not specifying anything for service, domain, or username is the same as "*".
success = jsonMatch.UpdateString("service","*")
success = jsonMatch.UpdateString("domain","*")
success = jsonMatch.UpdateString("username","*")
set results = Server.CreateObject("Chilkat.JsonObject")
results.EmitCompact = 0
success = secrets.ListSecrets(jsonMatch,results)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( secrets.LastErrorText) & "</pre>"
Response.End
End If
Response.Write "<pre>" & Server.HTMLEncode( results.Emit()) & "</pre>"
' Sample output:
' {
' "secrets": [
' {
' "appName": "Test",
' "service": "Something",
' "domain": "Xyz",
' "username": "Abc",
' "awsName": "Test/Something/Xyz/Abc"
' },
' {
' "appName": "Test2",
' "service": "Custom",
' "domain": "Ocean",
' "username": "Starfish",
' "awsName": "Test2/Custom/Ocean/Starfish"
' }
' ]
' }
' ---------------------------------------------------------------------------------------
' Here's sample code for parsing the JSON list of secrets.
i = 0
numSecrets = results.SizeOfArray("secrets")
Do While i < numSecrets
results.I = i
' Note: appName and domain are optional and may not exist in any given secret.
appName = results.StringOf("secrets[i].appName")
service = results.StringOf("secrets[i].service")
domain = results.StringOf("secrets[i].domain")
username = results.StringOf("secrets[i].username")
' Information field for the raw AWS secret name.
awsName = results.StringOf("secrets[i].awsName")
i = i + 1
Loop
%>
</body>
</html>