/*
* Copyright 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.
*/
/*
* Do not modify this file. This file is generated from the marketplacecommerceanalytics-2015-07-01.normal.json service model.
*/
using System;
using System.Threading;
using System.Threading.Tasks;
using System.Collections.Generic;
using Amazon.Runtime;
using Amazon.AWSMarketplaceCommerceAnalytics.Model;
namespace Amazon.AWSMarketplaceCommerceAnalytics
{
///
/// Interface for accessing AWSMarketplaceCommerceAnalytics
///
/// Provides AWS Marketplace business intelligence data on-demand.
///
public partial interface IAmazonAWSMarketplaceCommerceAnalytics : IAmazonService, IDisposable
{
#region GenerateDataSet
///
/// Given a data set type and data set publication date, asynchronously publishes the
/// requested data set to the specified S3 bucket and notifies the specified SNS topic
/// once the data is available. Returns a unique request identifier that can be used to
/// correlate requests with notifications from the SNS topic. Data sets will be published
/// in comma-separated values (CSV) format with the file name {data_set_type}_YYYY-MM-DD.csv.
/// If a file with the same name already exists (e.g. if the same data set is requested
/// twice), the original file will be overwritten by the new file. Requires a Role with
/// an attached permissions policy providing Allow permissions for the following actions:
/// s3:PutObject, s3:GetBucketLocation, sns:GetTopicAttributes, sns:Publish, iam:GetRolePolicy.
///
/// Container for the necessary parameters to execute the GenerateDataSet service method.
///
/// A cancellation token that can be used by other objects or threads to receive notice of cancellation.
///
///
/// The response from the GenerateDataSet service method, as returned by AWSMarketplaceCommerceAnalytics.
///
/// This exception is thrown when an internal service error occurs.
///
/// REST API Reference for GenerateDataSet Operation
Task GenerateDataSetAsync(GenerateDataSetRequest request, System.Threading.CancellationToken cancellationToken = default(CancellationToken));
#endregion
#region StartSupportDataExport
///
/// Given a data set type and a from date, asynchronously publishes the requested customer
/// support data to the specified S3 bucket and notifies the specified SNS topic once
/// the data is available. Returns a unique request identifier that can be used to correlate
/// requests with notifications from the SNS topic. Data sets will be published in comma-separated
/// values (CSV) format with the file name {data_set_type}_YYYY-MM-DD'T'HH-mm-ss'Z'.csv.
/// If a file with the same name already exists (e.g. if the same data set is requested
/// twice), the original file will be overwritten by the new file. Requires a Role with
/// an attached permissions policy providing Allow permissions for the following actions:
/// s3:PutObject, s3:GetBucketLocation, sns:GetTopicAttributes, sns:Publish, iam:GetRolePolicy.
///
/// Container for the necessary parameters to execute the StartSupportDataExport service method.
///
/// A cancellation token that can be used by other objects or threads to receive notice of cancellation.
///
///
/// The response from the StartSupportDataExport service method, as returned by AWSMarketplaceCommerceAnalytics.
///
/// This exception is thrown when an internal service error occurs.
///
/// REST API Reference for StartSupportDataExport Operation
Task StartSupportDataExportAsync(StartSupportDataExportRequest request, System.Threading.CancellationToken cancellationToken = default(CancellationToken));
#endregion
}
}