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
pxz-hos-client-cpp-module/support/aws-sdk-cpp-master/aws-cpp-sdk-lambda/include/aws/lambda/model/InvokeRequest.h

378 lines
18 KiB
C
Raw Normal View History

/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include <aws/lambda/Lambda_EXPORTS.h>
#include <aws/lambda/LambdaRequest.h>
#include <aws/core/utils/memory/stl/AWSString.h>
#include <aws/lambda/model/InvocationType.h>
#include <aws/lambda/model/LogType.h>
#include <aws/core/utils/Array.h>
#include <utility>
namespace Aws
{
namespace Http
{
class URI;
} //namespace Http
namespace Lambda
{
namespace Model
{
/**
*/
class AWS_LAMBDA_API InvokeRequest : public StreamingLambdaRequest
{
public:
InvokeRequest();
// 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 "Invoke"; }
void AddQueryStringParameters(Aws::Http::URI& uri) const override;
Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override;
/**
* <p>The name of the Lambda function, version, or alias.</p> <p class="title">
* <b>Name formats</b> </p> <ul> <li> <p> <b>Function name</b> -
* <code>my-function</code> (name-only), <code>my-function:v1</code> (with
* alias).</p> </li> <li> <p> <b>Function ARN</b> -
* <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p>
* </li> <li> <p> <b>Partial ARN</b> -
* <code>123456789012:function:my-function</code>.</p> </li> </ul> <p>You can
* append a version number or alias to any of the formats. The length constraint
* applies only to the full ARN. If you specify only the function name, it is
* limited to 64 characters in length.</p>
*/
inline const Aws::String& GetFunctionName() const{ return m_functionName; }
/**
* <p>The name of the Lambda function, version, or alias.</p> <p class="title">
* <b>Name formats</b> </p> <ul> <li> <p> <b>Function name</b> -
* <code>my-function</code> (name-only), <code>my-function:v1</code> (with
* alias).</p> </li> <li> <p> <b>Function ARN</b> -
* <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p>
* </li> <li> <p> <b>Partial ARN</b> -
* <code>123456789012:function:my-function</code>.</p> </li> </ul> <p>You can
* append a version number or alias to any of the formats. The length constraint
* applies only to the full ARN. If you specify only the function name, it is
* limited to 64 characters in length.</p>
*/
inline bool FunctionNameHasBeenSet() const { return m_functionNameHasBeenSet; }
/**
* <p>The name of the Lambda function, version, or alias.</p> <p class="title">
* <b>Name formats</b> </p> <ul> <li> <p> <b>Function name</b> -
* <code>my-function</code> (name-only), <code>my-function:v1</code> (with
* alias).</p> </li> <li> <p> <b>Function ARN</b> -
* <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p>
* </li> <li> <p> <b>Partial ARN</b> -
* <code>123456789012:function:my-function</code>.</p> </li> </ul> <p>You can
* append a version number or alias to any of the formats. The length constraint
* applies only to the full ARN. If you specify only the function name, it is
* limited to 64 characters in length.</p>
*/
inline void SetFunctionName(const Aws::String& value) { m_functionNameHasBeenSet = true; m_functionName = value; }
/**
* <p>The name of the Lambda function, version, or alias.</p> <p class="title">
* <b>Name formats</b> </p> <ul> <li> <p> <b>Function name</b> -
* <code>my-function</code> (name-only), <code>my-function:v1</code> (with
* alias).</p> </li> <li> <p> <b>Function ARN</b> -
* <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p>
* </li> <li> <p> <b>Partial ARN</b> -
* <code>123456789012:function:my-function</code>.</p> </li> </ul> <p>You can
* append a version number or alias to any of the formats. The length constraint
* applies only to the full ARN. If you specify only the function name, it is
* limited to 64 characters in length.</p>
*/
inline void SetFunctionName(Aws::String&& value) { m_functionNameHasBeenSet = true; m_functionName = std::move(value); }
/**
* <p>The name of the Lambda function, version, or alias.</p> <p class="title">
* <b>Name formats</b> </p> <ul> <li> <p> <b>Function name</b> -
* <code>my-function</code> (name-only), <code>my-function:v1</code> (with
* alias).</p> </li> <li> <p> <b>Function ARN</b> -
* <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p>
* </li> <li> <p> <b>Partial ARN</b> -
* <code>123456789012:function:my-function</code>.</p> </li> </ul> <p>You can
* append a version number or alias to any of the formats. The length constraint
* applies only to the full ARN. If you specify only the function name, it is
* limited to 64 characters in length.</p>
*/
inline void SetFunctionName(const char* value) { m_functionNameHasBeenSet = true; m_functionName.assign(value); }
/**
* <p>The name of the Lambda function, version, or alias.</p> <p class="title">
* <b>Name formats</b> </p> <ul> <li> <p> <b>Function name</b> -
* <code>my-function</code> (name-only), <code>my-function:v1</code> (with
* alias).</p> </li> <li> <p> <b>Function ARN</b> -
* <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p>
* </li> <li> <p> <b>Partial ARN</b> -
* <code>123456789012:function:my-function</code>.</p> </li> </ul> <p>You can
* append a version number or alias to any of the formats. The length constraint
* applies only to the full ARN. If you specify only the function name, it is
* limited to 64 characters in length.</p>
*/
inline InvokeRequest& WithFunctionName(const Aws::String& value) { SetFunctionName(value); return *this;}
/**
* <p>The name of the Lambda function, version, or alias.</p> <p class="title">
* <b>Name formats</b> </p> <ul> <li> <p> <b>Function name</b> -
* <code>my-function</code> (name-only), <code>my-function:v1</code> (with
* alias).</p> </li> <li> <p> <b>Function ARN</b> -
* <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p>
* </li> <li> <p> <b>Partial ARN</b> -
* <code>123456789012:function:my-function</code>.</p> </li> </ul> <p>You can
* append a version number or alias to any of the formats. The length constraint
* applies only to the full ARN. If you specify only the function name, it is
* limited to 64 characters in length.</p>
*/
inline InvokeRequest& WithFunctionName(Aws::String&& value) { SetFunctionName(std::move(value)); return *this;}
/**
* <p>The name of the Lambda function, version, or alias.</p> <p class="title">
* <b>Name formats</b> </p> <ul> <li> <p> <b>Function name</b> -
* <code>my-function</code> (name-only), <code>my-function:v1</code> (with
* alias).</p> </li> <li> <p> <b>Function ARN</b> -
* <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p>
* </li> <li> <p> <b>Partial ARN</b> -
* <code>123456789012:function:my-function</code>.</p> </li> </ul> <p>You can
* append a version number or alias to any of the formats. The length constraint
* applies only to the full ARN. If you specify only the function name, it is
* limited to 64 characters in length.</p>
*/
inline InvokeRequest& WithFunctionName(const char* value) { SetFunctionName(value); return *this;}
/**
* <p>Choose from the following options.</p> <ul> <li> <p>
* <code>RequestResponse</code> (default) - Invoke the function synchronously. Keep
* the connection open until the function returns a response or times out. The API
* response includes the function response and additional data.</p> </li> <li> <p>
* <code>Event</code> - Invoke the function asynchronously. Send events that fail
* multiple times to the function's dead-letter queue (if it's configured). The API
* response only includes a status code.</p> </li> <li> <p> <code>DryRun</code> -
* Validate parameter values and verify that the user or role has permission to
* invoke the function.</p> </li> </ul>
*/
inline const InvocationType& GetInvocationType() const{ return m_invocationType; }
/**
* <p>Choose from the following options.</p> <ul> <li> <p>
* <code>RequestResponse</code> (default) - Invoke the function synchronously. Keep
* the connection open until the function returns a response or times out. The API
* response includes the function response and additional data.</p> </li> <li> <p>
* <code>Event</code> - Invoke the function asynchronously. Send events that fail
* multiple times to the function's dead-letter queue (if it's configured). The API
* response only includes a status code.</p> </li> <li> <p> <code>DryRun</code> -
* Validate parameter values and verify that the user or role has permission to
* invoke the function.</p> </li> </ul>
*/
inline bool InvocationTypeHasBeenSet() const { return m_invocationTypeHasBeenSet; }
/**
* <p>Choose from the following options.</p> <ul> <li> <p>
* <code>RequestResponse</code> (default) - Invoke the function synchronously. Keep
* the connection open until the function returns a response or times out. The API
* response includes the function response and additional data.</p> </li> <li> <p>
* <code>Event</code> - Invoke the function asynchronously. Send events that fail
* multiple times to the function's dead-letter queue (if it's configured). The API
* response only includes a status code.</p> </li> <li> <p> <code>DryRun</code> -
* Validate parameter values and verify that the user or role has permission to
* invoke the function.</p> </li> </ul>
*/
inline void SetInvocationType(const InvocationType& value) { m_invocationTypeHasBeenSet = true; m_invocationType = value; }
/**
* <p>Choose from the following options.</p> <ul> <li> <p>
* <code>RequestResponse</code> (default) - Invoke the function synchronously. Keep
* the connection open until the function returns a response or times out. The API
* response includes the function response and additional data.</p> </li> <li> <p>
* <code>Event</code> - Invoke the function asynchronously. Send events that fail
* multiple times to the function's dead-letter queue (if it's configured). The API
* response only includes a status code.</p> </li> <li> <p> <code>DryRun</code> -
* Validate parameter values and verify that the user or role has permission to
* invoke the function.</p> </li> </ul>
*/
inline void SetInvocationType(InvocationType&& value) { m_invocationTypeHasBeenSet = true; m_invocationType = std::move(value); }
/**
* <p>Choose from the following options.</p> <ul> <li> <p>
* <code>RequestResponse</code> (default) - Invoke the function synchronously. Keep
* the connection open until the function returns a response or times out. The API
* response includes the function response and additional data.</p> </li> <li> <p>
* <code>Event</code> - Invoke the function asynchronously. Send events that fail
* multiple times to the function's dead-letter queue (if it's configured). The API
* response only includes a status code.</p> </li> <li> <p> <code>DryRun</code> -
* Validate parameter values and verify that the user or role has permission to
* invoke the function.</p> </li> </ul>
*/
inline InvokeRequest& WithInvocationType(const InvocationType& value) { SetInvocationType(value); return *this;}
/**
* <p>Choose from the following options.</p> <ul> <li> <p>
* <code>RequestResponse</code> (default) - Invoke the function synchronously. Keep
* the connection open until the function returns a response or times out. The API
* response includes the function response and additional data.</p> </li> <li> <p>
* <code>Event</code> - Invoke the function asynchronously. Send events that fail
* multiple times to the function's dead-letter queue (if it's configured). The API
* response only includes a status code.</p> </li> <li> <p> <code>DryRun</code> -
* Validate parameter values and verify that the user or role has permission to
* invoke the function.</p> </li> </ul>
*/
inline InvokeRequest& WithInvocationType(InvocationType&& value) { SetInvocationType(std::move(value)); return *this;}
/**
* <p>Set to <code>Tail</code> to include the execution log in the response.</p>
*/
inline const LogType& GetLogType() const{ return m_logType; }
/**
* <p>Set to <code>Tail</code> to include the execution log in the response.</p>
*/
inline bool LogTypeHasBeenSet() const { return m_logTypeHasBeenSet; }
/**
* <p>Set to <code>Tail</code> to include the execution log in the response.</p>
*/
inline void SetLogType(const LogType& value) { m_logTypeHasBeenSet = true; m_logType = value; }
/**
* <p>Set to <code>Tail</code> to include the execution log in the response.</p>
*/
inline void SetLogType(LogType&& value) { m_logTypeHasBeenSet = true; m_logType = std::move(value); }
/**
* <p>Set to <code>Tail</code> to include the execution log in the response.</p>
*/
inline InvokeRequest& WithLogType(const LogType& value) { SetLogType(value); return *this;}
/**
* <p>Set to <code>Tail</code> to include the execution log in the response.</p>
*/
inline InvokeRequest& WithLogType(LogType&& value) { SetLogType(std::move(value)); return *this;}
/**
* <p>Up to 3583 bytes of base64-encoded data about the invoking client to pass to
* the function in the context object.</p>
*/
inline const Aws::String& GetClientContext() const{ return m_clientContext; }
/**
* <p>Up to 3583 bytes of base64-encoded data about the invoking client to pass to
* the function in the context object.</p>
*/
inline bool ClientContextHasBeenSet() const { return m_clientContextHasBeenSet; }
/**
* <p>Up to 3583 bytes of base64-encoded data about the invoking client to pass to
* the function in the context object.</p>
*/
inline void SetClientContext(const Aws::String& value) { m_clientContextHasBeenSet = true; m_clientContext = value; }
/**
* <p>Up to 3583 bytes of base64-encoded data about the invoking client to pass to
* the function in the context object.</p>
*/
inline void SetClientContext(Aws::String&& value) { m_clientContextHasBeenSet = true; m_clientContext = std::move(value); }
/**
* <p>Up to 3583 bytes of base64-encoded data about the invoking client to pass to
* the function in the context object.</p>
*/
inline void SetClientContext(const char* value) { m_clientContextHasBeenSet = true; m_clientContext.assign(value); }
/**
* <p>Up to 3583 bytes of base64-encoded data about the invoking client to pass to
* the function in the context object.</p>
*/
inline InvokeRequest& WithClientContext(const Aws::String& value) { SetClientContext(value); return *this;}
/**
* <p>Up to 3583 bytes of base64-encoded data about the invoking client to pass to
* the function in the context object.</p>
*/
inline InvokeRequest& WithClientContext(Aws::String&& value) { SetClientContext(std::move(value)); return *this;}
/**
* <p>Up to 3583 bytes of base64-encoded data about the invoking client to pass to
* the function in the context object.</p>
*/
inline InvokeRequest& WithClientContext(const char* value) { SetClientContext(value); return *this;}
/**
* <p>Specify a version or alias to invoke a published version of the function.</p>
*/
inline const Aws::String& GetQualifier() const{ return m_qualifier; }
/**
* <p>Specify a version or alias to invoke a published version of the function.</p>
*/
inline bool QualifierHasBeenSet() const { return m_qualifierHasBeenSet; }
/**
* <p>Specify a version or alias to invoke a published version of the function.</p>
*/
inline void SetQualifier(const Aws::String& value) { m_qualifierHasBeenSet = true; m_qualifier = value; }
/**
* <p>Specify a version or alias to invoke a published version of the function.</p>
*/
inline void SetQualifier(Aws::String&& value) { m_qualifierHasBeenSet = true; m_qualifier = std::move(value); }
/**
* <p>Specify a version or alias to invoke a published version of the function.</p>
*/
inline void SetQualifier(const char* value) { m_qualifierHasBeenSet = true; m_qualifier.assign(value); }
/**
* <p>Specify a version or alias to invoke a published version of the function.</p>
*/
inline InvokeRequest& WithQualifier(const Aws::String& value) { SetQualifier(value); return *this;}
/**
* <p>Specify a version or alias to invoke a published version of the function.</p>
*/
inline InvokeRequest& WithQualifier(Aws::String&& value) { SetQualifier(std::move(value)); return *this;}
/**
* <p>Specify a version or alias to invoke a published version of the function.</p>
*/
inline InvokeRequest& WithQualifier(const char* value) { SetQualifier(value); return *this;}
private:
Aws::String m_functionName;
bool m_functionNameHasBeenSet;
InvocationType m_invocationType;
bool m_invocationTypeHasBeenSet;
LogType m_logType;
bool m_logTypeHasBeenSet;
Aws::String m_clientContext;
bool m_clientContextHasBeenSet;
Aws::String m_qualifier;
bool m_qualifierHasBeenSet;
};
} // namespace Model
} // namespace Lambda
} // namespace Aws