Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.
AWS::Serverless::GraphQLApi
Utilisez le type de AWS::Serverless::GraphQLApi
ressource AWS Serverless Application Model (AWS SAM) pour créer et configurer un AWS AppSync GraphQL APIpour votre application sans serveur.
Pour en savoir plus AWS AppSync, voir Qu'est-ce que c'est AWS AppSync ? dans le Guide AWS AppSync du développeur.
Syntaxe
YAML
LogicalId
: Type: AWS::Serverless::GraphQLApi Properties: ApiKeys:ApiKeys
Auth:Auth
Cache:AWS::AppSync::ApiCache
DataSources:DataSource
DomainName:AWS::AppSync::DomainName
Functions:Function
Logging:LogConfig
Name:String
Resolvers:Resolver
SchemaInline:String
SchemaUri:String
Tags:- Tag
XrayEnabled:Boolean
Propriétés
ApiKeys
-
Créez une clé unique qui peut être utilisée pour effectuer GraphQL opérations nécessitant une API clé.
Type : ApiKeys
Obligatoire : non
AWS CloudFormation compatibilité : cette propriété est unique AWS SAM et n'a pas d' AWS CloudFormation équivalent.
Auth
-
Configurez l'authentification pour votre GraphQL API.
Type : Authentification
Obligatoire : oui
AWS CloudFormation compatibilité : cette propriété est unique AWS SAM et n'a pas d' AWS CloudFormation équivalent.
Cache
-
Entrée d'une opération
CreateApiCache
.Type AWS : AppSync : : ApiCache
Obligatoire : non
AWS CloudFormation compatibilité : Cette propriété est transmise directement à la ApiCache ressource AWS: AppSync : : :.
DataSources
-
Créez des sources de données auxquelles les fonctions AWS AppSync peuvent se connecter. AWS SAM prend en charge Amazon DynamoDB et les sources de données AWS Lambda .
Type : DataSource
Obligatoire : oui
AWS CloudFormation compatibilité : cette propriété est unique AWS SAM et n'a pas d' AWS CloudFormation équivalent.
DomainName
-
Nom de domaine personnalisé pour votre GraphQL API.
Type AWS : AppSync : : DomainName
Obligatoire : non
AWS CloudFormation compatibilité : Cette propriété est transmise directement à la DomainName ressource AWS: AppSync : : :. AWS SAM génère automatiquement la DomainNameApiAssociation ressource AWS: AppSync : : :.
Functions
-
Configurer les fonctions dans GraphQL APIspour effectuer certaines opérations.
Type : Fonction
Obligatoire : oui
AWS CloudFormation compatibilité : cette propriété est unique AWS SAM et n'a pas d' AWS CloudFormation équivalent.
Logging
-
Configure la CloudWatch journalisation Amazon pour votre GraphQL API.
Si vous ne spécifiez pas cette propriété, AWS SAM générera
CloudWatchLogsRoleArn
et définira les valeurs suivantes :-
ExcludeVerboseContent: true
-
FieldLogLevel: ALL
Pour désactiver la journalisation, spécifiez les informations suivantes :
Logging: false
Type : LogConfig
Obligatoire : non
AWS CloudFormation compatibilité : cette propriété est transmise directement à la
LogConfig
propriété d'uneAWS::AppSync::GraphQLApi
ressource. -
LogicalId
-
Le nom unique de votre GraphQL API.
Type : chaîne
Obligatoire : oui
AWS CloudFormation compatibilité : cette propriété est transmise directement à la
Name
propriété d'uneAWS::AppSync::GraphQLApi
ressource. Name
-
Le nom de votre GraphQL API. Spécifiez cette propriété pour remplacer la
LogicalId
valeur.Type : chaîne
Obligatoire : non
AWS CloudFormation compatibilité : cette propriété est transmise directement à la
Name
propriété d'uneAWS::AppSync::GraphQLApi
ressource. Resolvers
-
Configurez des résolveurs pour les champs de votre GraphQL API. AWS SAM soutient JavaScript résolveurs de pipeline.
Type : Résolveur
Obligatoire : oui
AWS CloudFormation compatibilité : cette propriété est unique AWS SAM et n'a pas d' AWS CloudFormation équivalent.
SchemaInline
-
La représentation textuelle d'un GraphQL schéma dans SDL .
Type : chaîne
Obligatoire : selon les conditions. Vous devez spécifier
SchemaInline
ouSchemaUri
.AWS CloudFormation compatibilité : cette propriété est transmise directement à la
Definition
propriété d'uneAWS::AppSync::GraphQLSchema
ressource. SchemaUri
-
Le bucket Amazon Simple Storage Service (Amazon URI S3) du schéma ou le chemin d'accès à un dossier local.
Si vous spécifiez un chemin d'accès à un dossier local, le fichier AWS CloudFormation doit d'abord être chargé sur Amazon S3 avant le déploiement. Vous pouvez utiliser AWS SAM CLI pour faciliter ce processus. Pour de plus amples informations, veuillez consulter Comment AWS SAM télécharge les fichiers locaux lors du déploiement.
Type : chaîne
Obligatoire : selon les conditions. Vous devez spécifier
SchemaInline
ouSchemaUri
.AWS CloudFormation compatibilité : cette propriété est transmise directement à la
DefinitionS3Location
propriété d'uneAWS::AppSync::GraphQLSchema
ressource. -
Tags (paires clé-valeur) pour cela GraphQL API. Utilisez des balises pour identifier et classer les ressources.
Type : liste des éléments Tag
Obligatoire : non
AWS CloudFormation compatibilité : cette propriété est transmise directement à la
Tag
propriété d'uneAWS::AppSync::GraphQLApi
ressource. XrayEnabled
-
Indiquez si vous souhaitez utiliser le traçage aux rayons X AWS pour cette ressource.
Type : valeur booléenne
Obligatoire : non
AWS CloudFormation compatibilité : cette propriété est transmise directement à la
XrayEnabled
propriété d'uneAWS::AppSync::GraphQLApi
ressource.
Valeurs renvoyées
Pour obtenir la liste des valeurs renvoyées, reportez-vous à AWS::Serverless::GraphQLApi dans le guide de l'utilisateur AWS CloudFormation.
Exemples
GraphQL API avec la source de données DynamoDB
Dans cet exemple, nous créons un GraphQL APIqui utilise une table DynamoDB comme source de données.
schema.graphql
schema { query: Query mutation: Mutation } type Query { getPost(id: String!): Post } type Mutation { addPost(author: String!, title: String!, content: String!): Post! } type Post { id: String! author: String title: String content: String ups: Int! downs: Int! version: Int! }
template.yaml
AWSTemplateFormatVersion: '2010-09-09' Transform: AWS::Serverless-2016-10-31 ... Resources: DynamoDBPostsTable: Type: AWS::Serverless::SimpleTable MyGraphQLAPI: Type: AWS::Serverless::GraphQLApi Properties: SchemaUri: ./sam_graphql_api/schema.graphql Auth: Type: AWS_IAM DataSources: DynamoDb: PostsDataSource: TableName: !Ref DynamoDBPostsTable TableArn: !GetAtt DynamoDBPostsTable.Arn Functions: preprocessPostItem: Runtime: Name: APPSYNC_JS Version: 1.0.0 DataSource: NONE CodeUri: ./sam_graphql_api/preprocessPostItem.js createPostItem: Runtime: Name: APPSYNC_JS Version: "1.0.0" DataSource: PostsDataSource CodeUri: ./sam_graphql_api/createPostItem.js getPostFromTable: Runtime: Name: APPSYNC_JS Version: "1.0.0" DataSource: PostsDataSource CodeUri: ./sam_graphql_api/getPostFromTable.js Resolvers: Mutation: addPost: Runtime: Name: APPSYNC_JS Version: "1.0.0" Pipeline: - preprocessPostItem - createPostItem Query: getPost: CodeUri: ./sam_graphql_api/getPost.js Runtime: Name: APPSYNC_JS Version: "1.0.0" Pipeline: - getPostFromTable
createPostItem.js
import { util } from "@aws-appsync/utils"; export function request(ctx) { const { key, values } = ctx.prev.result; return { operation: "PutItem", key: util.dynamodb.toMapValues(key), attributeValues: util.dynamodb.toMapValues(values), }; } export function response(ctx) { return ctx.result; }
getPostFromTable.js
import { util } from "@aws-appsync/utils"; export function request(ctx) { return dynamoDBGetItemRequest({ id: ctx.args.id }); } export function response(ctx) { return ctx.result; } /** * A helper function to get a DynamoDB item */ function dynamoDBGetItemRequest(key) { return { operation: "GetItem", key: util.dynamodb.toMapValues(key), }; }
preprocessPostItem.js
import { util } from "@aws-appsync/utils"; export function request(ctx) { const id = util.autoId(); const { ...values } = ctx.args; values.ups = 1; values.downs = 0; values.version = 1; return { payload: { key: { id }, values: values } }; } export function response(ctx) { return ctx.result; }
Voici notre code de résolution :
getPost.js
export function request(ctx) { return {}; } export function response(ctx) { return ctx.prev.result; }
GraphQL APIavec une fonction Lambda comme source de données
Dans cet exemple, nous créons un GraphQL APIqui utilise une fonction Lambda comme source de données.
template.yaml
AWSTemplateFormatVersion: '2010-09-09' Transform: AWS::Serverless-2016-10-31 ... Resources: MyLambdaFunction: Type: AWS::Serverless::Function Properties: Handler: index.handler Runtime: nodejs20.x CodeUri: ./lambda MyGraphQLAPI: Type: AWS::Serverless::GraphQLApi Properties: Name: MyApi SchemaUri: ./gql/schema.gql Auth: Type: API_KEY ApiKeys: MyApiKey: Description: my api key DataSources: Lambda: MyLambdaDataSource: FunctionArn: !GetAtt MyLambdaFunction.Arn Functions: lambdaInvoker: Runtime: Name: APPSYNC_JS Version: 1.0.0 DataSource: MyLambdaDataSource CodeUri: ./gql/invoker.js Resolvers: Mutation: addPost: Runtime: Name: APPSYNC_JS Version: 1.0.0 Pipeline: - lambdaInvoker Query: getPost: Runtime: Name: APPSYNC_JS Version: 1.0.0 Pipeline: - lambdaInvoker Outputs: MyGraphQLAPI: Description: AppSync API Value: !GetAtt MyGraphQLAPI.GraphQLUrl MyGraphQLAPIMyApiKey: Description: API Key for authentication Value: !GetAtt MyGraphQLAPIMyApiKey.ApiKey
schema.graphql
schema { query: Query mutation: Mutation } type Query { getPost(id: ID!): Post } type Mutation { addPost(id: ID!, author: String!, title: String, content: String): Post! } type Post { id: ID! author: String! title: String content: String ups: Int downs: Int }
Voici nos fonctions :
lambda/index.js
exports.handler = async (event) => { console.log("Received event {}", JSON.stringify(event, 3)); const posts = { 1: { id: "1", title: "First book", author: "Author1", content: "Book 1 has this content", ups: "100", downs: "10", }, }; console.log("Got an Invoke Request."); let result; switch (event.field) { case "getPost": return posts[event.arguments.id]; case "addPost": // return the arguments back return event.arguments; default: throw new Error("Unknown field, unable to resolve " + event.field); } };
invoker.js
import { util } from "@aws-appsync/utils"; export function request(ctx) { const { source, args } = ctx; return { operation: "Invoke", payload: { field: ctx.info.fieldName, arguments: args, source }, }; } export function response(ctx) { return ctx.result; }