UpdateGraphqlApi PowerBuilder Example
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