Chilkat Online Tools

UpdateGraphqlApi PowerBuilder Example

AWS AppSync

integer li_rc
oleobject loo_Rest
integer li_Success
oleobject loo_AuthAws
oleobject loo_Json
oleobject loo_SbRequestBody
oleobject loo_SbResponseBody
integer li_RespStatusCode
oleobject loo_JResp
string ls_AuthenticationType
integer li_LambdaAuthorizerConfigAuthorizerResultTtlInSeconds
string ls_LambdaAuthorizerConfigAuthorizerUri
string ls_LambdaAuthorizerConfigIdentityValidationExpression
integer li_OpenIDConnectConfigAuthTTL
string ls_OpenIDConnectConfigClientId
integer li_OpenIDConnectConfigIatTTL
string ls_OpenIDConnectConfigIssuer
string ls_UserPoolConfigAppIdClientRegex
string ls_UserPoolConfigAwsRegion
string ls_UserPoolConfigUserPoolId
string ls_ApiId
string ls_Arn
string ls_AuthenticationType
integer li_AuthorizerResultTtlInSeconds
string ls_AuthorizerUri
string ls_IdentityValidationExpression
string ls_CloudWatchLogsRoleArn
integer li_ExcludeVerboseContent
string ls_FieldLogLevel
string ls_Name
integer li_AuthTTL
string ls_ClientId
integer li_IatTTL
string ls_Issuer
string ls_V_String
string ls_UrisString
string ls_AppIdClientRegex
string ls_AwsRegion
string ls_DefaultAction
string ls_UserPoolId
string ls_WafWebAclArn
integer li_XrayEnabled
integer i
integer li_Count_i

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

loo_Rest = create oleobject
li_rc = loo_Rest.ConnectToNewObject("Chilkat_9_5_0.Rest")
if li_rc < 0 then
    destroy loo_Rest
    MessageBox("Error","Connecting to COM object failed")
    return
end if

loo_AuthAws = create oleobject
li_rc = loo_AuthAws.ConnectToNewObject("Chilkat_9_5_0.AuthAws")

loo_AuthAws.AccessKey = "AWS_ACCESS_KEY"
loo_AuthAws.SecretKey = "AWS_SECRET_KEY"

// Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
loo_AuthAws.Region = "us-west-2"
loo_AuthAws.ServiceName = "appsync"
// SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
loo_Rest.SetAuthAws(loo_AuthAws)

// URL: https://appsync.us-west-2.amazonaws.com/
// Use the same region as specified above.
li_Success = loo_Rest.Connect("appsync.us-west-2.amazonaws.com",443,1,1)
if li_Success <> 1 then
    Write-Debug "ConnectFailReason: " + string(loo_Rest.ConnectFailReason)
    Write-Debug loo_Rest.LastErrorText
    destroy loo_Rest
    destroy loo_AuthAws
    return
end if

// The following code creates the JSON request body.
// The JSON created by this code is shown below.

// Use this online tool to generate code from sample JSON:
// Generate Code to Create JSON

loo_Json = create oleobject
li_rc = loo_Json.ConnectToNewObject("Chilkat_9_5_0.JsonObject")

