/** * 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 Utils { namespace Json { class JsonValue; class JsonView; } // namespace Json } // namespace Utils namespace Greengrass { namespace Model { /** * The environment configuration of the function.

See Also:

AWS * API Reference

*/ class FunctionConfigurationEnvironment { public: AWS_GREENGRASS_API FunctionConfigurationEnvironment(); AWS_GREENGRASS_API FunctionConfigurationEnvironment(Aws::Utils::Json::JsonView jsonValue); AWS_GREENGRASS_API FunctionConfigurationEnvironment& operator=(Aws::Utils::Json::JsonView jsonValue); AWS_GREENGRASS_API Aws::Utils::Json::JsonValue Jsonize() const; /** * If true, the Lambda function is allowed to access the host's /sys folder. Use * this when the Lambda function needs to read device information from /sys. This * setting applies only when you run the Lambda function in a Greengrass container. */ inline bool GetAccessSysfs() const{ return m_accessSysfs; } /** * If true, the Lambda function is allowed to access the host's /sys folder. Use * this when the Lambda function needs to read device information from /sys. This * setting applies only when you run the Lambda function in a Greengrass container. */ inline bool AccessSysfsHasBeenSet() const { return m_accessSysfsHasBeenSet; } /** * If true, the Lambda function is allowed to access the host's /sys folder. Use * this when the Lambda function needs to read device information from /sys. This * setting applies only when you run the Lambda function in a Greengrass container. */ inline void SetAccessSysfs(bool value) { m_accessSysfsHasBeenSet = true; m_accessSysfs = value; } /** * If true, the Lambda function is allowed to access the host's /sys folder. Use * this when the Lambda function needs to read device information from /sys. This * setting applies only when you run the Lambda function in a Greengrass container. */ inline FunctionConfigurationEnvironment& WithAccessSysfs(bool value) { SetAccessSysfs(value); return *this;} /** * Configuration related to executing the Lambda function */ inline const FunctionExecutionConfig& GetExecution() const{ return m_execution; } /** * Configuration related to executing the Lambda function */ inline bool ExecutionHasBeenSet() const { return m_executionHasBeenSet; } /** * Configuration related to executing the Lambda function */ inline void SetExecution(const FunctionExecutionConfig& value) { m_executionHasBeenSet = true; m_execution = value; } /** * Configuration related to executing the Lambda function */ inline void SetExecution(FunctionExecutionConfig&& value) { m_executionHasBeenSet = true; m_execution = std::move(value); } /** * Configuration related to executing the Lambda function */ inline FunctionConfigurationEnvironment& WithExecution(const FunctionExecutionConfig& value) { SetExecution(value); return *this;} /** * Configuration related to executing the Lambda function */ inline FunctionConfigurationEnvironment& WithExecution(FunctionExecutionConfig&& value) { SetExecution(std::move(value)); return *this;} /** * A list of the resources, with their permissions, to which the Lambda function * will be granted access. A Lambda function can have at most 10 resources. * ResourceAccessPolicies apply only when you run the Lambda function in a * Greengrass container. */ inline const Aws::Vector& GetResourceAccessPolicies() const{ return m_resourceAccessPolicies; } /** * A list of the resources, with their permissions, to which the Lambda function * will be granted access. A Lambda function can have at most 10 resources. * ResourceAccessPolicies apply only when you run the Lambda function in a * Greengrass container. */ inline bool ResourceAccessPoliciesHasBeenSet() const { return m_resourceAccessPoliciesHasBeenSet; } /** * A list of the resources, with their permissions, to which the Lambda function * will be granted access. A Lambda function can have at most 10 resources. * ResourceAccessPolicies apply only when you run the Lambda function in a * Greengrass container. */ inline void SetResourceAccessPolicies(const Aws::Vector& value) { m_resourceAccessPoliciesHasBeenSet = true; m_resourceAccessPolicies = value; } /** * A list of the resources, with their permissions, to which the Lambda function * will be granted access. A Lambda function can have at most 10 resources. * ResourceAccessPolicies apply only when you run the Lambda function in a * Greengrass container. */ inline void SetResourceAccessPolicies(Aws::Vector&& value) { m_resourceAccessPoliciesHasBeenSet = true; m_resourceAccessPolicies = std::move(value); } /** * A list of the resources, with their permissions, to which the Lambda function * will be granted access. A Lambda function can have at most 10 resources. * ResourceAccessPolicies apply only when you run the Lambda function in a * Greengrass container. */ inline FunctionConfigurationEnvironment& WithResourceAccessPolicies(const Aws::Vector& value) { SetResourceAccessPolicies(value); return *this;} /** * A list of the resources, with their permissions, to which the Lambda function * will be granted access. A Lambda function can have at most 10 resources. * ResourceAccessPolicies apply only when you run the Lambda function in a * Greengrass container. */ inline FunctionConfigurationEnvironment& WithResourceAccessPolicies(Aws::Vector&& value) { SetResourceAccessPolicies(std::move(value)); return *this;} /** * A list of the resources, with their permissions, to which the Lambda function * will be granted access. A Lambda function can have at most 10 resources. * ResourceAccessPolicies apply only when you run the Lambda function in a * Greengrass container. */ inline FunctionConfigurationEnvironment& AddResourceAccessPolicies(const ResourceAccessPolicy& value) { m_resourceAccessPoliciesHasBeenSet = true; m_resourceAccessPolicies.push_back(value); return *this; } /** * A list of the resources, with their permissions, to which the Lambda function * will be granted access. A Lambda function can have at most 10 resources. * ResourceAccessPolicies apply only when you run the Lambda function in a * Greengrass container. */ inline FunctionConfigurationEnvironment& AddResourceAccessPolicies(ResourceAccessPolicy&& value) { m_resourceAccessPoliciesHasBeenSet = true; m_resourceAccessPolicies.push_back(std::move(value)); return *this; } /** * Environment variables for the Lambda function's configuration. */ inline const Aws::Map& GetVariables() const{ return m_variables; } /** * Environment variables for the Lambda function's configuration. */ inline bool VariablesHasBeenSet() const { return m_variablesHasBeenSet; } /** * Environment variables for the Lambda function's configuration. */ inline void SetVariables(const Aws::Map& value) { m_variablesHasBeenSet = true; m_variables = value; } /** * Environment variables for the Lambda function's configuration. */ inline void SetVariables(Aws::Map&& value) { m_variablesHasBeenSet = true; m_variables = std::move(value); } /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& WithVariables(const Aws::Map& value) { SetVariables(value); return *this;} /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& WithVariables(Aws::Map&& value) { SetVariables(std::move(value)); return *this;} /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& AddVariables(const Aws::String& key, const Aws::String& value) { m_variablesHasBeenSet = true; m_variables.emplace(key, value); return *this; } /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& AddVariables(Aws::String&& key, const Aws::String& value) { m_variablesHasBeenSet = true; m_variables.emplace(std::move(key), value); return *this; } /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& AddVariables(const Aws::String& key, Aws::String&& value) { m_variablesHasBeenSet = true; m_variables.emplace(key, std::move(value)); return *this; } /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& AddVariables(Aws::String&& key, Aws::String&& value) { m_variablesHasBeenSet = true; m_variables.emplace(std::move(key), std::move(value)); return *this; } /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& AddVariables(const char* key, Aws::String&& value) { m_variablesHasBeenSet = true; m_variables.emplace(key, std::move(value)); return *this; } /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& AddVariables(Aws::String&& key, const char* value) { m_variablesHasBeenSet = true; m_variables.emplace(std::move(key), value); return *this; } /** * Environment variables for the Lambda function's configuration. */ inline FunctionConfigurationEnvironment& AddVariables(const char* key, const char* value) { m_variablesHasBeenSet = true; m_variables.emplace(key, value); return *this; } private: bool m_accessSysfs; bool m_accessSysfsHasBeenSet = false; FunctionExecutionConfig m_execution; bool m_executionHasBeenSet = false; Aws::Vector m_resourceAccessPolicies; bool m_resourceAccessPoliciesHasBeenSet = false; Aws::Map m_variables; bool m_variablesHasBeenSet = false; }; } // namespace Model } // namespace Greengrass } // namespace Aws