CreateComponentVersion
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 AWS 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 AWS IoT Greengrass component recipe reference in the AWS IoT Greengrass V2 Developer Guide. To create a component from a recipe, specify inlineRecipewhen you call this operation.
- 
         Create components from Lambda functions Create a component from an AWS Lambda function that runs on AWS 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 AWS IoT Greengrass V1 to AWS IoT Greengrass V2. This function accepts Lambda functions in all supported versions of Python, Node.js, and Java runtimes. AWS IoT Greengrass doesn't apply any additional restrictions on deprecated Lambda runtime versions. To create a component from a Lambda function, specify lambdaFunctionwhen you call this operation.NoteAWS IoT Greengrass currently supports Lambda functions on only Linux core devices. 
Request Syntax
POST /greengrass/v2/createComponentVersion HTTP/1.1
Content-type: application/json
{
   "clientToken": "string",
   "inlineRecipe": blob,
   "lambdaFunction": { 
      "componentDependencies": { 
         "string" : { 
            "dependencyType": "string",
            "versionRequirement": "string"
         }
      },
      "componentLambdaParameters": { 
         "environmentVariables": { 
            "string" : "string" 
         },
         "eventSources": [ 
            { 
               "topic": "string",
               "type": "string"
            }
         ],
         "execArgs": [ "string" ],
         "inputPayloadEncodingType": "string",
         "linuxProcessParams": { 
            "containerParams": { 
               "devices": [ 
                  { 
                     "addGroupOwner": boolean,
                     "path": "string",
                     "permission": "string"
                  }
               ],
               "memorySizeInKB": number,
               "mountROSysfs": boolean,
               "volumes": [ 
                  { 
                     "addGroupOwner": boolean,
                     "destinationPath": "string",
                     "permission": "string",
                     "sourcePath": "string"
                  }
               ]
            },
            "isolationMode": "string"
         },
         "maxIdleTimeInSeconds": number,
         "maxInstancesCount": number,
         "maxQueueSize": number,
         "pinned": boolean,
         "statusTimeoutInSeconds": number,
         "timeoutInSeconds": number
      },
      "componentName": "string",
      "componentPlatforms": [ 
         { 
            "attributes": { 
               "string" : "string" 
            },
            "name": "string"
         }
      ],
      "componentVersion": "string",
      "lambdaArn": "string"
   },
   "tags": { 
      "string" : "string" 
   }
}URI Request Parameters
The request does not use any URI parameters.
Request Body
The request accepts the following data in JSON format.
- 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 AWS IoT Greengrass V2 service returns the successful response that it caches from the previous request. AWS IoT Greengrass V2 caches successful responses for idempotent requests for up to 8 hours. Type: String Length Constraints: Minimum length of 1. Maximum length of 64. Pattern: ^[a-zA-Z0-9-]+$Required: No 
- 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 inlineRecipeorlambdaFunction.Type: Base64-encoded binary data object Required: No 
- lambdaFunction
- 
               The parameters to create a component from a Lambda function. You must specify either inlineRecipeorlambdaFunction.Type: LambdaFunctionRecipeSource object Required: No 
- 
               A list of key-value pairs that contain metadata for the resource. For more information, see Tag your resources in the AWS IoT Greengrass V2 Developer Guide. Type: String to string map Map Entries: Maximum number of 200 items. Key Length Constraints: Minimum length of 1. Maximum length of 128. Value Length Constraints: Maximum length of 256. Required: No 
Response Syntax
HTTP/1.1 201
Content-type: application/json
{
   "arn": "string",
   "componentName": "string",
   "componentVersion": "string",
   "creationTimestamp": number,
   "status": { 
      "componentState": "string",
      "errors": { 
         "string" : "string" 
      },
      "message": "string",
      "vendorGuidance": "string",
      "vendorGuidanceMessage": "string"
   }
}Response Elements
If the action is successful, the service sends back an HTTP 201 response.
The following data is returned in JSON format by the service.
- arn
- 
               The ARN of the component version. Type: String Pattern: arn:[^:]*:greengrass:[^:]*:(aws|[0-9]+):components:[^:]+:versions:[^:]+
- componentName
- 
               The name of the component. Type: String Length Constraints: Minimum length of 1. Maximum length of 128. 
- componentVersion
- 
               The version of the component. Type: String Length Constraints: Minimum length of 1. Maximum length of 64. 
- creationTimestamp
- 
               The time at which the component was created, expressed in ISO 8601 format. Type: Timestamp 
- status
- 
               The status of the component version in AWS IoT Greengrass V2. This status is different from the status of the component on a core device. Type: CloudComponentStatus object 
Errors
For information about the errors that are common to all actions, see Common Errors.
- AccessDeniedException
- 
               You don't have permission to perform the action. HTTP Status Code: 403 
- ConflictException
- 
               Your request has conflicting operations. This can occur if you're trying to perform more than one operation on the same resource at the same time. - resourceId
- 
                        The ID of the resource that conflicts with the request. 
- resourceType
- 
                        The type of the resource that conflicts with the request. 
 HTTP Status Code: 409 
- InternalServerException
- 
               AWS IoT Greengrass can't process your request right now. Try again later. - retryAfterSeconds
- 
                        The amount of time to wait before you retry the request. 
 HTTP Status Code: 500 
- RequestAlreadyInProgressException
- 
               The request is already in progress. This exception occurs when you use a client token for multiple requests while AWS IoT Greengrass is still processing an earlier request that uses the same client token. HTTP Status Code: 400 
- ServiceQuotaExceededException
- 
               Your request exceeds a service quota. For example, you might have the maximum number of components that you can create. - quotaCode
- 
                        The code for the quota in Service Quotas. 
- resourceId
- 
                        The ID of the resource that exceeds the service quota. 
- resourceType
- 
                        The type of the resource that exceeds the service quota. 
- serviceCode
- 
                        The code for the service in Service Quotas. 
 HTTP Status Code: 402 
- ThrottlingException
- 
               Your request exceeded a request rate quota. For example, you might have exceeded the amount of times that you can retrieve device or deployment status per second. - quotaCode
- 
                        The code for the quota in Service Quotas. 
- retryAfterSeconds
- 
                        The amount of time to wait before you retry the request. 
- serviceCode
- 
                        The code for the service in Service Quotas. 
 HTTP Status Code: 429 
- ValidationException
- 
               The request isn't valid. This can occur if your request contains malformed JSON or unsupported characters. - fields
- 
                        The list of fields that failed to validate. 
- reason
- 
                        The reason for the validation exception. 
 HTTP Status Code: 400 
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: