package Paws::Chime::UpdateSipRule;
  use Moose;
  has Disabled => (is => 'ro', isa => 'Bool');
  has Name => (is => 'ro', isa => 'Str', required => 1);
  has SipRuleId => (is => 'ro', isa => 'Str', traits => ['ParamInURI'], uri_name => 'sipRuleId', required => 1);
  has TargetApplications => (is => 'ro', isa => 'ArrayRef[Paws::Chime::SipRuleTargetApplication]');

  use MooseX::ClassAttribute;

  class_has _api_call => (isa => 'Str', is => 'ro', default => 'UpdateSipRule');
  class_has _api_uri  => (isa => 'Str', is => 'ro', default => '/sip-rules/{sipRuleId}');
  class_has _api_method  => (isa => 'Str', is => 'ro', default => 'PUT');
  class_has _returns => (isa => 'Str', is => 'ro', default => 'Paws::Chime::UpdateSipRuleResponse');
1;

### main pod documentation begin ###

=head1 NAME

Paws::Chime::UpdateSipRule - Arguments for method UpdateSipRule on L<Paws::Chime>

=head1 DESCRIPTION

This class represents the parameters used for calling the method UpdateSipRule on the
L<Amazon Chime|Paws::Chime> service. Use the attributes of this class
as arguments to method UpdateSipRule.

You shouldn't make instances of this class. Each attribute should be used as a named argument in the call to UpdateSipRule.

=head1 SYNOPSIS

    my $chime = Paws->service('Chime');
    my $UpdateSipRuleResponse = $chime->UpdateSipRule(
      Name               => 'MySipRuleName',
      SipRuleId          => 'MyNonEmptyString',
      Disabled           => 1,                    # OPTIONAL
      TargetApplications => [
        {
          AwsRegion             => 'MyString',           # OPTIONAL
          Priority              => 1,                    # min: 1; OPTIONAL
          SipMediaApplicationId => 'MyNonEmptyString',
        },
        ...
      ],    # OPTIONAL
    );

    # Results:
    my $SipRule = $UpdateSipRuleResponse->SipRule;

    # Returns a L<Paws::Chime::UpdateSipRuleResponse> object.

Values for attributes that are native types (Int, String, Float, etc) can passed as-is (scalar values). Values for complex Types (objects) can be passed as a HashRef. The keys and values of the hashref will be used to instance the underlying object.
For the AWS API documentation, see L<https://docs.aws.amazon.com/goto/WebAPI/chime/UpdateSipRule>

=head1 ATTRIBUTES


=head2 Disabled => Bool

The new value specified to indicate whether the rule is disabled.



=head2 B<REQUIRED> Name => Str

The new name for the specified SIP rule.



=head2 B<REQUIRED> SipRuleId => Str

The SIP rule ID.



=head2 TargetApplications => ArrayRef[L<Paws::Chime::SipRuleTargetApplication>]

The new value of the list of target applications.




=head1 SEE ALSO

This class forms part of L<Paws>, documenting arguments for method UpdateSipRule in L<Paws::Chime>

=head1 BUGS and CONTRIBUTIONS

The source code is located here: L<https://github.com/pplu/aws-sdk-perl>

Please report bugs to: L<https://github.com/pplu/aws-sdk-perl/issues>

=cut