Seleccione sus preferencias de cookies

Usamos cookies esenciales y herramientas similares que son necesarias para proporcionar nuestro sitio y nuestros servicios. Usamos cookies de rendimiento para recopilar estadísticas anónimas para que podamos entender cómo los clientes usan nuestro sitio y hacer mejoras. Las cookies esenciales no se pueden desactivar, pero puede hacer clic en “Personalizar” o “Rechazar” para rechazar las cookies de rendimiento.

Si está de acuerdo, AWS y los terceros aprobados también utilizarán cookies para proporcionar características útiles del sitio, recordar sus preferencias y mostrar contenido relevante, incluida publicidad relevante. Para aceptar o rechazar todas las cookies no esenciales, haga clic en “Aceptar” o “Rechazar”. Para elegir opciones más detalladas, haga clic en “Personalizar”.

Ejemplos de registros rápidos en Amazon Q Developer

Modo de enfoque
Ejemplos de registros rápidos en Amazon Q Developer - Amazon Q Developer

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

En esta sección se proporcionan ejemplos de registros de solicitudes generados por Amazon Q Developer.

Después de cada ejemplo hay una tabla que describe los campos del archivo de registro.

Para obtener más información sobre los registros de solicitudes, consulteHabilitar el registro rápido en Amazon Q Developer.

Ejemplo de registro de sugerencias en línea

El siguiente ejemplo muestra un archivo de registro que se genera cuando un usuario acepta una sugerencia en línea.

{ "records": [ { "generateCompletionsEventRequest": { "leftContext": "import * cdk from 'aws-cdk-lib';\r\nimport * s3 from 'aws-cdk-lib/aws-s3';\r\nimport { Stack, StackProps } from 'constructs';\r\nexport class MyStack extends Stack {\r\n constructor(scope: cdk.App, id: string, props?: StackProps) {\r\n super(scope, id, props);\r\n\r\n new s3.Bucket(this, 'XXXXXXXX', {\r\n versioned: true\r\n });\r\n }\r\n ", "rightContext": "", "fileName": "cdk-modified.ts", "customizationArn": null, "userId": "d-92675051d5.b8f1f340-9081-70ad-5fc5-0f37151937a6", "timeStamp": "2025-01-06T15:09:16.412719Z" }, "generateCompletionsEventResponse": { "completions": ["synth() {\n return cdk.App.prototype.synth.apply(this, arguments);\n }"], "requestId": "797c70ee-abc9-4cc7-a148-b9df17f6ce48" } } ] }

En la siguiente tabla se describen los campos del archivo de registro para las sugerencias en línea.

Nombre del campo Descripción

records

Campo de nivel superior que contiene un conjunto de sugerencias integradas, también conocidas como finalizaciones integradas.

generateCompletionsEventRequest

Describe la solicitud de una sugerencia de código en línea. Amazon Q realiza la solicitud en nombre del usuario.

leftContext

Indica el código situado delante del cursor que Amazon Q utiliza como contexto para generar una sugerencia en línea.

rightContext

Indica el código situado tras el cursor que Amazon Q utiliza como contexto para generar una sugerencia en línea.

fileName

Indica el nombre del archivo en el que se solicitó una sugerencia en línea.

customizationArn

Indica el nombre de recurso de Amazon (ARN) de la personalización aplicada a las sugerencias en línea. En este ejemplo, no hay personalización. Para obtener más información sobre las personalizaciones, consulteSugerencias de personalización.

userId

Indica el seudónimo del usuario que solicitó una sugerencia en línea.

timeStamp

Indica la fecha y la hora en que se solicitó la sugerencia en línea. La marca de tiempo está en hora universal coordinada (UTC).

generateCompletionsEventResponse

Describe la sugerencia en línea generada por Amazon Q.

completions

Indica la sugerencia en línea que Amazon Q proporcionó y que el usuario aceptó.

requestId

El identificador de la solicitud en línea que identifica de forma exclusiva el evento.

Ejemplo de registro de chat

El siguiente ejemplo muestra un archivo de registro que se genera cuando un usuario chatea con Amazon Q en su IDE.