loo_Json.UpdateString("additionalAuthenticationProviders[0].authenticationType","string")
loo_Json.UpdateInt("additionalAuthenticationProviders[0].lambdaAuthorizerConfig.authorizerResultTtlInSeconds",123)
loo_Json.UpdateString("additionalAuthenticationProviders[0].lambdaAuthorizerConfig.authorizerUri","string")
loo_Json.UpdateString("additionalAuthenticationProviders[0].lambdaAuthorizerConfig.identityValidationExpression","string")
loo_Json.UpdateInt("additionalAuthenticationProviders[0].openIDConnectConfig.authTTL",123)
loo_Json.UpdateString("additionalAuthenticationProviders[0].openIDConnectConfig.clientId","string")
loo_Json.UpdateInt("additionalAuthenticationProviders[0].openIDConnectConfig.iatTTL",123)
loo_Json.UpdateString("additionalAuthenticationProviders[0].openIDConnectConfig.issuer","string")
loo_Json.UpdateString("additionalAuthenticationProviders[0].userPoolConfig.appIdClientRegex","string")
loo_Json.UpdateString("additionalAuthenticationProviders[0].userPoolConfig.awsRegion","string")
loo_Json.UpdateString("additionalAuthenticationProviders[0].userPoolConfig.userPoolId","string")
loo_Json.UpdateString("authenticationType","string")
loo_Json.UpdateInt("lambdaAuthorizerConfig.authorizerResultTtlInSeconds",123)
loo_Json.UpdateString("lambdaAuthorizerConfig.authorizerUri","string")
loo_Json.UpdateString("lambdaAuthorizerConfig.identityValidationExpression","string")
loo_Json.UpdateString("logConfig.cloudWatchLogsRoleArn","string")
loo_Json.UpdateInt("logConfig.excludeVerboseContent",123)
loo_Json.UpdateString("logConfig.fieldLogLevel","string")
loo_Json.UpdateString("name","string")
loo_Json.UpdateInt("openIDConnectConfig.authTTL",123)
loo_Json.UpdateString("openIDConnectConfig.clientId","string")
loo_Json.UpdateInt("openIDConnectConfig.iatTTL",123)
loo_Json.UpdateString("openIDConnectConfig.issuer","string")
loo_Json.UpdateString("userPoolConfig.appIdClientRegex","string")
loo_Json.UpdateString("userPoolConfig.awsRegion","string")
loo_Json.UpdateString("userPoolConfig.defaultAction","string")
loo_Json.UpdateString("userPoolConfig.userPoolId","string")
loo_Json.UpdateInt("xrayEnabled",123)

// The JSON request body created by the above code:

// {
//   "additionalAuthenticationProviders": [
//     {
//       "authenticationType": "string",
//       "lambdaAuthorizerConfig": {
//         "authorizerResultTtlInSeconds": number,
//         "authorizerUri": "string",
//         "identityValidationExpression": "string"
//       },
//       "openIDConnectConfig": {
//         "authTTL": number,
//         "clientId": "string",
//         "iatTTL": number,
//         "issuer": "string"
//       },
//       "userPoolConfig": {
//         "appIdClientRegex": "string",
//         "awsRegion": "string",
//         "userPoolId": "string"
//       }
//     }
//   ],
//   "authenticationType": "string",
//   "lambdaAuthorizerConfig": {
//     "authorizerResultTtlInSeconds": number,
//     "authorizerUri": "string",
//     "identityValidationExpression": "string"
//   },
//   "logConfig": {
//     "cloudWatchLogsRoleArn": "string",
//     "excludeVerboseContent": boolean,
//     "fieldLogLevel": "string"
//   },
//   "name": "string",
//   "openIDConnectConfig": {
//     "authTTL": number,
//     "clientId": "string",
//     "iatTTL": number,
//     "issuer": "string"
//   },
//   "userPoolConfig": {
//     "appIdClientRegex": "string",
//     "awsRegion": "string",
//     "defaultAction": "string",
//     "userPoolId": "string"
//   },
//   "xrayEnabled": boolean
// }

loo_Rest.AddHeader("Content-Type","application/x-amz-json-1.1")
loo_Rest.AddHeader("X-Amz-Target","UpdateGraphqlApi")

loo_SbRequestBody = create oleobject
li_rc = loo_SbRequestBody.ConnectToNewObject("Chilkat_9_5_0.StringBuilder")

loo_Json.EmitSb(loo_SbRequestBody)
loo_SbResponseBody = create oleobject
li_rc = loo_SbResponseBody.ConnectToNewObject("Chilkat_9_5_0.StringBuilder")

