Registro em log de chamadas à API do AWS Serverless Application Repository com o AWS CloudTrail - AWS Serverless Application Repository

As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.

Registro em log de chamadas à API do AWS Serverless Application Repository com o AWS CloudTrail

AWS Serverless Application RepositoryO é integrado aoAWS CloudTrail, que é um serviço que fornece um registro das ações realizadas por um usuário, uma função ou umAWSserviçoServiço noAWS Serverless Application Repository. CloudTrailO captura todas as chamadas à API doAWS Serverless Application Repositorycomo eventos. As chamadas capturadas incluem as chamadas do console do AWS Serverless Application Repository e as chamadas de código para as operações da API do AWS Serverless Application Repository.

Se você criar uma trilha, poderá habilitar a entrega contínua doCloudTraileventos para um bucket do Amazon S3, incluindo eventos para oAWS Serverless Application Repository. Se não configurar uma trilha, você ainda poderá visualizar os eventos mais recentes no console do CloudTrail em Event history.

Usando as informações coletadas pelo CloudTrail, é possível determinar a solicitação que foi feita ao AWS Serverless Application Repository. Também é possível determinar o endereço IP do qual a solicitação foi feita, quem fez a solicitação, quando ela foi feita, e detalhes adicionais.

Para saber mais sobre CloudTrail, consulte o Guia do usuário de AWS CloudTrail.

Informações sobre o AWS Serverless Application Repository no CloudTrail

O CloudTrail está habilitado na sua conta da AWS ao criá-la. Quando ocorre uma atividade no AWS Serverless Application Repository, ela é registrada em um evento do CloudTrail com outros eventos de serviços da AWS em Event history (Histórico de eventos). Você pode visualizar, pesquisar e baixar eventos recentes em sua conta da AWS. Para obter mais informações, consulte Visualizar eventos com o histórico de eventos do CloudTrail.

Para obter um registro contínuo de eventos na conta da AWS, incluindo eventos do AWS Serverless Application Repository, crie uma trilha. UMAtrilhaativaCloudTrailpara enviar arquivos de log para um bucket do Amazon S3. Por padrão, quando você cria uma trilha no console, ela é aplicada a todas as regiões da AWS. A trilha registra em log eventos de todas as regiões da AWS na partição da AWS e entrega os arquivos de log para o bucket do Amazon S3 especificado por você. Além disso, é possível configurar outros serviços da AWS para analisar mais profundamente e agir sobre os dados de evento coletados nos logs do CloudTrail. Para obter mais informações, consulte as informações a seguir:

Todas as ações do AWS Serverless Application Repository são registradas em log pelo CloudTrail e documentadas na página Recursos do AWS Serverless Application Repository. Por exemplo, as chamadas para as operações CreateApplication, UpdateApplications e ListApplications geram entradas nos arquivos de log do CloudTrail.

Cada entrada de log ou evento contém informações sobre quem gerou a solicitação. As informações de identidade ajudam a determinar:

  • Se a solicitação foi feita com credenciais de usuário raiz ou do AWS Identity and Access Management (IAM).

  • Se a solicitação foi feita com credenciais de segurança temporárias de uma função ou de um usuário federado.

  • Se a solicitação foi feita por outro serviço da AWS.

Para obter mais informações, consulte Elemento userIdentity do CloudTrail.

Noções básicas das entradas dos arquivos de log do AWS Serverless Application Repository

Uma trilha é uma configuração que permite a entrega de eventos como arquivos de log a um bucket do Amazon S3 especificado. Os arquivos de log do CloudTrail contêm uma ou mais entradas de log. Um evento representa uma única solicitação de qualquer fonte e inclui informações sobre a ação solicitada, a data e a hora da ação, os parâmetros de solicitação e assim por diante. Os arquivos de log do CloudTrail não são um rastreamento de pilha ordenada de chamadas de API pública. Dessa forma, eles não são exibidos em uma ordem específica.

O exemplo a seguir mostra uma entrada de log do CloudTrail que demonstra a ação CreateApplication.

{ "eventVersion": "1.05", "userIdentity": { "type": "Root", "principalId": "999999999999", "arn": "arn:aws:iam::999999999999:root", "accountId": "999999999999", "accessKeyId": "ASIAUVPLBDH76HEXAMPLE", "sessionContext": { "attributes": { "mfaAuthenticated": "false", "creationDate": "2018-07-30T16:40:42Z" } }, "invokedBy": "signin.amazonaws.com" }, "eventTime": "2018-07-30T17:37:37Z", "eventSource": "serverlessrepo.amazonaws.com", "eventName": "CreateApplication", "awsRegion": "us-east-1", "sourceIPAddress": "72.21.217.161", "userAgent": "signin.amazonaws.com", "requestParameters": { "licenseBody": "<content of license>", "sourceCodeUrl": "<sample url>", "spdxLicenseId": "<sample license id>", "readmeBody": "<content of readme>", "author": "<author name>", "templateBody": "<content of SAM template>", "name": "<application name>", "semanticVersion": "<version>", "description": "<content of description>", "homePageUrl": "<sample url>", "labels": [ "<label1>", "<label2>" ] }, "responseElements": { "licenseUrl": "<url to access content of license>", "readmeUrl": "<url to access content of readme>", "spdxLicenseId": "<sample license id>", "creationTime": "2018-07-30T17:37:37.045Z", "author": "<author name>", "name": "<application name>", "description": "<content of description>", "applicationId": "arn:aws:serverlessrepo:us-east-1:999999999999:applications/<application name>", "homePageUrl": "<sample url>", "version": { "applicationId": "arn:aws:serverlessrepo:us-east-1:999999999999:applications/<application name>", "semanticVersion": "<version>", "sourceCodeUrl": "<sample url>", "templateUrl": "<url to access content of SAM template>", "creationTime": "2018-07-30T17:37:37.027Z", "parameterDefinitions": [ { "name": "<parameter name>", "description": "<parameter description>", "type": "<parameter type>" } ] }, "labels": [ "<label1>", "<label2>" ] }, "requestID": "3f50d899-941f-11e8-ab18-01063f863be5", "eventID": "a66a6490-d388-4a4f-8c7b-9d6ec61ab262", "readOnly": false, "eventType": "AwsApiCall", "recipientAccountId": "999999999999" }