/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include #include namespace Aws { namespace RAM { namespace Model { /** */ class CreateResourceShareRequest : public RAMRequest { public: AWS_RAM_API CreateResourceShareRequest(); // Service request name is the Operation name which will send this request out, // each operation should has unique request name, so that we can get operation's name from this request. // Note: this is not true for response, multiple operations may have the same response name, // so we can not get operation's name from response. inline virtual const char* GetServiceRequestName() const override { return "CreateResourceShare"; } AWS_RAM_API Aws::String SerializePayload() const override; /** *

Specifies the name of the resource share.

*/ inline const Aws::String& GetName() const{ return m_name; } /** *

Specifies the name of the resource share.

*/ inline bool NameHasBeenSet() const { return m_nameHasBeenSet; } /** *

Specifies the name of the resource share.

*/ inline void SetName(const Aws::String& value) { m_nameHasBeenSet = true; m_name = value; } /** *

Specifies the name of the resource share.

*/ inline void SetName(Aws::String&& value) { m_nameHasBeenSet = true; m_name = std::move(value); } /** *

Specifies the name of the resource share.

*/ inline void SetName(const char* value) { m_nameHasBeenSet = true; m_name.assign(value); } /** *

Specifies the name of the resource share.

*/ inline CreateResourceShareRequest& WithName(const Aws::String& value) { SetName(value); return *this;} /** *

Specifies the name of the resource share.

*/ inline CreateResourceShareRequest& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;} /** *

Specifies the name of the resource share.

*/ inline CreateResourceShareRequest& WithName(const char* value) { SetName(value); return *this;} /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline const Aws::Vector& GetResourceArns() const{ return m_resourceArns; } /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline bool ResourceArnsHasBeenSet() const { return m_resourceArnsHasBeenSet; } /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline void SetResourceArns(const Aws::Vector& value) { m_resourceArnsHasBeenSet = true; m_resourceArns = value; } /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline void SetResourceArns(Aws::Vector&& value) { m_resourceArnsHasBeenSet = true; m_resourceArns = std::move(value); } /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline CreateResourceShareRequest& WithResourceArns(const Aws::Vector& value) { SetResourceArns(value); return *this;} /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline CreateResourceShareRequest& WithResourceArns(Aws::Vector&& value) { SetResourceArns(std::move(value)); return *this;} /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline CreateResourceShareRequest& AddResourceArns(const Aws::String& value) { m_resourceArnsHasBeenSet = true; m_resourceArns.push_back(value); return *this; } /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline CreateResourceShareRequest& AddResourceArns(Aws::String&& value) { m_resourceArnsHasBeenSet = true; m_resourceArns.push_back(std::move(value)); return *this; } /** *

Specifies a list of one or more ARNs of the resources to associate with the * resource share.

*/ inline CreateResourceShareRequest& AddResourceArns(const char* value) { m_resourceArnsHasBeenSet = true; m_resourceArns.push_back(value); return *this; } /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline const Aws::Vector& GetPrincipals() const{ return m_principals; } /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline bool PrincipalsHasBeenSet() const { return m_principalsHasBeenSet; } /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline void SetPrincipals(const Aws::Vector& value) { m_principalsHasBeenSet = true; m_principals = value; } /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline void SetPrincipals(Aws::Vector&& value) { m_principalsHasBeenSet = true; m_principals = std::move(value); } /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline CreateResourceShareRequest& WithPrincipals(const Aws::Vector& value) { SetPrincipals(value); return *this;} /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline CreateResourceShareRequest& WithPrincipals(Aws::Vector&& value) { SetPrincipals(std::move(value)); return *this;} /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline CreateResourceShareRequest& AddPrincipals(const Aws::String& value) { m_principalsHasBeenSet = true; m_principals.push_back(value); return *this; } /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline CreateResourceShareRequest& AddPrincipals(Aws::String&& value) { m_principalsHasBeenSet = true; m_principals.push_back(std::move(value)); return *this; } /** *

Specifies a list of one or more principals to associate with the resource * share.

You can include the following values:

  • An Amazon * Web Services account ID, for example: 123456789012

  • *

    An Amazon * Resource Name (ARN) of an organization in Organizations, for example: * organizations::123456789012:organization/o-exampleorgid

  • *
  • An ARN of an organizational unit (OU) in Organizations, for example: * organizations::123456789012:ou/o-exampleorgid/ou-examplerootid-exampleouid123 *

  • An ARN of an IAM role, for example: * iam::123456789012:role/rolename

  • An ARN of an IAM * user, for example: iam::123456789012user/username

*

Not all resource types can be shared with IAM roles and users. For * more information, see Sharing * with IAM roles and users in the Resource Access Manager User * Guide.

*/ inline CreateResourceShareRequest& AddPrincipals(const char* value) { m_principalsHasBeenSet = true; m_principals.push_back(value); return *this; } /** *

Specifies one or more tags to attach to the resource share itself. It doesn't * attach the tags to the resources associated with the resource share.

*/ inline const Aws::Vector& GetTags() const{ return m_tags; } /** *

Specifies one or more tags to attach to the resource share itself. It doesn't * attach the tags to the resources associated with the resource share.

*/ inline bool TagsHasBeenSet() const { return m_tagsHasBeenSet; } /** *

Specifies one or more tags to attach to the resource share itself. It doesn't * attach the tags to the resources associated with the resource share.

*/ inline void SetTags(const Aws::Vector& value) { m_tagsHasBeenSet = true; m_tags = value; } /** *

Specifies one or more tags to attach to the resource share itself. It doesn't * attach the tags to the resources associated with the resource share.

*/ inline void SetTags(Aws::Vector&& value) { m_tagsHasBeenSet = true; m_tags = std::move(value); } /** *

Specifies one or more tags to attach to the resource share itself. It doesn't * attach the tags to the resources associated with the resource share.

*/ inline CreateResourceShareRequest& WithTags(const Aws::Vector& value) { SetTags(value); return *this;} /** *

Specifies one or more tags to attach to the resource share itself. It doesn't * attach the tags to the resources associated with the resource share.

*/ inline CreateResourceShareRequest& WithTags(Aws::Vector&& value) { SetTags(std::move(value)); return *this;} /** *

Specifies one or more tags to attach to the resource share itself. It doesn't * attach the tags to the resources associated with the resource share.

*/ inline CreateResourceShareRequest& AddTags(const Tag& value) { m_tagsHasBeenSet = true; m_tags.push_back(value); return *this; } /** *

Specifies one or more tags to attach to the resource share itself. It doesn't * attach the tags to the resources associated with the resource share.

*/ inline CreateResourceShareRequest& AddTags(Tag&& value) { m_tagsHasBeenSet = true; m_tags.push_back(std::move(value)); return *this; } /** *

Specifies whether principals outside your organization in Organizations can * be associated with a resource share. A value of true lets you share * with individual Amazon Web Services accounts that are not in your * organization. A value of false only has meaning if your account is * a member of an Amazon Web Services Organization. The default value is * true.

*/ inline bool GetAllowExternalPrincipals() const{ return m_allowExternalPrincipals; } /** *

Specifies whether principals outside your organization in Organizations can * be associated with a resource share. A value of true lets you share * with individual Amazon Web Services accounts that are not in your * organization. A value of false only has meaning if your account is * a member of an Amazon Web Services Organization. The default value is * true.

*/ inline bool AllowExternalPrincipalsHasBeenSet() const { return m_allowExternalPrincipalsHasBeenSet; } /** *

Specifies whether principals outside your organization in Organizations can * be associated with a resource share. A value of true lets you share * with individual Amazon Web Services accounts that are not in your * organization. A value of false only has meaning if your account is * a member of an Amazon Web Services Organization. The default value is * true.

*/ inline void SetAllowExternalPrincipals(bool value) { m_allowExternalPrincipalsHasBeenSet = true; m_allowExternalPrincipals = value; } /** *

Specifies whether principals outside your organization in Organizations can * be associated with a resource share. A value of true lets you share * with individual Amazon Web Services accounts that are not in your * organization. A value of false only has meaning if your account is * a member of an Amazon Web Services Organization. The default value is * true.

*/ inline CreateResourceShareRequest& WithAllowExternalPrincipals(bool value) { SetAllowExternalPrincipals(value); return *this;} /** *

Specifies a unique, case-sensitive identifier that you provide to ensure the * idempotency of the request. This lets you safely retry the request without * accidentally performing the same operation a second time. Passing the same value * to a later call to an operation requires that you also pass the same value for * all other parameters. We recommend that you use a UUID type of * value..

If you don't provide this value, then Amazon Web Services * generates a random one for you.

If you retry the operation with the same * ClientToken, but with different parameters, the retry fails with an * IdempotentParameterMismatch error.

*/ inline const Aws::String& GetClientToken() const{ return m_clientToken; } /** *

Specifies a unique, case-sensitive identifier that you provide to ensure the * idempotency of the request. This lets you safely retry the request without * accidentally performing the same operation a second time. Passing the same value * to a later call to an operation requires that you also pass the same value for * all other parameters. We recommend that you use a UUID type of * value..

If you don't provide this value, then Amazon Web Services * generates a random one for you.

If you retry the operation with the same * ClientToken, but with different parameters, the retry fails with an * IdempotentParameterMismatch error.

*/ inline bool ClientTokenHasBeenSet() const { return m_clientTokenHasBeenSet; } /** *

Specifies a unique, case-sensitive identifier that you provide to ensure the * idempotency of the request. This lets you safely retry the request without * accidentally performing the same operation a second time. Passing the same value * to a later call to an operation requires that you also pass the same value for * all other parameters. We recommend that you use a UUID type of * value..

If you don't provide this value, then Amazon Web Services * generates a random one for you.

If you retry the operation with the same * ClientToken, but with different parameters, the retry fails with an * IdempotentParameterMismatch error.

*/ inline void SetClientToken(const Aws::String& value) { m_clientTokenHasBeenSet = true; m_clientToken = value; } /** *

Specifies a unique, case-sensitive identifier that you provide to ensure the * idempotency of the request. This lets you safely retry the request without * accidentally performing the same operation a second time. Passing the same value * to a later call to an operation requires that you also pass the same value for * all other parameters. We recommend that you use a UUID type of * value..

If you don't provide this value, then Amazon Web Services * generates a random one for you.

If you retry the operation with the same * ClientToken, but with different parameters, the retry fails with an * IdempotentParameterMismatch error.

*/ inline void SetClientToken(Aws::String&& value) { m_clientTokenHasBeenSet = true; m_clientToken = std::move(value); } /** *

Specifies a unique, case-sensitive identifier that you provide to ensure the * idempotency of the request. This lets you safely retry the request without * accidentally performing the same operation a second time. Passing the same value * to a later call to an operation requires that you also pass the same value for * all other parameters. We recommend that you use a UUID type of * value..

If you don't provide this value, then Amazon Web Services * generates a random one for you.

If you retry the operation with the same * ClientToken, but with different parameters, the retry fails with an * IdempotentParameterMismatch error.

*/ inline void SetClientToken(const char* value) { m_clientTokenHasBeenSet = true; m_clientToken.assign(value); } /** *

Specifies a unique, case-sensitive identifier that you provide to ensure the * idempotency of the request. This lets you safely retry the request without * accidentally performing the same operation a second time. Passing the same value * to a later call to an operation requires that you also pass the same value for * all other parameters. We recommend that you use a UUID type of * value..

If you don't provide this value, then Amazon Web Services * generates a random one for you.

If you retry the operation with the same * ClientToken, but with different parameters, the retry fails with an * IdempotentParameterMismatch error.

*/ inline CreateResourceShareRequest& WithClientToken(const Aws::String& value) { SetClientToken(value); return *this;} /** *

Specifies a unique, case-sensitive identifier that you provide to ensure the * idempotency of the request. This lets you safely retry the request without * accidentally performing the same operation a second time. Passing the same value * to a later call to an operation requires that you also pass the same value for * all other parameters. We recommend that you use a UUID type of * value..

If you don't provide this value, then Amazon Web Services * generates a random one for you.

If you retry the operation with the same * ClientToken, but with different parameters, the retry fails with an * IdempotentParameterMismatch error.

*/ inline CreateResourceShareRequest& WithClientToken(Aws::String&& value) { SetClientToken(std::move(value)); return *this;} /** *

Specifies a unique, case-sensitive identifier that you provide to ensure the * idempotency of the request. This lets you safely retry the request without * accidentally performing the same operation a second time. Passing the same value * to a later call to an operation requires that you also pass the same value for * all other parameters. We recommend that you use a UUID type of * value..

If you don't provide this value, then Amazon Web Services * generates a random one for you.

If you retry the operation with the same * ClientToken, but with different parameters, the retry fails with an * IdempotentParameterMismatch error.

*/ inline CreateResourceShareRequest& WithClientToken(const char* value) { SetClientToken(value); return *this;} /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline const Aws::Vector& GetPermissionArns() const{ return m_permissionArns; } /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline bool PermissionArnsHasBeenSet() const { return m_permissionArnsHasBeenSet; } /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline void SetPermissionArns(const Aws::Vector& value) { m_permissionArnsHasBeenSet = true; m_permissionArns = value; } /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline void SetPermissionArns(Aws::Vector&& value) { m_permissionArnsHasBeenSet = true; m_permissionArns = std::move(value); } /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline CreateResourceShareRequest& WithPermissionArns(const Aws::Vector& value) { SetPermissionArns(value); return *this;} /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline CreateResourceShareRequest& WithPermissionArns(Aws::Vector&& value) { SetPermissionArns(std::move(value)); return *this;} /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline CreateResourceShareRequest& AddPermissionArns(const Aws::String& value) { m_permissionArnsHasBeenSet = true; m_permissionArns.push_back(value); return *this; } /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline CreateResourceShareRequest& AddPermissionArns(Aws::String&& value) { m_permissionArnsHasBeenSet = true; m_permissionArns.push_back(std::move(value)); return *this; } /** *

Specifies the Amazon * Resource Names (ARNs) of the RAM permission to associate with the resource * share. If you do not specify an ARN for the permission, RAM automatically * attaches the default version of the permission for each resource type. You can * associate only one permission with each resource type included in the resource * share.

*/ inline CreateResourceShareRequest& AddPermissionArns(const char* value) { m_permissionArnsHasBeenSet = true; m_permissionArns.push_back(value); return *this; } /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline const Aws::Vector& GetSources() const{ return m_sources; } /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline bool SourcesHasBeenSet() const { return m_sourcesHasBeenSet; } /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline void SetSources(const Aws::Vector& value) { m_sourcesHasBeenSet = true; m_sources = value; } /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline void SetSources(Aws::Vector&& value) { m_sourcesHasBeenSet = true; m_sources = std::move(value); } /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline CreateResourceShareRequest& WithSources(const Aws::Vector& value) { SetSources(value); return *this;} /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline CreateResourceShareRequest& WithSources(Aws::Vector&& value) { SetSources(std::move(value)); return *this;} /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline CreateResourceShareRequest& AddSources(const Aws::String& value) { m_sourcesHasBeenSet = true; m_sources.push_back(value); return *this; } /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline CreateResourceShareRequest& AddSources(Aws::String&& value) { m_sourcesHasBeenSet = true; m_sources.push_back(std::move(value)); return *this; } /** *

Specifies from which source accounts the service principal has access to the * resources in this resource share.

*/ inline CreateResourceShareRequest& AddSources(const char* value) { m_sourcesHasBeenSet = true; m_sources.push_back(value); return *this; } private: Aws::String m_name; bool m_nameHasBeenSet = false; Aws::Vector m_resourceArns; bool m_resourceArnsHasBeenSet = false; Aws::Vector m_principals; bool m_principalsHasBeenSet = false; Aws::Vector m_tags; bool m_tagsHasBeenSet = false; bool m_allowExternalPrincipals; bool m_allowExternalPrincipalsHasBeenSet = false; Aws::String m_clientToken; bool m_clientTokenHasBeenSet = false; Aws::Vector m_permissionArns; bool m_permissionArnsHasBeenSet = false; Aws::Vector m_sources; bool m_sourcesHasBeenSet = false; }; } // namespace Model } // namespace RAM } // namespace Aws