/* * Copyright 2010-2015 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ using System; using System.Collections.Generic; using System.Xml.Serialization; using System.Text; using System.IO; namespace Amazon.S3.Model { /// /// This class contains the configuration Amazon S3 uses to figure out what events you want to listen /// and send the event to an Amazon SQS queue. /// /// The queue's policy must allow S3 to send messages to it. The utility method /// Amazon.SQS.AmazonSQSClient.AuthorizeS3ToSendMessage(string,string) /// can be used to help setup the queue policy. /// /// public class QueueConfiguration : NotificationConfiguration { /// /// Gets and set the Id property. The Id will be provided in the event content and can be used /// to identify which configuration caused an event to fire. If the Id is not provided for the configuration, one will be generated. /// public string Id { get; set; } internal bool IsSetId() { return this.Id != null; } /// /// Gets and sets the Queue property. Amazon SQS queue to which Amazon S3 will publish a message /// to report the specified events for the bucket. /// /// The queue's policy must allow S3 to send messages to it. The utility method /// Amazon.SQS.AmazonSQSClient.AuthorizeS3ToSendMessage(string,string) /// can be used to help setup the queue policy. /// /// public string Queue { get; set; } // Check to see if Queue property is set internal bool IsSetQueue() { return this.Queue != null; } } }