Visual FoxPro
Visual FoxPro
AWS Secrets Manager - Get Secret Value
See more AWS Secrets Manager Examples
Retrieves the contents of the encrypted fields SecretString or SecretBinary from the specified version of a secret, whichever contains content.Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loRest
LOCAL lnBTls
LOCAL lnPort
LOCAL lnBAutoReconnect
LOCAL loAuthAws
LOCAL loJson
LOCAL loSbRequestBody
LOCAL loSbResponseBody
LOCAL lnRespStatusCode
LOCAL loJResp
LOCAL lcARN
LOCAL lcCreatedDate
LOCAL lcName
LOCAL lcSecretString
LOCAL lcVersionId
lnSuccess = 0
* 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.GetSecretValue
* 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>
*
* {
* "SecretId": "MyTestDatabaseSecret",
* }
loRest = CreateObject('Chilkat.Rest')
* Connect to the Amazon AWS REST server.
* such as https://secretsmanager.us-west-2.amazonaws.com/
lnBTls = 1
lnPort = 443
lnBAutoReconnect = 1
lnSuccess = loRest.Connect("secretsmanager.us-west-2.amazonaws.com",lnPort,lnBTls,lnBAutoReconnect)
* Provide AWS credentials for the REST call.
loAuthAws = CreateObject('Chilkat.AuthAws')
loAuthAws.AccessKey = "AWS_ACCESS_KEY"
loAuthAws.SecretKey = "AWS_SECRET_KEY"
* the region should match our URL above..
loAuthAws.Region = "us-west-2"
loAuthAws.ServiceName = "secretsmanager"
loRest.SetAuthAws(loAuthAws)
* Use this online tool to generate code from sample JSON:
* Generate Code to Create JSON
loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("SecretId","MyTestDatabaseSecret2")
loRest.AddHeader("Content-Type","application/x-amz-json-1.1")
loRest.AddHeader("X-Amz-Target","secretsmanager.GetSecretValue")
loSbRequestBody = CreateObject('Chilkat.StringBuilder')
loJson.EmitSb(loSbRequestBody)
loSbResponseBody = CreateObject('Chilkat.StringBuilder')
lnSuccess = loRest.FullRequestSb("POST","/",loSbRequestBody,loSbResponseBody)
IF (lnSuccess <> 1) THEN
? loRest.LastErrorText
RELEASE loRest
RELEASE loAuthAws
RELEASE loJson
RELEASE loSbRequestBody
RELEASE loSbResponseBody
CANCEL
ENDIF
lnRespStatusCode = loRest.ResponseStatusCode
? "response status code = " + STR(lnRespStatusCode)
loJResp = CreateObject('Chilkat.JsonObject')
loJResp.EmitCompact = 0
loJResp.LoadSb(loSbResponseBody)
IF (lnRespStatusCode >= 400) THEN
? "Response Status Code = " + STR(lnRespStatusCode)
? "Response Header:"
? loRest.ResponseHeader
? "Response Body:"
? loJResp.Emit()
RELEASE loRest
RELEASE loAuthAws
RELEASE loJson
RELEASE loSbRequestBody
RELEASE loSbResponseBody
RELEASE loJResp
CANCEL
ENDIF
? "Response Body:"
? loJResp.Emit()
* Sample response body:
* {
* "ARN":"arn:aws:secretsmanager:us-west-2:123456789012:secret:MyTestDatabaseSecret-a1b2c3",
* "CreatedDate":1.523477145713E9,
* "Name":"MyTestDatabaseSecret",
* "SecretString":"{\n \"username\":\"david\",\n \"password\":\"BnQw&XDWgaEeT9XGTT29\"\n}\n",
* "VersionId":"EXAMPLE1-90ab-cdef-fedc-ba987SECRET1"
* }
* Use this online tool to generate parsing code from sample JSON:
* Generate Parsing Code from JSON
lcARN = loJResp.StringOf("ARN")
lcCreatedDate = loJResp.StringOf("CreatedDate")
lcName = loJResp.StringOf("Name")
lcSecretString = loJResp.StringOf("SecretString")
lcVersionId = loJResp.StringOf("VersionId")
RELEASE loRest
RELEASE loAuthAws
RELEASE loJson
RELEASE loSbRequestBody
RELEASE loSbResponseBody
RELEASE loJResp