{ "records": [ { "generateAssistantResponseEventRequest": { "prompt": "Can you explain how to set up object-level access control in an S3 bucket using AWS CDK?", "chatTriggerType": "MANUAL", "customizationArn": null, "userId": "d-92675051d5.b8f1f340-9081-70ad-5fc5-0f37151937a6", "timeStamp": "2025-01-06T15:05:56.313070Z" }, "generateAssistantResponseEventResponse": { "assistantResponse": "I'll explain how to set up object-level access control for an S3 bucket using AWS CDK. Here's how you can implement different access control configurations: [[1]](https://docs.aws.amazon.com/AmazonS3/latest/API/s3_example_s3_Scenario_ManageACLs_section.html)\n\n1. Using Bucket Owner Enforced (Recommended Modern Approach):\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\n\nnew s3.Bucket(this, 'XXXXXXXX', {\n objectOwnership: s3.ObjectOwnership.BUCKET_OWNER_ENFORCED,\n blockPublicAccess: s3.BlockPublicAccess.BLOCK_ALL\n});\n```\n\n2. Using Public Access Block Configuration:\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\n\nnew s3.Bucket(this, 'XXXXXXXX', {\n blockPublicAccess: new s3.BlockPublicAccess({\n blockPublicAcls: true,\n blockPublicPolicy: true,\n ignorePublicAcls: true,\n restrictPublicBuckets: true\n })\n});\n```\n\n3. Setting Access Control for Specific Use Cases:\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as iam from 'aws-cdk-lib/aws-iam';\n\nconst bucket = new s3.Bucket(this, 'XXXXXXXX', {\n // Enable versioning for object-level recovery\n versioned: true,\n \n // Enforce encryption\n encryption: s3.BucketEncryption.S3_MANAGED,\n \n // Block all public access\n blockPublicAccess: s3.BlockPublicAccess.BLOCK_ALL,\n \n // Enforce object ownership\n objectOwnership: s3.ObjectOwnership.BUCKET_OWNER_ENFORCED,\n \n // Enable server access logs\n serverAccessLogsPrefix: 'logs/'\n});\n\n// Grant read access to specific IAM role\nconst role = new iam.Role(this, 'MyRole', {\n assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n});\nbucket.grantRead(role);\n\n// Grant write access to specific objects with prefix\nbucket.addToResourcePolicy(new iam.PolicyStatement({\n actions: ['s3:PutObject'],\n resources: [bucket.arnForObjects('uploads/*')],\n principals: [new iam.AccountRootPrincipal()]\n}));\n```\n\n4. Setting up Lifecycle Rules for Objects:\n```typescript\nimport * as cdk from 'aws-cdk-lib';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\n\nnew s3.Bucket(this, 'XXXXXXXX', {\n lifecycle: [\n {\n transitions: [\n {\n storageClass: s3.StorageClass.INFREQUENT_ACCESS,\n transitionAfter: cdk.Duration.days(30)\n },\n {\n storageClass: s3.StorageClass.GLACIER,\n transitionAfter: cdk.Duration.days(90)\n }\n ],\n expiration: cdk.Duration.days(365)\n }\n ]\n});\n```\n\nKey points to remember:\n- Always use the principle of least privilege\n- Block public access by default unless explicitly required\n- Use BUCKET_OWNER_ENFORCED for object ownership when possible\n- Consider implementing lifecycle rules for cost optimization\n- Use versioning for sensitive data\n- Implement server-side encryption\n- Use resource policies and IAM roles for access control instead of ACLs\n- Monitor access patterns using server access logging\n\nThese configurations help create a secure and well-managed S3 bucket with appropriate access controls at both bucket and object levels.", "followupPrompts": "How can you implement multi-factor authentication for S3 bucket access using AWS CDK?What are the best practices for setting up object-level versioning in AWS S3 using CDK?How can you use AWS CDK to create a custom error message for unauthorized access attempts on an S3 bucket?", "messageMetadata": { "conversationId": "491bd3cd-d70d-40c0-a452-5ef3f0878422", "utteranceId": null }, "codeReferenceEvents": [], "supplementaryWebLinksEvent": [ { "uri": "https://docs.aws.amazon.com/AmazonS3/latest/API/s3_example_s3_Scenario_ManageACLs_section.html", "title": "[1] Manage access control lists (ACLs) for Amazon S3 buckets using an AWS SDK - Amazon Simple Storage Service", "snippet": "The following code example shows how to manage access control lists (ACLs) for Amazon S3 buckets.\n\n.NET\n\n**AWS SDK for .NET**\n\n```\n using System;\n using System.Collections.Generic;\n using System.Threading.Tasks;\n using Amazon.S3;\n using Amazon.S3.Model;\n\n /// <summary>\n /// This example shows how to manage Amazon Simple Storage Service\n /// (Amazon S3) access control lists (ACLs) to control Amazon S3 bucket\n /// access.\n /// </summary>\n public class ManageACLs\n {\n public static async Task Main()\n {\n string bucketName = \"amzn-s3-demo-bucket1\";\n string newBucketName = \"amzn-s3-demo-bucket2\";\n string keyName = \"sample-object.txt\";\n string emailAddress = \"someone@example.com\";\n\n // If the AWS Region where your bucket is located is different from\n // the Region defined for the default user, pass the Amazon S3 bucket's\n // name to the client constructor. It should look like this:\n // RegionEndpoint bucketRegion = RegionEndpoint.USEast1;\n IAmazonS3 client = new AmazonS3Client();\n\n await TestBucketObjectACLsAsync(client, bucketName, newBucketName, keyName, emailAddress);\n }\n\n /// <summary>\n /// Creates a new Amazon S3 bucket with a canned ACL, then retrieves the ACL\n /// information and then adds a new ACL to one of the objects in the\n /// Amazon S3 bucket.\n /// </summary>\n /// <param name=\"client\">The initialized Amazon S3 client object used to call\n /// methods to create a bucket, get an ACL, and add a different ACL to\n /// one of the objects.</param>\n /// <param name=\"bucketName\">A string representing the original Amazon S3\n /// bucket name.</param>\n /// <param name=\"newBucketName\">A string representing the name of the\n /// new bucket that will be created.</param>\n /// <param name=\"keyName\">A string representing the key name of an Amazon S3\n /// object for which we will change the ACL.</param>\n /// <param name=\"emailAddress\">A string representing the email address\n /// belonging to the person to whom access to the Amazon S3 bucket will be\n /// granted.</param>\n public static async Task TestBucketObjectACLsAsync(\n IAmazonS3 client,\n string bucketName,\n string newBucketName,\n string keyName,\n string emailAddress)\n {\n try\n {\n // Create a new Amazon S3 bucket and specify canned ACL.\n var success = await CreateBucketWithCannedACLAsync(client, newBucketName);\n\n // Get the ACL on a bucket.\n await GetBucketACLAsync(client, bucketName);\n\n // Add (replace) the ACL on an object in a bucket.\n await AddACLToExistingObjectAsync(client, bucketName, keyName, emailAddress);\n }\n catch (AmazonS3Exception amazonS3Exception)\n {\n Console.WriteLine($\"Exception: {amazonS3Exception.Message}\");\n }\n }\n\n /// <summary>\n /// Creates a new Amazon S3 bucket with a canned ACL attached.\n /// </summary>\n /// <param name=\"client\">The initialized client object used to call\n /// PutBucketAsync.</param>\n /// <param name=\"newBucketName\">A string representing the name of the\n /// new Amazon S3 bucket.</param>\n /// <returns>Returns a boolean value indicating success or failure.</returns>\n public static async Task<bool> CreateBucketWithCannedACLAsync(IAmazonS3 client, string newBucketName)\n {\n var request = new PutBucketRequest()\n {\n BucketName = newBucketName,\n BucketRegion = S3Region.EUWest1,\n\n // Add a canned ACL.\n CannedACL = S3CannedACL.LogDeliveryWrite,\n };\n\n var response = await client.PutBucketAsync(request);\n return response.HttpStatusCode == System.Net.HttpStatusCode.OK;\n }\n\n\n /// <summary>\n /// Retrieves the ACL associated with the Amazon S3 bucket name in the\n /// bucketName parameter.\n /// </summary>\n /// <param name=\"client\">The initialized client object used to call\n /// PutBucketAsync.</param>\n /// <param name=\"bucketName\">The Amazon S3 bucket for which we want to get the\n /// ACL list.</param>\n /// <returns>Returns an S3AccessControlList returned from the call to\n /// GetACLAsync.</returns>\n public static async Task<S3AccessControlList> GetBucketACLAsync(IAmazonS3 client, string bucketName)\n {\n GetACLResponse response = await client.GetACLAsync(new GetACLRequest\n {\n BucketName = bucketName,\n });\n\n return response.AccessControlList;\n }\n\n\n\n /// <summary>\n /// Adds a new ACL to an existing object in the Amazon S3 bucket.\n /// </summary>\n /// <param name=\"client\">The initialized client object used to call\n /// PutBucketAsync.</param>\n /// <param name=\"bucketName\">A string representing the name of the Amazon S3\n /// bucket containing the object to which we want to apply a new ACL.</param>\n /// <param name=\"keyName\">A string representing the name of the object\n /// to which we want to apply the new ACL.</param>\n /// <param name=\"emailAddress\">The email address of the person to whom\n /// we will be applying to whom access will be granted.</param>\n public static async Task AddACLToExistingObjectAsync(IAmazonS3 client, string bucketName, string keyName, string emailAddress)\n {\n // Retrieve the ACL for an object.\n GetACLResponse aclResponse = await client.GetACLAsync(new GetACLRequest\n {\n BucketName = bucketName,\n Key = keyName,\n });\n\n S3AccessControlList acl = aclResponse.AccessControlList;\n\n // Retrieve the owner.\n Owner owner = acl.Owner;\n\n // Clear existing grants.\n acl.Grants.Clear();\n\n // Add a grant to reset the owner's full permission\n // (the previous clear statement removed all permissions).\n var fullControlGrant = new S3Grant\n {\n Grantee = new S3Grantee { CanonicalUser = acl.Owner.Id },\n };\n acl.AddGrant(fullControlGrant.Grantee, S3Permission.FULL_CONTROL);\n\n // Specify email to identify grantee for granting permissions.\n var grantUsingEmail = new S3Grant\n {\n Grantee = new S3Grantee { EmailAddress = emailAddress },\n Permission = S3Permission.WRITE_ACP,\n };\n\n // Specify log delivery group as grantee.\n var grantLogDeliveryGroup = new S3Grant\n {\n Grantee = new S3Grantee { URI = \"http://acs.amazonaws.com/groups/s3/LogDelivery\" },\n Permission = S3Permission.WRITE,\n };\n\n // Create a new ACL.\n var newAcl = new S3AccessControlList\n {\n Grants = new List<S3Grant> { grantUsingEmail, grantLogDeliveryGroup },\n Owner = owner,\n };\n\n // Set the new ACL. We're throwing away the response here.\n _ = await client.PutACLAsync(new PutACLRequest\n {\n BucketName = bucketName,\n Key = keyName,\n AccessControlList = newAcl,\n });\n }\n\n }\n\n\n```\n\n* For API details, see the following topics in _AWS SDK for .NET API Reference_.\n \n * GetBucketAcl\n\n* GetObjectAcl\n\n* PutBucketAcl\n\n* PutObjectAcl\n\nFor a complete list of AWS SDK developer guides and code examples, see Developing with Amazon S3 using the AWS SDKs. This topic also includes information about getting started and details about previous SDK versions.\n" } ], "requestId": "dad38fc0-815c-45f7-970a-db916cb7f131" } } ] }
Nombre del campo Descripción

