/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include namespace Aws { namespace XRay { namespace Model { /** */ class PutResourcePolicyRequest : public XRayRequest { public: AWS_XRAY_API PutResourcePolicyRequest(); // 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 "PutResourcePolicy"; } AWS_XRAY_API Aws::String SerializePayload() const override; /** *

The name of the resource policy. Must be unique within a specific Amazon Web * Services account.

*/ inline const Aws::String& GetPolicyName() const{ return m_policyName; } /** *

The name of the resource policy. Must be unique within a specific Amazon Web * Services account.

*/ inline bool PolicyNameHasBeenSet() const { return m_policyNameHasBeenSet; } /** *

The name of the resource policy. Must be unique within a specific Amazon Web * Services account.

*/ inline void SetPolicyName(const Aws::String& value) { m_policyNameHasBeenSet = true; m_policyName = value; } /** *

The name of the resource policy. Must be unique within a specific Amazon Web * Services account.

*/ inline void SetPolicyName(Aws::String&& value) { m_policyNameHasBeenSet = true; m_policyName = std::move(value); } /** *

The name of the resource policy. Must be unique within a specific Amazon Web * Services account.

*/ inline void SetPolicyName(const char* value) { m_policyNameHasBeenSet = true; m_policyName.assign(value); } /** *

The name of the resource policy. Must be unique within a specific Amazon Web * Services account.

*/ inline PutResourcePolicyRequest& WithPolicyName(const Aws::String& value) { SetPolicyName(value); return *this;} /** *

The name of the resource policy. Must be unique within a specific Amazon Web * Services account.

*/ inline PutResourcePolicyRequest& WithPolicyName(Aws::String&& value) { SetPolicyName(std::move(value)); return *this;} /** *

The name of the resource policy. Must be unique within a specific Amazon Web * Services account.

*/ inline PutResourcePolicyRequest& WithPolicyName(const char* value) { SetPolicyName(value); return *this;} /** *

The resource policy document, which can be up to 5kb in size.

*/ inline const Aws::String& GetPolicyDocument() const{ return m_policyDocument; } /** *

The resource policy document, which can be up to 5kb in size.

*/ inline bool PolicyDocumentHasBeenSet() const { return m_policyDocumentHasBeenSet; } /** *

The resource policy document, which can be up to 5kb in size.

*/ inline void SetPolicyDocument(const Aws::String& value) { m_policyDocumentHasBeenSet = true; m_policyDocument = value; } /** *

The resource policy document, which can be up to 5kb in size.

*/ inline void SetPolicyDocument(Aws::String&& value) { m_policyDocumentHasBeenSet = true; m_policyDocument = std::move(value); } /** *

The resource policy document, which can be up to 5kb in size.

*/ inline void SetPolicyDocument(const char* value) { m_policyDocumentHasBeenSet = true; m_policyDocument.assign(value); } /** *

The resource policy document, which can be up to 5kb in size.

*/ inline PutResourcePolicyRequest& WithPolicyDocument(const Aws::String& value) { SetPolicyDocument(value); return *this;} /** *

The resource policy document, which can be up to 5kb in size.

*/ inline PutResourcePolicyRequest& WithPolicyDocument(Aws::String&& value) { SetPolicyDocument(std::move(value)); return *this;} /** *

The resource policy document, which can be up to 5kb in size.

*/ inline PutResourcePolicyRequest& WithPolicyDocument(const char* value) { SetPolicyDocument(value); return *this;} /** *

Specifies a specific policy revision, to ensure an atomic create operation. * By default the resource policy is created if it does not exist, or updated with * an incremented revision id. The revision id is unique to each policy in the * account.

If the policy revision id does not match the latest revision id, * the operation will fail with an InvalidPolicyRevisionIdException * exception. You can also provide a PolicyRevisionId of 0. In this * case, the operation will fail with an * InvalidPolicyRevisionIdException exception if a resource policy * with the same name already exists.

*/ inline const Aws::String& GetPolicyRevisionId() const{ return m_policyRevisionId; } /** *

Specifies a specific policy revision, to ensure an atomic create operation. * By default the resource policy is created if it does not exist, or updated with * an incremented revision id. The revision id is unique to each policy in the * account.

If the policy revision id does not match the latest revision id, * the operation will fail with an InvalidPolicyRevisionIdException * exception. You can also provide a PolicyRevisionId of 0. In this * case, the operation will fail with an * InvalidPolicyRevisionIdException exception if a resource policy * with the same name already exists.

*/ inline bool PolicyRevisionIdHasBeenSet() const { return m_policyRevisionIdHasBeenSet; } /** *

Specifies a specific policy revision, to ensure an atomic create operation. * By default the resource policy is created if it does not exist, or updated with * an incremented revision id. The revision id is unique to each policy in the * account.

If the policy revision id does not match the latest revision id, * the operation will fail with an InvalidPolicyRevisionIdException * exception. You can also provide a PolicyRevisionId of 0. In this * case, the operation will fail with an * InvalidPolicyRevisionIdException exception if a resource policy * with the same name already exists.

*/ inline void SetPolicyRevisionId(const Aws::String& value) { m_policyRevisionIdHasBeenSet = true; m_policyRevisionId = value; } /** *

Specifies a specific policy revision, to ensure an atomic create operation. * By default the resource policy is created if it does not exist, or updated with * an incremented revision id. The revision id is unique to each policy in the * account.

If the policy revision id does not match the latest revision id, * the operation will fail with an InvalidPolicyRevisionIdException * exception. You can also provide a PolicyRevisionId of 0. In this * case, the operation will fail with an * InvalidPolicyRevisionIdException exception if a resource policy * with the same name already exists.

*/ inline void SetPolicyRevisionId(Aws::String&& value) { m_policyRevisionIdHasBeenSet = true; m_policyRevisionId = std::move(value); } /** *

Specifies a specific policy revision, to ensure an atomic create operation. * By default the resource policy is created if it does not exist, or updated with * an incremented revision id. The revision id is unique to each policy in the * account.

If the policy revision id does not match the latest revision id, * the operation will fail with an InvalidPolicyRevisionIdException * exception. You can also provide a PolicyRevisionId of 0. In this * case, the operation will fail with an * InvalidPolicyRevisionIdException exception if a resource policy * with the same name already exists.

*/ inline void SetPolicyRevisionId(const char* value) { m_policyRevisionIdHasBeenSet = true; m_policyRevisionId.assign(value); } /** *

Specifies a specific policy revision, to ensure an atomic create operation. * By default the resource policy is created if it does not exist, or updated with * an incremented revision id. The revision id is unique to each policy in the * account.

If the policy revision id does not match the latest revision id, * the operation will fail with an InvalidPolicyRevisionIdException * exception. You can also provide a PolicyRevisionId of 0. In this * case, the operation will fail with an * InvalidPolicyRevisionIdException exception if a resource policy * with the same name already exists.

*/ inline PutResourcePolicyRequest& WithPolicyRevisionId(const Aws::String& value) { SetPolicyRevisionId(value); return *this;} /** *

Specifies a specific policy revision, to ensure an atomic create operation. * By default the resource policy is created if it does not exist, or updated with * an incremented revision id. The revision id is unique to each policy in the * account.

If the policy revision id does not match the latest revision id, * the operation will fail with an InvalidPolicyRevisionIdException * exception. You can also provide a PolicyRevisionId of 0. In this * case, the operation will fail with an * InvalidPolicyRevisionIdException exception if a resource policy * with the same name already exists.

*/ inline PutResourcePolicyRequest& WithPolicyRevisionId(Aws::String&& value) { SetPolicyRevisionId(std::move(value)); return *this;} /** *

Specifies a specific policy revision, to ensure an atomic create operation. * By default the resource policy is created if it does not exist, or updated with * an incremented revision id. The revision id is unique to each policy in the * account.

If the policy revision id does not match the latest revision id, * the operation will fail with an InvalidPolicyRevisionIdException * exception. You can also provide a PolicyRevisionId of 0. In this * case, the operation will fail with an * InvalidPolicyRevisionIdException exception if a resource policy * with the same name already exists.

*/ inline PutResourcePolicyRequest& WithPolicyRevisionId(const char* value) { SetPolicyRevisionId(value); return *this;} /** *

A flag to indicate whether to bypass the resource policy lockout safety * check.

Setting this value to true increases the risk that the * policy becomes unmanageable. Do not set this value to true indiscriminately.

*

Use this parameter only when you include a policy in the request * and you intend to prevent the principal that is making the request from making a * subsequent PutResourcePolicy request.

The default value is * false.

*/ inline bool GetBypassPolicyLockoutCheck() const{ return m_bypassPolicyLockoutCheck; } /** *

A flag to indicate whether to bypass the resource policy lockout safety * check.

Setting this value to true increases the risk that the * policy becomes unmanageable. Do not set this value to true indiscriminately.

*

Use this parameter only when you include a policy in the request * and you intend to prevent the principal that is making the request from making a * subsequent PutResourcePolicy request.

The default value is * false.

*/ inline bool BypassPolicyLockoutCheckHasBeenSet() const { return m_bypassPolicyLockoutCheckHasBeenSet; } /** *

A flag to indicate whether to bypass the resource policy lockout safety * check.

Setting this value to true increases the risk that the * policy becomes unmanageable. Do not set this value to true indiscriminately.

*

Use this parameter only when you include a policy in the request * and you intend to prevent the principal that is making the request from making a * subsequent PutResourcePolicy request.

The default value is * false.

*/ inline void SetBypassPolicyLockoutCheck(bool value) { m_bypassPolicyLockoutCheckHasBeenSet = true; m_bypassPolicyLockoutCheck = value; } /** *

A flag to indicate whether to bypass the resource policy lockout safety * check.

Setting this value to true increases the risk that the * policy becomes unmanageable. Do not set this value to true indiscriminately.

*

Use this parameter only when you include a policy in the request * and you intend to prevent the principal that is making the request from making a * subsequent PutResourcePolicy request.

The default value is * false.

*/ inline PutResourcePolicyRequest& WithBypassPolicyLockoutCheck(bool value) { SetBypassPolicyLockoutCheck(value); return *this;} private: Aws::String m_policyName; bool m_policyNameHasBeenSet = false; Aws::String m_policyDocument; bool m_policyDocumentHasBeenSet = false; Aws::String m_policyRevisionId; bool m_policyRevisionIdHasBeenSet = false; bool m_bypassPolicyLockoutCheck; bool m_bypassPolicyLockoutCheckHasBeenSet = false; }; } // namespace Model } // namespace XRay } // namespace Aws