This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files

322 lines
12 KiB
C++

/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include <aws/apigateway/APIGateway_EXPORTS.h>
#include <aws/core/utils/memory/stl/AWSString.h>
#include <utility>
namespace Aws
{
namespace Utils
{
namespace Json
{
class JsonValue;
class JsonView;
} // namespace Json
} // namespace Utils
namespace APIGateway
{
namespace Model
{
/**
* <p>Represents the data structure of a method's request or response payload.</p>
* <div class="remarks"> <p>A request model defines the data structure of the
* client-supplied request payload. A response model defines the data structure of
* the response payload returned by the back end. Although not required, models are
* useful for mapping payloads between the front end and back end.</p> <p>A model
* is used for generating an API's SDK, validating the input request body, and
* creating a skeletal mapping template.</p> </div> <div class="seeAlso">
* <a>Method</a>, <a>MethodResponse</a>, <a
* href="https://docs.aws.amazon.com/apigateway/latest/developerguide/models-mappings.html">Models
* and Mappings</a> </div><p><h3>See Also:</h3> <a
* href="http://docs.aws.amazon.com/goto/WebAPI/apigateway-2015-07-09/Model">AWS
* API Reference</a></p>
*/
class AWS_APIGATEWAY_API Model
{
public:
Model();
Model(Aws::Utils::Json::JsonView jsonValue);
Model& operator=(Aws::Utils::Json::JsonView jsonValue);
Aws::Utils::Json::JsonValue Jsonize() const;
/**
* <p>The identifier for the model resource.</p>
*/
inline const Aws::String& GetId() const{ return m_id; }
/**
* <p>The identifier for the model resource.</p>
*/
inline bool IdHasBeenSet() const { return m_idHasBeenSet; }
/**
* <p>The identifier for the model resource.</p>
*/
inline void SetId(const Aws::String& value) { m_idHasBeenSet = true; m_id = value; }
/**
* <p>The identifier for the model resource.</p>
*/
inline void SetId(Aws::String&& value) { m_idHasBeenSet = true; m_id = std::move(value); }
/**
* <p>The identifier for the model resource.</p>
*/
inline void SetId(const char* value) { m_idHasBeenSet = true; m_id.assign(value); }
/**
* <p>The identifier for the model resource.</p>
*/
inline Model& WithId(const Aws::String& value) { SetId(value); return *this;}
/**
* <p>The identifier for the model resource.</p>
*/
inline Model& WithId(Aws::String&& value) { SetId(std::move(value)); return *this;}
/**
* <p>The identifier for the model resource.</p>
*/
inline Model& WithId(const char* value) { SetId(value); return *this;}
/**
* <p>The name of the model. Must be an alphanumeric string.</p>
*/
inline const Aws::String& GetName() const{ return m_name; }
/**
* <p>The name of the model. Must be an alphanumeric string.</p>
*/
inline bool NameHasBeenSet() const { return m_nameHasBeenSet; }
/**
* <p>The name of the model. Must be an alphanumeric string.</p>
*/
inline void SetName(const Aws::String& value) { m_nameHasBeenSet = true; m_name = value; }
/**
* <p>The name of the model. Must be an alphanumeric string.</p>
*/
inline void SetName(Aws::String&& value) { m_nameHasBeenSet = true; m_name = std::move(value); }
/**
* <p>The name of the model. Must be an alphanumeric string.</p>
*/
inline void SetName(const char* value) { m_nameHasBeenSet = true; m_name.assign(value); }
/**
* <p>The name of the model. Must be an alphanumeric string.</p>
*/
inline Model& WithName(const Aws::String& value) { SetName(value); return *this;}
/**
* <p>The name of the model. Must be an alphanumeric string.</p>
*/
inline Model& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;}
/**
* <p>The name of the model. Must be an alphanumeric string.</p>
*/
inline Model& WithName(const char* value) { SetName(value); return *this;}
/**
* <p>The description of the model.</p>
*/
inline const Aws::String& GetDescription() const{ return m_description; }
/**
* <p>The description of the model.</p>
*/
inline bool DescriptionHasBeenSet() const { return m_descriptionHasBeenSet; }
/**
* <p>The description of the model.</p>
*/
inline void SetDescription(const Aws::String& value) { m_descriptionHasBeenSet = true; m_description = value; }
/**
* <p>The description of the model.</p>
*/
inline void SetDescription(Aws::String&& value) { m_descriptionHasBeenSet = true; m_description = std::move(value); }
/**
* <p>The description of the model.</p>
*/
inline void SetDescription(const char* value) { m_descriptionHasBeenSet = true; m_description.assign(value); }
/**
* <p>The description of the model.</p>
*/
inline Model& WithDescription(const Aws::String& value) { SetDescription(value); return *this;}
/**
* <p>The description of the model.</p>
*/
inline Model& WithDescription(Aws::String&& value) { SetDescription(std::move(value)); return *this;}
/**
* <p>The description of the model.</p>
*/
inline Model& WithDescription(const char* value) { SetDescription(value); return *this;}
/**
* <p>The schema for the model. For <code>application/json</code> models, this
* should be <a href="https://tools.ietf.org/html/draft-zyp-json-schema-04"
* target="_blank">JSON schema draft 4</a> model. Do not include "\* /" characters
* in the description of any properties because such "\* /" characters may be
* interpreted as the closing marker for comments in some languages, such as Java
* or JavaScript, causing the installation of your API's SDK generated by API
* Gateway to fail.</p>
*/
inline const Aws::String& GetSchema() const{ return m_schema; }
/**
* <p>The schema for the model. For <code>application/json</code> models, this
* should be <a href="https://tools.ietf.org/html/draft-zyp-json-schema-04"
* target="_blank">JSON schema draft 4</a> model. Do not include "\* /" characters
* in the description of any properties because such "\* /" characters may be
* interpreted as the closing marker for comments in some languages, such as Java
* or JavaScript, causing the installation of your API's SDK generated by API
* Gateway to fail.</p>
*/
inline bool SchemaHasBeenSet() const { return m_schemaHasBeenSet; }
/**
* <p>The schema for the model. For <code>application/json</code> models, this
* should be <a href="https://tools.ietf.org/html/draft-zyp-json-schema-04"
* target="_blank">JSON schema draft 4</a> model. Do not include "\* /" characters
* in the description of any properties because such "\* /" characters may be
* interpreted as the closing marker for comments in some languages, such as Java
* or JavaScript, causing the installation of your API's SDK generated by API
* Gateway to fail.</p>
*/
inline void SetSchema(const Aws::String& value) { m_schemaHasBeenSet = true; m_schema = value; }
/**
* <p>The schema for the model. For <code>application/json</code> models, this
* should be <a href="https://tools.ietf.org/html/draft-zyp-json-schema-04"
* target="_blank">JSON schema draft 4</a> model. Do not include "\* /" characters
* in the description of any properties because such "\* /" characters may be
* interpreted as the closing marker for comments in some languages, such as Java
* or JavaScript, causing the installation of your API's SDK generated by API
* Gateway to fail.</p>
*/
inline void SetSchema(Aws::String&& value) { m_schemaHasBeenSet = true; m_schema = std::move(value); }
/**
* <p>The schema for the model. For <code>application/json</code> models, this
* should be <a href="https://tools.ietf.org/html/draft-zyp-json-schema-04"
* target="_blank">JSON schema draft 4</a> model. Do not include "\* /" characters
* in the description of any properties because such "\* /" characters may be
* interpreted as the closing marker for comments in some languages, such as Java
* or JavaScript, causing the installation of your API's SDK generated by API
* Gateway to fail.</p>
*/
inline void SetSchema(const char* value) { m_schemaHasBeenSet = true; m_schema.assign(value); }
/**
* <p>The schema for the model. For <code>application/json</code> models, this
* should be <a href="https://tools.ietf.org/html/draft-zyp-json-schema-04"
* target="_blank">JSON schema draft 4</a> model. Do not include "\* /" characters
* in the description of any properties because such "\* /" characters may be
* interpreted as the closing marker for comments in some languages, such as Java
* or JavaScript, causing the installation of your API's SDK generated by API
* Gateway to fail.</p>
*/
inline Model& WithSchema(const Aws::String& value) { SetSchema(value); return *this;}
/**
* <p>The schema for the model. For <code>application/json</code> models, this
* should be <a href="https://tools.ietf.org/html/draft-zyp-json-schema-04"
* target="_blank">JSON schema draft 4</a> model. Do not include "\* /" characters
* in the description of any properties because such "\* /" characters may be
* interpreted as the closing marker for comments in some languages, such as Java
* or JavaScript, causing the installation of your API's SDK generated by API
* Gateway to fail.</p>
*/
inline Model& WithSchema(Aws::String&& value) { SetSchema(std::move(value)); return *this;}
/**
* <p>The schema for the model. For <code>application/json</code> models, this
* should be <a href="https://tools.ietf.org/html/draft-zyp-json-schema-04"
* target="_blank">JSON schema draft 4</a> model. Do not include "\* /" characters
* in the description of any properties because such "\* /" characters may be
* interpreted as the closing marker for comments in some languages, such as Java
* or JavaScript, causing the installation of your API's SDK generated by API
* Gateway to fail.</p>
*/
inline Model& WithSchema(const char* value) { SetSchema(value); return *this;}
/**
* <p>The content-type for the model.</p>
*/
inline const Aws::String& GetContentType() const{ return m_contentType; }
/**
* <p>The content-type for the model.</p>
*/
inline bool ContentTypeHasBeenSet() const { return m_contentTypeHasBeenSet; }
/**
* <p>The content-type for the model.</p>
*/
inline void SetContentType(const Aws::String& value) { m_contentTypeHasBeenSet = true; m_contentType = value; }
/**
* <p>The content-type for the model.</p>
*/
inline void SetContentType(Aws::String&& value) { m_contentTypeHasBeenSet = true; m_contentType = std::move(value); }
/**
* <p>The content-type for the model.</p>
*/
inline void SetContentType(const char* value) { m_contentTypeHasBeenSet = true; m_contentType.assign(value); }
/**
* <p>The content-type for the model.</p>
*/
inline Model& WithContentType(const Aws::String& value) { SetContentType(value); return *this;}
/**
* <p>The content-type for the model.</p>
*/
inline Model& WithContentType(Aws::String&& value) { SetContentType(std::move(value)); return *this;}
/**
* <p>The content-type for the model.</p>
*/
inline Model& WithContentType(const char* value) { SetContentType(value); return *this;}
private:
Aws::String m_id;
bool m_idHasBeenSet;
Aws::String m_name;
bool m_nameHasBeenSet;
Aws::String m_description;
bool m_descriptionHasBeenSet;
Aws::String m_schema;
bool m_schemaHasBeenSet;
Aws::String m_contentType;
bool m_contentTypeHasBeenSet;
};
} // namespace Model
} // namespace APIGateway
} // namespace Aws