CfnGraphQLApiProps
- class aws_cdk.aws_appsync.CfnGraphQLApiProps(*, authentication_type, name, additional_authentication_providers=None, api_type=None, enhanced_metrics_config=None, environment_variables=None, introspection_config=None, lambda_authorizer_config=None, log_config=None, merged_api_execution_role_arn=None, open_id_connect_config=None, owner_contact=None, query_depth_limit=None, resolver_count_limit=None, tags=None, user_pool_config=None, visibility=None, xray_enabled=None)
Bases:
objectProperties for defining a
CfnGraphQLApi.- Parameters:
authentication_type (
str) – Security configuration for your GraphQL API. For allowed values (such asAPI_KEY,AWS_IAM,AMAZON_COGNITO_USER_POOLS,OPENID_CONNECT, orAWS_LAMBDA), see Security in the AWS AppSync Developer Guide .name (
str) – The API name.additional_authentication_providers (
Union[IResolvable,Sequence[Union[IResolvable,AdditionalAuthenticationProviderProperty,Dict[str,Any]]],None]) – A list of additional authentication providers for theGraphqlApiAPI.api_type (
Optional[str]) – The value that indicates whether the GraphQL API is a standard API (GRAPHQL) or merged API (MERGED). WARNING : If theApiTypehas not been defined, explicitly setting it toGRAPHQLin a template/stack update will result in an API replacement and new DNS values. The following values are valid:GRAPHQL | MERGEDenhanced_metrics_config (
Union[IResolvable,EnhancedMetricsConfigProperty,Dict[str,Any],None]) – Enables and controls the enhanced metrics feature. Enhanced metrics emit granular data on API usage and performance such as AppSync request and error counts, latency, and cache hits/misses. All enhanced metric data is sent to your CloudWatch account, and you can configure the types of data that will be sent. Enhanced metrics can be configured at the resolver, data source, and operation levels. For more information, see Monitoring and logging in the AWS AppSync User Guide .environment_variables (
Union[Mapping[str,str],IResolvable,None]) – A map containing the list of resources with their properties and environment variables. For more information, see Environmental variables . Pattern :^[A-Za-z]+\\w*$\\Minimum : 2 Maximum : 64introspection_config (
Optional[str]) – Sets the value of the GraphQL API to enable (ENABLED) or disable (DISABLED) introspection. If no value is provided, the introspection configuration will be set toENABLEDby default. This field will produce an error if the operation attempts to use the introspection feature while this field is disabled. For more information about introspection, see GraphQL introspection .lambda_authorizer_config (
Union[IResolvable,LambdaAuthorizerConfigProperty,Dict[str,Any],None]) – ALambdaAuthorizerConfigholds configuration on how to authorize AWS AppSync API access when using theAWS_LAMBDAauthorizer mode. Be aware that an AWS AppSync API may have only one Lambda authorizer configured at a time.log_config (
Union[IResolvable,LogConfigProperty,Dict[str,Any],None]) – The Amazon CloudWatch Logs configuration.merged_api_execution_role_arn (
Optional[str]) – The AWS Identity and Access Management service role ARN for a merged API. The AppSync service assumes this role on behalf of the Merged API to validate access to source APIs at runtime and to prompt theAUTO_MERGEto update the merged API endpoint with the source API changes automatically.open_id_connect_config (
Union[IResolvable,OpenIDConnectConfigProperty,Dict[str,Any],None]) – The OpenID Connect configuration.owner_contact (
Optional[str]) – The owner contact information for an API resource. This field accepts any string input with a length of 0 - 256 characters.query_depth_limit (
Union[int,float,None]) – The maximum depth a query can have in a single request. Depth refers to the amount of nested levels allowed in the body of query. The default value is0(or unspecified), which indicates there’s no depth limit. If you set a limit, it can be between1and75nested levels. This field will produce a limit error if the operation falls out of bounds. Note that fields can still be set to nullable or non-nullable. If a non-nullable field produces an error, the error will be thrown upwards to the first nullable field available.resolver_count_limit (
Union[int,float,None]) – The maximum number of resolvers that can be invoked in a single request. The default value is0(or unspecified), which will set the limit to10000. When specified, the limit value can be between1and10000. This field will produce a limit error if the operation falls out of bounds.tags (
Optional[Sequence[Union[CfnTag,Dict[str,Any]]]]) – An arbitrary set of tags (key-value pairs) for this GraphQL API.user_pool_config (
Union[IResolvable,UserPoolConfigProperty,Dict[str,Any],None]) – Optional authorization configuration for using Amazon Cognito user pools with your GraphQL endpoint.visibility (
Optional[str]) – Sets the scope of the GraphQL API to public (GLOBAL) or private (PRIVATE). By default, the scope is set toGlobalif no value is provided. WARNING : IfVisibilityhas not been defined, explicitly setting it toGLOBALin a template/stack update will result in an API replacement and new DNS values.xray_enabled (
Union[bool,IResolvable,None]) – A flag indicating whether to use AWS X-Ray tracing for thisGraphqlApi.
- See:
http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-appsync-graphqlapi.html
- ExampleMetadata:
fixture=_generated
Example:
# The code below shows an example of how to instantiate this type. # The values are placeholders you should change. from aws_cdk import aws_appsync as appsync cfn_graph_qLApi_props = appsync.CfnGraphQLApiProps( authentication_type="authenticationType", name="name", # the properties below are optional additional_authentication_providers=[appsync.CfnGraphQLApi.AdditionalAuthenticationProviderProperty( authentication_type="authenticationType", # the properties below are optional lambda_authorizer_config=appsync.CfnGraphQLApi.LambdaAuthorizerConfigProperty( authorizer_result_ttl_in_seconds=123, authorizer_uri="authorizerUri", identity_validation_expression="identityValidationExpression" ), open_id_connect_config=appsync.CfnGraphQLApi.OpenIDConnectConfigProperty( auth_ttl=123, client_id="clientId", iat_ttl=123, issuer="issuer" ), user_pool_config=appsync.CfnGraphQLApi.CognitoUserPoolConfigProperty( app_id_client_regex="appIdClientRegex", aws_region="awsRegion", user_pool_id="userPoolId" ) )], api_type="apiType", enhanced_metrics_config=appsync.CfnGraphQLApi.EnhancedMetricsConfigProperty( data_source_level_metrics_behavior="dataSourceLevelMetricsBehavior", operation_level_metrics_config="operationLevelMetricsConfig", resolver_level_metrics_behavior="resolverLevelMetricsBehavior" ), environment_variables={ "environment_variables_key": "environmentVariables" }, introspection_config="introspectionConfig", lambda_authorizer_config=appsync.CfnGraphQLApi.LambdaAuthorizerConfigProperty( authorizer_result_ttl_in_seconds=123, authorizer_uri="authorizerUri", identity_validation_expression="identityValidationExpression" ), log_config=appsync.CfnGraphQLApi.LogConfigProperty( cloud_watch_logs_role_arn="cloudWatchLogsRoleArn", exclude_verbose_content=False, field_log_level="fieldLogLevel" ), merged_api_execution_role_arn="mergedApiExecutionRoleArn", open_id_connect_config=appsync.CfnGraphQLApi.OpenIDConnectConfigProperty( auth_ttl=123, client_id="clientId", iat_ttl=123, issuer="issuer" ), owner_contact="ownerContact", query_depth_limit=123, resolver_count_limit=123, tags=[CfnTag( key="key", value="value" )], user_pool_config=appsync.CfnGraphQLApi.UserPoolConfigProperty( app_id_client_regex="appIdClientRegex", aws_region="awsRegion", default_action="defaultAction", user_pool_id="userPoolId" ), visibility="visibility", xray_enabled=False )
Attributes
- additional_authentication_providers
A list of additional authentication providers for the
GraphqlApiAPI.
- api_type
The value that indicates whether the GraphQL API is a standard API (
GRAPHQL) or merged API (MERGED).WARNING : If the
ApiTypehas not been defined, explicitly setting it toGRAPHQLin a template/stack update will result in an API replacement and new DNS values.The following values are valid:
GRAPHQL | MERGED
- authentication_type
Security configuration for your GraphQL API.
For allowed values (such as
API_KEY,AWS_IAM,AMAZON_COGNITO_USER_POOLS,OPENID_CONNECT, orAWS_LAMBDA), see Security in the AWS AppSync Developer Guide .
- enhanced_metrics_config
Enables and controls the enhanced metrics feature.
Enhanced metrics emit granular data on API usage and performance such as AppSync request and error counts, latency, and cache hits/misses. All enhanced metric data is sent to your CloudWatch account, and you can configure the types of data that will be sent.
Enhanced metrics can be configured at the resolver, data source, and operation levels. For more information, see Monitoring and logging in the AWS AppSync User Guide .
- environment_variables
A map containing the list of resources with their properties and environment variables.
For more information, see Environmental variables .
Pattern :
^[A-Za-z]+\\w*$\\Minimum : 2
Maximum : 64
- introspection_config
Sets the value of the GraphQL API to enable (
ENABLED) or disable (DISABLED) introspection.If no value is provided, the introspection configuration will be set to
ENABLEDby default. This field will produce an error if the operation attempts to use the introspection feature while this field is disabled.For more information about introspection, see GraphQL introspection .
- lambda_authorizer_config
A
LambdaAuthorizerConfigholds configuration on how to authorize AWS AppSync API access when using theAWS_LAMBDAauthorizer mode.Be aware that an AWS AppSync API may have only one Lambda authorizer configured at a time.
- log_config
The Amazon CloudWatch Logs configuration.
- merged_api_execution_role_arn
The AWS Identity and Access Management service role ARN for a merged API.
The AppSync service assumes this role on behalf of the Merged API to validate access to source APIs at runtime and to prompt the
AUTO_MERGEto update the merged API endpoint with the source API changes automatically.
- name
The API name.
- open_id_connect_config
The OpenID Connect configuration.
- owner_contact
The owner contact information for an API resource.
This field accepts any string input with a length of 0 - 256 characters.
- query_depth_limit
The maximum depth a query can have in a single request.
Depth refers to the amount of nested levels allowed in the body of query. The default value is
0(or unspecified), which indicates there’s no depth limit. If you set a limit, it can be between1and75nested levels. This field will produce a limit error if the operation falls out of bounds. Note that fields can still be set to nullable or non-nullable. If a non-nullable field produces an error, the error will be thrown upwards to the first nullable field available.
- resolver_count_limit
The maximum number of resolvers that can be invoked in a single request.
The default value is
0(or unspecified), which will set the limit to10000. When specified, the limit value can be between1and10000. This field will produce a limit error if the operation falls out of bounds.
- tags
An arbitrary set of tags (key-value pairs) for this GraphQL API.
- user_pool_config
Optional authorization configuration for using Amazon Cognito user pools with your GraphQL endpoint.
- visibility
Sets the scope of the GraphQL API to public (
GLOBAL) or private (PRIVATE).By default, the scope is set to
Globalif no value is provided.WARNING : If
Visibilityhas not been defined, explicitly setting it toGLOBALin a template/stack update will result in an API replacement and new DNS values.
- xray_enabled
A flag indicating whether to use AWS X-Ray tracing for this
GraphqlApi.