records

Campo de nivel superior que contiene un conjunto de mensajes y respuestas.

generateAssistantResponseEventRequest

Describe el mensaje introducido por el usuario en la ventana de chat de su IDE.

prompt

Indica el mensaje que el usuario ingresó en la ventana de chat.

chatTriggerType

MANUALindica que el usuario ha introducido un mensaje en la ventana de chat o ha hecho clic en una de las preguntas sugeridas en la ventana de chat. INLINE_CHATindica que el usuario ha introducido un mensaje en la pequeña pantalla de entrada de la ventana principal de codificación. Para obtener más información sobre el chat en línea, consulteCharlar en línea con un desarrollador de Amazon Q.

customizationArn

Indica el nombre del recurso de Amazon (ARN) de la personalización aplicada al chat. En este ejemplo, no hay personalización. Para obtener más información sobre las personalizaciones, consulteSugerencias de personalización.

userId

Indica el seudónimo del usuario que ha introducido la solicitud.

timeStamp

Indica la fecha y la hora en que el usuario ingresó la solicitud. La marca de tiempo está en hora universal (UTC).

generateAssistantResponseEventResponse

Describe la respuesta generada por Amazon Q.

assistantResponse

Indica la respuesta que Amazon Q proporcionó a la solicitud del usuario.

