/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include namespace Aws { namespace Utils { namespace Json { class JsonValue; class JsonView; } // namespace Json } // namespace Utils namespace Pinpoint { namespace Model { /** *

Specifies the name and version of the message template to use for the * message.

See Also:

AWS * API Reference

*/ class Template { public: AWS_PINPOINT_API Template(); AWS_PINPOINT_API Template(Aws::Utils::Json::JsonView jsonValue); AWS_PINPOINT_API Template& operator=(Aws::Utils::Json::JsonView jsonValue); AWS_PINPOINT_API Aws::Utils::Json::JsonValue Jsonize() const; /** *

The name of the message template to use for the message. If specified, this * value must match the name of an existing message template.

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

The name of the message template to use for the message. If specified, this * value must match the name of an existing message template.

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

The name of the message template to use for the message. If specified, this * value must match the name of an existing message template.

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

The name of the message template to use for the message. If specified, this * value must match the name of an existing message template.

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

The name of the message template to use for the message. If specified, this * value must match the name of an existing message template.

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

The name of the message template to use for the message. If specified, this * value must match the name of an existing message template.

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

The name of the message template to use for the message. If specified, this * value must match the name of an existing message template.

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

The name of the message template to use for the message. If specified, this * value must match the name of an existing message template.

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

The unique identifier for the version of the message template to use for the * message. If specified, this value must match the identifier for an existing * template version. To retrieve a list of versions and version identifiers for a * template, use the Template * Versions resource.

If you don't specify a value for this property, * Amazon Pinpoint uses the active version of the template. The active * version is typically the version of a template that's been most recently * reviewed and approved for use, depending on your workflow. It isn't necessarily * the latest version of a template.

*/ inline const Aws::String& GetVersion() const{ return m_version; } /** *

The unique identifier for the version of the message template to use for the * message. If specified, this value must match the identifier for an existing * template version. To retrieve a list of versions and version identifiers for a * template, use the Template * Versions resource.

If you don't specify a value for this property, * Amazon Pinpoint uses the active version of the template. The active * version is typically the version of a template that's been most recently * reviewed and approved for use, depending on your workflow. It isn't necessarily * the latest version of a template.

*/ inline bool VersionHasBeenSet() const { return m_versionHasBeenSet; } /** *

The unique identifier for the version of the message template to use for the * message. If specified, this value must match the identifier for an existing * template version. To retrieve a list of versions and version identifiers for a * template, use the Template * Versions resource.

If you don't specify a value for this property, * Amazon Pinpoint uses the active version of the template. The active * version is typically the version of a template that's been most recently * reviewed and approved for use, depending on your workflow. It isn't necessarily * the latest version of a template.

*/ inline void SetVersion(const Aws::String& value) { m_versionHasBeenSet = true; m_version = value; } /** *

The unique identifier for the version of the message template to use for the * message. If specified, this value must match the identifier for an existing * template version. To retrieve a list of versions and version identifiers for a * template, use the Template * Versions resource.

If you don't specify a value for this property, * Amazon Pinpoint uses the active version of the template. The active * version is typically the version of a template that's been most recently * reviewed and approved for use, depending on your workflow. It isn't necessarily * the latest version of a template.

*/ inline void SetVersion(Aws::String&& value) { m_versionHasBeenSet = true; m_version = std::move(value); } /** *

The unique identifier for the version of the message template to use for the * message. If specified, this value must match the identifier for an existing * template version. To retrieve a list of versions and version identifiers for a * template, use the Template * Versions resource.

If you don't specify a value for this property, * Amazon Pinpoint uses the active version of the template. The active * version is typically the version of a template that's been most recently * reviewed and approved for use, depending on your workflow. It isn't necessarily * the latest version of a template.

*/ inline void SetVersion(const char* value) { m_versionHasBeenSet = true; m_version.assign(value); } /** *

The unique identifier for the version of the message template to use for the * message. If specified, this value must match the identifier for an existing * template version. To retrieve a list of versions and version identifiers for a * template, use the Template * Versions resource.

If you don't specify a value for this property, * Amazon Pinpoint uses the active version of the template. The active * version is typically the version of a template that's been most recently * reviewed and approved for use, depending on your workflow. It isn't necessarily * the latest version of a template.

*/ inline Template& WithVersion(const Aws::String& value) { SetVersion(value); return *this;} /** *

The unique identifier for the version of the message template to use for the * message. If specified, this value must match the identifier for an existing * template version. To retrieve a list of versions and version identifiers for a * template, use the Template * Versions resource.

If you don't specify a value for this property, * Amazon Pinpoint uses the active version of the template. The active * version is typically the version of a template that's been most recently * reviewed and approved for use, depending on your workflow. It isn't necessarily * the latest version of a template.

*/ inline Template& WithVersion(Aws::String&& value) { SetVersion(std::move(value)); return *this;} /** *

The unique identifier for the version of the message template to use for the * message. If specified, this value must match the identifier for an existing * template version. To retrieve a list of versions and version identifiers for a * template, use the Template * Versions resource.

If you don't specify a value for this property, * Amazon Pinpoint uses the active version of the template. The active * version is typically the version of a template that's been most recently * reviewed and approved for use, depending on your workflow. It isn't necessarily * the latest version of a template.

*/ inline Template& WithVersion(const char* value) { SetVersion(value); return *this;} private: Aws::String m_name; bool m_nameHasBeenSet = false; Aws::String m_version; bool m_versionHasBeenSet = false; }; } // namespace Model } // namespace Pinpoint } // namespace Aws