Swift
Swift
AWS Secrets Manager - List Secrets
See more AWS Secrets Manager Examples
Lists the secrets that are stored by Secrets Manager in the AWS account. Lists the secrets that are stored by Secrets Manager in the AWS account.Chilkat Swift Downloads
func chilkatTest() {
var success: Bool = false
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// Sends the following sample request.
// Note: Chilkat will automatically add Content-Length, X-Amz-Date, Accept-Encoding, and Authorization
// POST / HTTP/1.1
// Host: secretsmanager.region.domain
// Accept-Encoding: identity
// X-Amz-Target: secretsmanager.ListSecrets
// Content-Type: application/x-amz-json-1.1
// X-Amz-Date: <date>
// Authorization: AWS4-HMAC-SHA256 Credential=<credentials>,SignedHeaders=<headers>, Signature=<signature>
// Content-Length: <payload-size-bytes>
//
// {}
let rest = CkoRest()!
// Connect to the Amazon AWS REST server.
// such as https://secretsmanager.us-west-2.amazonaws.com/
var bTls: Bool = true
var port: Int = 443
var bAutoReconnect: Bool = true
success = rest.connect(hostname: "secretsmanager.us-west-2.amazonaws.com", port: port, tls: bTls, autoReconnect: bAutoReconnect)
// Provide AWS credentials for the REST call.
let authAws = CkoAuthAws()!
authAws.accessKey = "AWS_ACCESS_KEY"
authAws.secretKey = "AWS_SECRET_KEY"
// the region should match our URL above..
authAws.region = "us-west-2"
authAws.serviceName = "secretsmanager"
rest.setAuthAws(authProvider: authAws)
rest.addHeader(name: "Content-Type", value: "application/x-amz-json-1.1")
rest.addHeader(name: "X-Amz-Target", value: "secretsmanager.ListSecrets")
var strResponse: String? = rest.fullRequestString(httpVerb: "POST", uriPath: "/", bodyText: "{}")
if rest.lastMethodSuccess == false {
print("\(rest.lastErrorText!)")
return
}
var respStatusCode: Int = rest.responseStatusCode.intValue
print("response status code = \(respStatusCode)")
let jResp = CkoJsonObject()!
jResp.emitCompact = false
jResp.load(json: strResponse)
if respStatusCode >= 400 {
print("Response Status Code = \(respStatusCode)")
print("Response Header:")
print("\(rest.responseHeader!)")
print("Response Body:")
print("\(jResp.emit()!)")
return
}
print("Response Body:")
print("\(jResp.emit()!)")
// Sample response body:
// {
// "SecretList":[
// {
// "ARN":"arn:aws:secretsmanager:us-west-2:123456789012:secret:MyTestDatabaseSecret-a1b2c3",
// "Description":"My test database secret",
// "LastChangedDate":1.523477145729E9,
// "Name":"MyTestDatabaseSecret",
// "SecretVersionsToStages":{
// "EXAMPLE2-90ab-cdef-fedc-ba987EXAMPLE":["AWSCURRENT"]
// }
// },
// {
// "ARN":"arn:aws:secretsmanager:us-west-2:123456789012:secret:AnotherDatabaseSecret-d4e5f6",
// "Description":"Another secret created for a different database",
// "LastChangedDate":1.523482025685E9,
// "Name":"AnotherDatabaseSecret",
// "SecretVersionsToStages":{
// "EXAMPLE3-90ab-cdef-fedc-ba987EXAMPLE":["AWSCURRENT"]
// }
// }
// ]
// }
var ARN: String?
var Description: String?
var LastChangedDate: String?
var Name: String?
var strVal: String?
let json2 = CkoJsonObject()!
let jarr = CkoJsonArray()!
var i: Int = 0
var count_i: Int = jResp.size(ofArray: "SecretList").intValue
while i < count_i {
jResp.i = i
ARN = jResp.string(of: "SecretList[i].ARN")
Description = jResp.string(of: "SecretList[i].Description")
LastChangedDate = jResp.string(of: "SecretList[i].LastChangedDate")
Name = jResp.string(of: "SecretList[i].Name")
jResp.objectOf2(jsonPath: "SecretList[i].SecretVersionsToStages", jsonObj: json2)
var count: Int = json2.size.intValue
var j: Int = 0
while j < count {
var versionName: String? = json2.name(at: j)
json2.arrayOf2(jsonPath: versionName, jarr: jarr)
var stage: String? = jarr.string(at: 0)
print("versionName = \(versionName!)")
print("stage = \(stage!)")
j = j + 1
}
i = i + 1
}
}