followupPrompts

Indica las siguientes solicitudes de ejemplo que se mostraron al usuario al final de la respuesta.

messageMetadata

Describe los metadatos asociados a la respuesta.

conversationId

Indica el identificador de conversación de la respuesta. El identificador de conversación agrupa los mensajes de una sesión de chat.

utteranceId

Indica el identificador del enunciado de la respuesta. Un identificador de enunciado es una etiqueta que distingue un mensaje de otro dentro de un diálogo o conjunto de datos.

codeReferenceEvents

Describe los enlaces a las referencias de código incluidas en la respuesta.

supplementaryWebLinksEvent

Indica los enlaces que se mostraron al usuario al final de la respuesta.

requestId

El ID de la respuesta que identifica de forma exclusiva el evento.

Ejemplo de registro /dev

El siguiente ejemplo muestra un archivo de registro que se genera cuando un usuario introduce un /dev comando en el chat de Amazon Q en su IDE.

{ "records": [ { "startTaskAssistCodeGenerationEventRequest": { "prompt": "write a python application that prints 'hello world!' text to the screen and format it in red bold text", "chatTriggerType": "MANUAL", "conversationId": "da1c95b6-84e1-46a2-9ef9-fe92f5ee169e", "customizationArn": null, "userId": "d-92675051d5.b8f1f340-9081-70ad-5fc5-0f37151937a6", "timeStamp": "2025-01-13T15:40:27.808027101Z" }, "startTaskAssistCodeGenerationEventResponse": { "requestId": "e504f126-7197-4e3c-a046-1a10d5a3f3e0" } } ] }
Nombre del campo Descripción