li_Success = loo_Rest.FullRequestSb("POST","/v1/apis/{apiId}",loo_SbRequestBody,loo_SbResponseBody)
if li_Success <> 1 then
    Write-Debug loo_Rest.LastErrorText
    destroy loo_Rest
    destroy loo_AuthAws
    destroy loo_Json
    destroy loo_SbRequestBody
    destroy loo_SbResponseBody
    return
end if

li_RespStatusCode = loo_Rest.ResponseStatusCode
Write-Debug "response status code = " + string(li_RespStatusCode)
if li_RespStatusCode <> 200 then
    Write-Debug "Response Header:"
    Write-Debug loo_Rest.ResponseHeader
    Write-Debug "Response Body:"
    Write-Debug loo_SbResponseBody.GetAsString()
    destroy loo_Rest
    destroy loo_AuthAws
    destroy loo_Json
    destroy loo_SbRequestBody
    destroy loo_SbResponseBody
    return
end if

loo_JResp = create oleobject
li_rc = loo_JResp.ConnectToNewObject("Chilkat_9_5_0.JsonObject")

loo_JResp.LoadSb(loo_SbResponseBody)

// The following code parses the JSON response.
// A sample JSON response is shown below the sample code.

// Use this online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON

ls_ApiId = loo_JResp.StringOf("graphqlApi.apiId")
ls_Arn = loo_JResp.StringOf("graphqlApi.arn")
ls_AuthenticationType = loo_JResp.StringOf("graphqlApi.authenticationType")
li_AuthorizerResultTtlInSeconds = loo_JResp.IntOf("graphqlApi.lambdaAuthorizerConfig.authorizerResultTtlInSeconds")
ls_AuthorizerUri = loo_JResp.StringOf("graphqlApi.lambdaAuthorizerConfig.authorizerUri")
ls_IdentityValidationExpression = loo_JResp.StringOf("graphqlApi.lambdaAuthorizerConfig.identityValidationExpression")
ls_CloudWatchLogsRoleArn = loo_JResp.StringOf("graphqlApi.logConfig.cloudWatchLogsRoleArn")
li_ExcludeVerboseContent = loo_JResp.IntOf("graphqlApi.logConfig.excludeVerboseContent")
ls_FieldLogLevel = loo_JResp.StringOf("graphqlApi.logConfig.fieldLogLevel")
ls_Name = loo_JResp.StringOf("graphqlApi.name")
li_AuthTTL = loo_JResp.IntOf("graphqlApi.openIDConnectConfig.authTTL")
ls_ClientId = loo_JResp.StringOf("graphqlApi.openIDConnectConfig.clientId")
li_IatTTL = loo_JResp.IntOf("graphqlApi.openIDConnectConfig.iatTTL")
ls_Issuer = loo_JResp.StringOf("graphqlApi.openIDConnectConfig.issuer")
ls_V_String = loo_JResp.StringOf("graphqlApi.tags.string")
ls_UrisString = loo_JResp.StringOf("graphqlApi.uris.string")
ls_AppIdClientRegex = loo_JResp.StringOf("graphqlApi.userPoolConfig.appIdClientRegex")
ls_AwsRegion = loo_JResp.StringOf("graphqlApi.userPoolConfig.awsRegion")
ls_DefaultAction = loo_JResp.StringOf("graphqlApi.userPoolConfig.defaultAction")
ls_UserPoolId = loo_JResp.StringOf("graphqlApi.userPoolConfig.userPoolId")
ls_WafWebAclArn = loo_JResp.StringOf("graphqlApi.wafWebAclArn")
li_XrayEnabled = loo_JResp.IntOf("graphqlApi.xrayEnabled")
i = 0
li_Count_i = loo_JResp.SizeOfArray("graphqlApi.additionalAuthenticationProviders")
do while i < li_Count_i
    loo_JResp.I = i
    ls_AuthenticationType = loo_JResp.StringOf("graphqlApi.additionalAuthenticationProviders[i].authenticationType")
    li_LambdaAuthorizerConfigAuthorizerResultTtlInSeconds = loo_JResp.IntOf("graphqlApi.additionalAuthenticationProviders[i].lambdaAuthorizerConfig.authorizerResultTtlInSeconds")
    ls_LambdaAuthorizerConfigAuthorizerUri = loo_JResp.StringOf("graphqlApi.additionalAuthenticationProviders[i].lambdaAuthorizerConfig.authorizerUri")
    ls_LambdaAuthorizerConfigIdentityValidationExpression = loo_JResp.StringOf("graphqlApi.additionalAuthenticationProviders[i].lambdaAuthorizerConfig.identityValidationExpression")
    li_OpenIDConnectConfigAuthTTL = loo_JResp.IntOf("graphqlApi.additionalAuthenticationProviders[i].openIDConnectConfig.authTTL")
    ls_OpenIDConnectConfigClientId = loo_JResp.StringOf("graphqlApi.additionalAuthenticationProviders[i].openIDConnectConfig.clientId")
    li_OpenIDConnectConfigIatTTL = loo_JResp.IntOf("graphqlApi.additionalAuthenticationProviders[i].openIDConnectConfig.iatTTL")
    ls_OpenIDConnectConfigIssuer = loo_JResp.StringOf("graphqlApi.additionalAuthenticationProviders[i].openIDConnectConfig.issuer")
    ls_UserPoolConfigAppIdClientRegex = loo_JResp.StringOf("graphqlApi.additionalAuthenticationProviders[i].userPoolConfig.appIdClientRegex")
    ls_UserPoolConfigAwsRegion = loo_JResp.StringOf("graphqlApi.additionalAuthenticationProviders[i].userPoolConfig.awsRegion")
    ls_UserPoolConfigUserPoolId = loo_JResp.StringOf("graphqlApi.additionalAuthenticationProviders[i].userPoolConfig.userPoolId")
    i = i + 1
