/*
* 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 resiliencehub-2020-04-30.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.ResilienceHub.Model
{
///
/// Container for the parameters to the CreateApp operation.
/// Creates an Resilience Hub application. An Resilience Hub application is a collection
/// of Amazon Web Services resources structured to prevent and recover Amazon Web Services
/// application disruptions. To describe an Resilience Hub application, you provide an
/// application name, resources from one or more CloudFormation stacks, Resource Groups,
/// Terraform state files, AppRegistry applications, and an appropriate resiliency policy.
/// For more information about the number of resources supported per application, see
/// Service
/// Quotas.
///
///
///
/// After you create an Resilience Hub application, you publish it so that you can run
/// a resiliency assessment on it. You can then use recommendations from the assessment
/// to improve resiliency by running another assessment, comparing results, and then iterating
/// the process until you achieve your goals for recovery time objective (RTO) and recovery
/// point objective (RPO).
///
///
public partial class CreateAppRequest : AmazonResilienceHubRequest
{
private AppAssessmentScheduleType _assessmentSchedule;
private string _clientToken;
private string _description;
private string _name;
private string _policyArn;
private Dictionary _tags = new Dictionary();
///
/// Gets and sets the property AssessmentSchedule.
///
/// Assessment execution schedule with 'Daily' or 'Disabled' values.
///
///
public AppAssessmentScheduleType AssessmentSchedule
{
get { return this._assessmentSchedule; }
set { this._assessmentSchedule = value; }
}
// Check to see if AssessmentSchedule property is set
internal bool IsSetAssessmentSchedule()
{
return this._assessmentSchedule != null;
}
///
/// Gets and sets the property ClientToken.
///
/// Used for an idempotency token. A client token is a unique, case-sensitive string of
/// up to 64 ASCII characters. You should not reuse the same client token for other API
/// requests.
///
///
[AWSProperty(Min=1, Max=63)]
public string ClientToken
{
get { return this._clientToken; }
set { this._clientToken = value; }
}
// Check to see if ClientToken property is set
internal bool IsSetClientToken()
{
return this._clientToken != null;
}
///
/// Gets and sets the property Description.
///
/// The optional description for an app.
///
///
[AWSProperty(Min=0, Max=500)]
public string Description
{
get { return this._description; }
set { this._description = value; }
}
// Check to see if Description property is set
internal bool IsSetDescription()
{
return this._description != null;
}
///
/// Gets and sets the property Name.
///
/// The name for the application.
///
///
[AWSProperty(Required=true)]
public string Name
{
get { return this._name; }
set { this._name = value; }
}
// Check to see if Name property is set
internal bool IsSetName()
{
return this._name != null;
}
///
/// Gets and sets the property PolicyArn.
///
/// The Amazon Resource Name (ARN) of the resiliency policy. The format for this ARN is:
/// arn:partition
:resiliencehub:region
:account
:resiliency-policy/policy-id
.
/// For more information about ARNs, see
/// Amazon Resource Names (ARNs) in the AWS General Reference guide.
///
///
public string PolicyArn
{
get { return this._policyArn; }
set { this._policyArn = value; }
}
// Check to see if PolicyArn property is set
internal bool IsSetPolicyArn()
{
return this._policyArn != null;
}
///
/// Gets and sets the property Tags.
///
/// The tags assigned to the resource. A tag is a label that you assign to an Amazon Web
/// Services resource. Each tag consists of a key/value pair.
///
///
[AWSProperty(Sensitive=true, Min=1, Max=50)]
public Dictionary Tags
{
get { return this._tags; }
set { this._tags = value; }
}
// Check to see if Tags property is set
internal bool IsSetTags()
{
return this._tags != null && this._tags.Count > 0;
}
}
}