records

Campo de nivel superior que contiene un conjunto de solicitudes y respuestas.

startTaskAssistCodeGenerationEventRequest

Describe el /dev mensaje introducido por el usuario en la ventana de chat de su IDE.

prompt

Indica el /dev mensaje que el usuario ingresó en la ventana de chat.

chatTriggerType

MANUALindica que el usuario ha introducido un mensaje en la ventana de chat o ha hecho clic en una de las preguntas sugeridas en la ventana de chat. INLINE_CHATindica que el usuario ha introducido un mensaje en la pequeña pantalla de entrada de la ventana principal de codificación. Para obtener más información sobre el chat en línea, consulteCharlar en línea con un desarrollador de Amazon Q.

conversationId

Indica el identificador de conversación de la respuesta. El identificador de conversación agrupa los mensajes de una sesión de chat.

customizationArn

Indica el nombre del recurso de Amazon (ARN) de la personalización aplicada al chat. En este ejemplo, no hay personalización. Para obtener más información sobre las personalizaciones, consulteSugerencias de personalización.

userId

Indica el seudónimo del usuario que ha introducido la solicitud.

timeStamp

Indica la fecha y la hora en que el usuario ingresó la solicitud. La marca de tiempo está en hora universal (UTC).

startTaskAssistCodeGenerationEventResponse

Describe la respuesta generada por Amazon Q. Actualmente, no se admite el registro de las respuestas a los /dev comandos, por lo que el campo no incluirá ninguna respuesta.

assistantResponse

Indica la respuesta que Amazon Q proporcionó a la solicitud del usuario.

requestId

El ID de la respuesta que identifica de forma exclusiva el evento.

PrivacidadTérminos del sitioPreferencias de cookies
© 2025, Amazon Web Services, Inc o sus afiliados. Todos los derechos reservados.