/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
/*
* Do not modify this file. This file is generated from the greengrassv2-2020-11-30.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.GreengrassV2.Model
{
///
/// Container for the parameters to the CreateComponentVersion operation.
/// Creates a component. Components are software that run on Greengrass core devices.
/// After you develop and test a component on your core device, you can use this operation
/// to upload your component to IoT Greengrass. Then, you can deploy the component to
/// other core devices.
///
///
///
/// You can use this operation to do the following:
///
/// -
///
/// Create components from recipes
///
///
///
/// Create a component from a recipe, which is a file that defines the component's metadata,
/// parameters, dependencies, lifecycle, artifacts, and platform capability. For more
/// information, see IoT
/// Greengrass component recipe reference in the IoT Greengrass V2 Developer Guide.
///
///
///
/// To create a component from a recipe, specify
inlineRecipe
when you call
/// this operation.
///
/// -
///
/// Create components from Lambda functions
///
///
///
/// Create a component from an Lambda function that runs on IoT Greengrass. This creates
/// a recipe and artifacts from the Lambda function's deployment package. You can use
/// this operation to migrate Lambda functions from IoT Greengrass V1 to IoT Greengrass
/// V2.
///
///
///
/// This function only accepts Lambda functions that use the following runtimes:
///
///
-
///
/// Python 2.7 –
python2.7
///
/// -
///
/// Python 3.7 –
python3.7
///
/// -
///
/// Python 3.8 –
python3.8
///
/// -
///
/// Python 3.9 –
python3.9
///
/// -
///
/// Java 8 –
java8
///
/// -
///
/// Java 11 –
java11
///
/// -
///
/// Node.js 10 –
nodejs10.x
///
/// -
///
/// Node.js 12 –
nodejs12.x
///
/// -
///
/// Node.js 14 –
nodejs14.x
///
///
///
/// To create a component from a Lambda function, specify lambdaFunction
/// when you call this operation.
///
///
///
/// IoT Greengrass currently supports Lambda functions on only Linux core devices.
///
///
///
public partial class CreateComponentVersionRequest : AmazonGreengrassV2Request
{
private string _clientToken;
private MemoryStream _inlineRecipe;
private LambdaFunctionRecipeSource _lambdaFunction;
private Dictionary _tags = new Dictionary();
///
/// Gets and sets the property ClientToken.
///
/// A unique, case-sensitive identifier that you can provide to ensure that the request
/// is idempotent. Idempotency means that the request is successfully processed only once,
/// even if you send the request multiple times. When a request succeeds, and you specify
/// the same client token for subsequent successful requests, the IoT Greengrass V2 service
/// returns the successful response that it caches from the previous request. IoT Greengrass
/// V2 caches successful responses for idempotent requests for up to 8 hours.
///
///
[AWSProperty(Min=1, Max=64)]
public string ClientToken
{
get { return this._clientToken; }
set { this._clientToken = value; }
}
// Check to see if ClientToken property is set
internal bool IsSetClientToken()
{
return this._clientToken != null;
}
///
/// Gets and sets the property InlineRecipe.
///
/// The recipe to use to create the component. The recipe defines the component's metadata,
/// parameters, dependencies, lifecycle, artifacts, and platform compatibility.
///
///
///
/// You must specify either inlineRecipe
or lambdaFunction
.
///
///
public MemoryStream InlineRecipe
{
get { return this._inlineRecipe; }
set { this._inlineRecipe = value; }
}
// Check to see if InlineRecipe property is set
internal bool IsSetInlineRecipe()
{
return this._inlineRecipe != null;
}
///
/// Gets and sets the property LambdaFunction.
///
/// The parameters to create a component from a Lambda function.
///
///
///
/// You must specify either inlineRecipe
or lambdaFunction
.
///
///
public LambdaFunctionRecipeSource LambdaFunction
{
get { return this._lambdaFunction; }
set { this._lambdaFunction = value; }
}
// Check to see if LambdaFunction property is set
internal bool IsSetLambdaFunction()
{
return this._lambdaFunction != null;
}
///
/// Gets and sets the property Tags.
///
/// A list of key-value pairs that contain metadata for the resource. For more information,
/// see Tag
/// your resources in the IoT Greengrass V2 Developer Guide.
///
///
[AWSProperty(Min=1, Max=200)]
public Dictionary Tags
{
get { return this._tags; }
set { this._tags = value; }
}
// Check to see if Tags property is set
internal bool IsSetTags()
{
return this._tags != null && this._tags.Count > 0;
}
}
}