/*
* 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 codecommit-2015-04-13.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.CodeCommit.Model
{
///
/// Container for the parameters to the UpdatePullRequestApprovalRuleContent operation.
/// Updates the structure of an approval rule created specifically for a pull request.
/// For example, you can change the number of required approvers and the approval pool
/// for approvers.
///
public partial class UpdatePullRequestApprovalRuleContentRequest : AmazonCodeCommitRequest
{
private string _approvalRuleName;
private string _existingRuleContentSha256;
private string _newRuleContent;
private string _pullRequestId;
///
/// Gets and sets the property ApprovalRuleName.
///
/// The name of the approval rule you want to update.
///
///
[AWSProperty(Required=true, Min=1, Max=100)]
public string ApprovalRuleName
{
get { return this._approvalRuleName; }
set { this._approvalRuleName = value; }
}
// Check to see if ApprovalRuleName property is set
internal bool IsSetApprovalRuleName()
{
return this._approvalRuleName != null;
}
///
/// Gets and sets the property ExistingRuleContentSha256.
///
/// The SHA-256 hash signature for the content of the approval rule. You can retrieve
/// this information by using GetPullRequest.
///
///
public string ExistingRuleContentSha256
{
get { return this._existingRuleContentSha256; }
set { this._existingRuleContentSha256 = value; }
}
// Check to see if ExistingRuleContentSha256 property is set
internal bool IsSetExistingRuleContentSha256()
{
return this._existingRuleContentSha256 != null;
}
///
/// Gets and sets the property NewRuleContent.
///
/// The updated content for the approval rule.
///
///
///
/// When you update the content of the approval rule, you can specify approvers in an
/// approval pool in one of two ways:
///
/// -
///
/// CodeCommitApprovers: This option only requires an AWS account and a resource.
/// It can be used for both IAM users and federated access users whose name matches the
/// provided resource name. This is a very powerful option that offers a great deal of
/// flexibility. For example, if you specify the AWS account 123456789012 and Mary_Major,
/// all of the following are counted as approvals coming from that user:
///
///
-
///
/// An IAM user in the account (arn:aws:iam::123456789012:user/Mary_Major)
///
///
-
///
/// A federated user identified in IAM as Mary_Major (arn:aws:sts::123456789012:federated-user/Mary_Major)
///
///
///
/// This option does not recognize an active session of someone assuming the role of CodeCommitReview
/// with a role session name of Mary_Major (arn:aws:sts::123456789012:assumed-role/CodeCommitReview/Mary_Major)
/// unless you include a wildcard (*Mary_Major).
///
/// -
///
/// Fully qualified ARN: This option allows you to specify the fully qualified
/// Amazon Resource Name (ARN) of the IAM user or role.
///
///
///
/// For more information about IAM ARNs, wildcards, and formats, see IAM
/// Identifiers in the IAM User Guide.
///
///
///
[AWSProperty(Required=true, Min=1, Max=3000)]
public string NewRuleContent
{
get { return this._newRuleContent; }
set { this._newRuleContent = value; }
}
// Check to see if NewRuleContent property is set
internal bool IsSetNewRuleContent()
{
return this._newRuleContent != null;
}
///
/// Gets and sets the property PullRequestId.
///
/// The system-generated ID of the pull request.
///
///
[AWSProperty(Required=true)]
public string PullRequestId
{
get { return this._pullRequestId; }
set { this._pullRequestId = value; }
}
// Check to see if PullRequestId property is set
internal bool IsSetPullRequestId()
{
return this._pullRequestId != null;
}
}
}