loop

// A sample JSON response body parsed by the above code:

// {
//   "graphqlApi": {
//     "additionalAuthenticationProviders": [
//       {
//         "authenticationType": "string",
//         "lambdaAuthorizerConfig": {
//           "authorizerResultTtlInSeconds": number,
//           "authorizerUri": "string",
//           "identityValidationExpression": "string"
//         },
//         "openIDConnectConfig": {
//           "authTTL": number,
//           "clientId": "string",
//           "iatTTL": number,
//           "issuer": "string"
//         },
//         "userPoolConfig": {
//           "appIdClientRegex": "string",
//           "awsRegion": "string",
//           "userPoolId": "string"
//         }
//       }
//     ],
//     "apiId": "string",
//     "arn": "string",
//     "authenticationType": "string",
//     "lambdaAuthorizerConfig": {
//       "authorizerResultTtlInSeconds": number,
//       "authorizerUri": "string",
//       "identityValidationExpression": "string"
//     },
//     "logConfig": {
//       "cloudWatchLogsRoleArn": "string",
//       "excludeVerboseContent": boolean,
//       "fieldLogLevel": "string"
//     },
//     "name": "string",
//     "openIDConnectConfig": {
//       "authTTL": number,
//       "clientId": "string",
//       "iatTTL": number,
//       "issuer": "string"
//     },
//     "tags": {
//       "string": "string"
//     },
//     "uris": {
//       "string": "string"
//     },
//     "userPoolConfig": {
//       "appIdClientRegex": "string",
//       "awsRegion": "string",
//       "defaultAction": "string",
//       "userPoolId": "string"
//     },
//     "wafWebAclArn": "string",
//     "xrayEnabled": boolean
//   }
// }


destroy loo_Rest
destroy loo_AuthAws
destroy loo_Json
destroy loo_SbRequestBody
destroy loo_SbResponseBody
destroy loo_JResp