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

The case-sensitive name of the new group. Default is a reserved name and * names must be unique.

*/ inline const Aws::String& GetGroupName() const{ return m_groupName; } /** *

The case-sensitive name of the new group. Default is a reserved name and * names must be unique.

*/ inline bool GroupNameHasBeenSet() const { return m_groupNameHasBeenSet; } /** *

The case-sensitive name of the new group. Default is a reserved name and * names must be unique.

*/ inline void SetGroupName(const Aws::String& value) { m_groupNameHasBeenSet = true; m_groupName = value; } /** *

The case-sensitive name of the new group. Default is a reserved name and * names must be unique.

*/ inline void SetGroupName(Aws::String&& value) { m_groupNameHasBeenSet = true; m_groupName = std::move(value); } /** *

The case-sensitive name of the new group. Default is a reserved name and * names must be unique.

*/ inline void SetGroupName(const char* value) { m_groupNameHasBeenSet = true; m_groupName.assign(value); } /** *

The case-sensitive name of the new group. Default is a reserved name and * names must be unique.

*/ inline CreateGroupRequest& WithGroupName(const Aws::String& value) { SetGroupName(value); return *this;} /** *

The case-sensitive name of the new group. Default is a reserved name and * names must be unique.

*/ inline CreateGroupRequest& WithGroupName(Aws::String&& value) { SetGroupName(std::move(value)); return *this;} /** *

The case-sensitive name of the new group. Default is a reserved name and * names must be unique.

*/ inline CreateGroupRequest& WithGroupName(const char* value) { SetGroupName(value); return *this;} /** *

The filter expression defining criteria by which to group traces.

*/ inline const Aws::String& GetFilterExpression() const{ return m_filterExpression; } /** *

The filter expression defining criteria by which to group traces.

*/ inline bool FilterExpressionHasBeenSet() const { return m_filterExpressionHasBeenSet; } /** *

The filter expression defining criteria by which to group traces.

*/ inline void SetFilterExpression(const Aws::String& value) { m_filterExpressionHasBeenSet = true; m_filterExpression = value; } /** *

The filter expression defining criteria by which to group traces.

*/ inline void SetFilterExpression(Aws::String&& value) { m_filterExpressionHasBeenSet = true; m_filterExpression = std::move(value); } /** *

The filter expression defining criteria by which to group traces.

*/ inline void SetFilterExpression(const char* value) { m_filterExpressionHasBeenSet = true; m_filterExpression.assign(value); } /** *

The filter expression defining criteria by which to group traces.

*/ inline CreateGroupRequest& WithFilterExpression(const Aws::String& value) { SetFilterExpression(value); return *this;} /** *

The filter expression defining criteria by which to group traces.

*/ inline CreateGroupRequest& WithFilterExpression(Aws::String&& value) { SetFilterExpression(std::move(value)); return *this;} /** *

The filter expression defining criteria by which to group traces.

*/ inline CreateGroupRequest& WithFilterExpression(const char* value) { SetFilterExpression(value); return *this;} /** *

The structure containing configurations related to insights.

  • *

    The InsightsEnabled boolean can be set to true to enable insights for the new * group or false to disable insights for the new group.

  • The * NotificationsEnabled boolean can be set to true to enable insights notifications * for the new group. Notifications may only be enabled on a group with * InsightsEnabled set to true.

*/ inline const InsightsConfiguration& GetInsightsConfiguration() const{ return m_insightsConfiguration; } /** *

The structure containing configurations related to insights.

  • *

    The InsightsEnabled boolean can be set to true to enable insights for the new * group or false to disable insights for the new group.

  • The * NotificationsEnabled boolean can be set to true to enable insights notifications * for the new group. Notifications may only be enabled on a group with * InsightsEnabled set to true.

*/ inline bool InsightsConfigurationHasBeenSet() const { return m_insightsConfigurationHasBeenSet; } /** *

The structure containing configurations related to insights.

  • *

    The InsightsEnabled boolean can be set to true to enable insights for the new * group or false to disable insights for the new group.

  • The * NotificationsEnabled boolean can be set to true to enable insights notifications * for the new group. Notifications may only be enabled on a group with * InsightsEnabled set to true.

*/ inline void SetInsightsConfiguration(const InsightsConfiguration& value) { m_insightsConfigurationHasBeenSet = true; m_insightsConfiguration = value; } /** *

The structure containing configurations related to insights.

  • *

    The InsightsEnabled boolean can be set to true to enable insights for the new * group or false to disable insights for the new group.

  • The * NotificationsEnabled boolean can be set to true to enable insights notifications * for the new group. Notifications may only be enabled on a group with * InsightsEnabled set to true.

*/ inline void SetInsightsConfiguration(InsightsConfiguration&& value) { m_insightsConfigurationHasBeenSet = true; m_insightsConfiguration = std::move(value); } /** *

The structure containing configurations related to insights.

  • *

    The InsightsEnabled boolean can be set to true to enable insights for the new * group or false to disable insights for the new group.

  • The * NotificationsEnabled boolean can be set to true to enable insights notifications * for the new group. Notifications may only be enabled on a group with * InsightsEnabled set to true.

*/ inline CreateGroupRequest& WithInsightsConfiguration(const InsightsConfiguration& value) { SetInsightsConfiguration(value); return *this;} /** *

The structure containing configurations related to insights.

  • *

    The InsightsEnabled boolean can be set to true to enable insights for the new * group or false to disable insights for the new group.

  • The * NotificationsEnabled boolean can be set to true to enable insights notifications * for the new group. Notifications may only be enabled on a group with * InsightsEnabled set to true.

*/ inline CreateGroupRequest& WithInsightsConfiguration(InsightsConfiguration&& value) { SetInsightsConfiguration(std::move(value)); return *this;} /** *

A map that contains one or more tag keys and tag values to attach to an X-Ray * group. For more information about ways to use tags, see Tagging * Amazon Web Services resources in the Amazon Web Services General * Reference.

The following restrictions apply to tags:

  • *

    Maximum number of user-applied tags per resource: 50

  • *

    Maximum tag key length: 128 Unicode characters

  • Maximum tag * value length: 256 Unicode characters

  • Valid values for key and * value: a-z, A-Z, 0-9, space, and the following characters: _ . : / = + - and * @

  • Tag keys and values are case sensitive.

  • *

    Don't use aws: as a prefix for keys; it's reserved for Amazon * Web Services use.

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

A map that contains one or more tag keys and tag values to attach to an X-Ray * group. For more information about ways to use tags, see Tagging * Amazon Web Services resources in the Amazon Web Services General * Reference.

The following restrictions apply to tags:

  • *

    Maximum number of user-applied tags per resource: 50

  • *

    Maximum tag key length: 128 Unicode characters

  • Maximum tag * value length: 256 Unicode characters

  • Valid values for key and * value: a-z, A-Z, 0-9, space, and the following characters: _ . : / = + - and * @

  • Tag keys and values are case sensitive.

  • *

    Don't use aws: as a prefix for keys; it's reserved for Amazon * Web Services use.

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

A map that contains one or more tag keys and tag values to attach to an X-Ray * group. For more information about ways to use tags, see Tagging * Amazon Web Services resources in the Amazon Web Services General * Reference.

The following restrictions apply to tags:

  • *

    Maximum number of user-applied tags per resource: 50

  • *

    Maximum tag key length: 128 Unicode characters

  • Maximum tag * value length: 256 Unicode characters

  • Valid values for key and * value: a-z, A-Z, 0-9, space, and the following characters: _ . : / = + - and * @

  • Tag keys and values are case sensitive.

  • *

    Don't use aws: as a prefix for keys; it's reserved for Amazon * Web Services use.

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

A map that contains one or more tag keys and tag values to attach to an X-Ray * group. For more information about ways to use tags, see Tagging * Amazon Web Services resources in the Amazon Web Services General * Reference.

The following restrictions apply to tags:

  • *

    Maximum number of user-applied tags per resource: 50

  • *

    Maximum tag key length: 128 Unicode characters

  • Maximum tag * value length: 256 Unicode characters

  • Valid values for key and * value: a-z, A-Z, 0-9, space, and the following characters: _ . : / = + - and * @

  • Tag keys and values are case sensitive.

  • *

    Don't use aws: as a prefix for keys; it's reserved for Amazon * Web Services use.

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

A map that contains one or more tag keys and tag values to attach to an X-Ray * group. For more information about ways to use tags, see Tagging * Amazon Web Services resources in the Amazon Web Services General * Reference.

The following restrictions apply to tags:

  • *

    Maximum number of user-applied tags per resource: 50

  • *

    Maximum tag key length: 128 Unicode characters

  • Maximum tag * value length: 256 Unicode characters

  • Valid values for key and * value: a-z, A-Z, 0-9, space, and the following characters: _ . : / = + - and * @

  • Tag keys and values are case sensitive.

  • *

    Don't use aws: as a prefix for keys; it's reserved for Amazon * Web Services use.

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

A map that contains one or more tag keys and tag values to attach to an X-Ray * group. For more information about ways to use tags, see Tagging * Amazon Web Services resources in the Amazon Web Services General * Reference.

The following restrictions apply to tags:

  • *

    Maximum number of user-applied tags per resource: 50

  • *

    Maximum tag key length: 128 Unicode characters

  • Maximum tag * value length: 256 Unicode characters

  • Valid values for key and * value: a-z, A-Z, 0-9, space, and the following characters: _ . : / = + - and * @

  • Tag keys and values are case sensitive.

  • *

    Don't use aws: as a prefix for keys; it's reserved for Amazon * Web Services use.

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

A map that contains one or more tag keys and tag values to attach to an X-Ray * group. For more information about ways to use tags, see Tagging * Amazon Web Services resources in the Amazon Web Services General * Reference.

The following restrictions apply to tags:

  • *

    Maximum number of user-applied tags per resource: 50

  • *

    Maximum tag key length: 128 Unicode characters

  • Maximum tag * value length: 256 Unicode characters

  • Valid values for key and * value: a-z, A-Z, 0-9, space, and the following characters: _ . : / = + - and * @

  • Tag keys and values are case sensitive.

  • *

    Don't use aws: as a prefix for keys; it's reserved for Amazon * Web Services use.

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

A map that contains one or more tag keys and tag values to attach to an X-Ray * group. For more information about ways to use tags, see Tagging * Amazon Web Services resources in the Amazon Web Services General * Reference.

The following restrictions apply to tags:

  • *

    Maximum number of user-applied tags per resource: 50

  • *

    Maximum tag key length: 128 Unicode characters

  • Maximum tag * value length: 256 Unicode characters

  • Valid values for key and * value: a-z, A-Z, 0-9, space, and the following characters: _ . : / = + - and * @

  • Tag keys and values are case sensitive.

  • *

    Don't use aws: as a prefix for keys; it's reserved for Amazon * Web Services use.

*/ inline CreateGroupRequest& AddTags(Tag&& value) { m_tagsHasBeenSet = true; m_tags.push_back(std::move(value)); return *this; } private: Aws::String m_groupName; bool m_groupNameHasBeenSet = false; Aws::String m_filterExpression; bool m_filterExpressionHasBeenSet = false; InsightsConfiguration m_insightsConfiguration; bool m_insightsConfigurationHasBeenSet = false; Aws::Vector m_tags; bool m_tagsHasBeenSet = false; }; } // namespace Model } // namespace XRay } // namespace Aws