Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.aws.comprehend.kotlin
import com.pulumi.aws.comprehend.DocumentClassifierArgs.builder
import com.pulumi.aws.comprehend.kotlin.inputs.DocumentClassifierInputDataConfigArgs
import com.pulumi.aws.comprehend.kotlin.inputs.DocumentClassifierInputDataConfigArgsBuilder
import com.pulumi.aws.comprehend.kotlin.inputs.DocumentClassifierOutputDataConfigArgs
import com.pulumi.aws.comprehend.kotlin.inputs.DocumentClassifierOutputDataConfigArgsBuilder
import com.pulumi.aws.comprehend.kotlin.inputs.DocumentClassifierVpcConfigArgs
import com.pulumi.aws.comprehend.kotlin.inputs.DocumentClassifierVpcConfigArgsBuilder
import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.Pair
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.Map
import kotlin.jvm.JvmName
/**
* Resource for managing an AWS Comprehend Document Classifier.
* ## Example Usage
* ### Basic Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as aws from "@pulumi/aws";
* const documents = new aws.s3.BucketObjectv2("documents", {});
* const example = new aws.comprehend.DocumentClassifier("example", {
* name: "example",
* dataAccessRoleArn: exampleAwsIamRole.arn,
* languageCode: "en",
* inputDataConfig: {
* s3Uri: pulumi.interpolate`s3://${test.bucket}/${documents.id}`,
* },
* }, {
* dependsOn: [exampleAwsIamRolePolicy],
* });
* const entities = new aws.s3.BucketObjectv2("entities", {});
* ```
* ```python
* import pulumi
* import pulumi_aws as aws
* documents = aws.s3.BucketObjectv2("documents")
* example = aws.comprehend.DocumentClassifier("example",
* name="example",
* data_access_role_arn=example_aws_iam_role["arn"],
* language_code="en",
* input_data_config={
* "s3_uri": documents.id.apply(lambda id: f"s3://{test['bucket']}/{id}"),
* },
* opts = pulumi.ResourceOptions(depends_on=[example_aws_iam_role_policy]))
* entities = aws.s3.BucketObjectv2("entities")
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Aws = Pulumi.Aws;
* return await Deployment.RunAsync(() =>
* {
* var documents = new Aws.S3.BucketObjectv2("documents");
* var example = new Aws.Comprehend.DocumentClassifier("example", new()
* {
* Name = "example",
* DataAccessRoleArn = exampleAwsIamRole.Arn,
* LanguageCode = "en",
* InputDataConfig = new Aws.Comprehend.Inputs.DocumentClassifierInputDataConfigArgs
* {
* S3Uri = documents.Id.Apply(id => $"s3://{test.Bucket}/{id}"),
* },
* }, new CustomResourceOptions
* {
* DependsOn =
* {
* exampleAwsIamRolePolicy,
* },
* });
* var entities = new Aws.S3.BucketObjectv2("entities");
* });
* ```
* ```go
* package main
* import (
* "fmt"
* "github.com/pulumi/pulumi-aws/sdk/v6/go/aws/comprehend"
* "github.com/pulumi/pulumi-aws/sdk/v6/go/aws/s3"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* documents, err := s3.NewBucketObjectv2(ctx, "documents", nil)
* if err != nil {
* return err
* }
* _, err = comprehend.NewDocumentClassifier(ctx, "example", &comprehend.DocumentClassifierArgs{
* Name: pulumi.String("example"),
* DataAccessRoleArn: pulumi.Any(exampleAwsIamRole.Arn),
* LanguageCode: pulumi.String("en"),
* InputDataConfig: &comprehend.DocumentClassifierInputDataConfigArgs{
* S3Uri: documents.ID().ApplyT(func(id string) (string, error) {
* return fmt.Sprintf("s3://%v/%v", test.Bucket, id), nil
* }).(pulumi.StringOutput),
* },
* }, pulumi.DependsOn([]pulumi.Resource{
* exampleAwsIamRolePolicy,
* }))
* if err != nil {
* return err
* }
* _, err = s3.NewBucketObjectv2(ctx, "entities", nil)
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.aws.s3.BucketObjectv2;
* import com.pulumi.aws.comprehend.DocumentClassifier;
* import com.pulumi.aws.comprehend.DocumentClassifierArgs;
* import com.pulumi.aws.comprehend.inputs.DocumentClassifierInputDataConfigArgs;
* import com.pulumi.resources.CustomResourceOptions;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
* public static void stack(Context ctx) {
* var documents = new BucketObjectv2("documents");
* var example = new DocumentClassifier("example", DocumentClassifierArgs.builder()
* .name("example")
* .dataAccessRoleArn(exampleAwsIamRole.arn())
* .languageCode("en")
* .inputDataConfig(DocumentClassifierInputDataConfigArgs.builder()
* .s3Uri(documents.id().applyValue(id -> String.format("s3://%s/%s", test.bucket(),id)))
* .build())
* .build(), CustomResourceOptions.builder()
* .dependsOn(exampleAwsIamRolePolicy)
* .build());
* var entities = new BucketObjectv2("entities");
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: aws:comprehend:DocumentClassifier
* properties:
* name: example
* dataAccessRoleArn: ${exampleAwsIamRole.arn}
* languageCode: en
* inputDataConfig:
* s3Uri: s3://${test.bucket}/${documents.id}
* options:
* dependson:
* - ${exampleAwsIamRolePolicy}
* documents:
* type: aws:s3:BucketObjectv2
* entities:
* type: aws:s3:BucketObjectv2
* ```
*
* ## Import
* Using `pulumi import`, import Comprehend Document Classifier using the ARN. For example:
* ```sh
* $ pulumi import aws:comprehend/documentClassifier:DocumentClassifier example arn:aws:comprehend:us-west-2:123456789012:document_classifier/example
* ```
* @property dataAccessRoleArn The ARN for an IAM Role which allows Comprehend to read the training and testing data.
* @property inputDataConfig Configuration for the training and testing data.
* See the `input_data_config` Configuration Block section below.
* @property languageCode Two-letter language code for the language.
* One of `en`, `es`, `fr`, `it`, `de`, or `pt`.
* @property mode The document classification mode.
* One of `MULTI_CLASS` or `MULTI_LABEL`.
* `MULTI_CLASS` is also known as "Single Label" in the AWS Console.
* @property modelKmsKeyId KMS Key used to encrypt trained Document Classifiers.
* Can be a KMS Key ID or a KMS Key ARN.
* @property name Name for the Document Classifier.
* Has a maximum length of 63 characters.
* Can contain upper- and lower-case letters, numbers, and hypen (`-`).
* The following arguments are optional:
* @property outputDataConfig Configuration for the output results of training.
* See the `output_data_config` Configuration Block section below.
* @property tags A map of tags to assign to the resource. If configured with a provider `default_tags` Configuration Block present, tags with matching keys will overwrite those defined at the provider-level.
* @property versionName Name for the version of the Document Classifier.
* Each version must have a unique name within the Document Classifier.
* If omitted, the provider will assign a random, unique version name.
* If explicitly set to `""`, no version name will be set.
* Has a maximum length of 63 characters.
* Can contain upper- and lower-case letters, numbers, and hypen (`-`).
* Conflicts with `version_name_prefix`.
* @property versionNamePrefix Creates a unique version name beginning with the specified prefix.
* Has a maximum length of 37 characters.
* Can contain upper- and lower-case letters, numbers, and hypen (`-`).
* Conflicts with `version_name`.
* @property volumeKmsKeyId KMS Key used to encrypt storage volumes during job processing.
* Can be a KMS Key ID or a KMS Key ARN.
* @property vpcConfig Configuration parameters for VPC to contain Document Classifier resources.
* See the `vpc_config` Configuration Block section below.
*/
public data class DocumentClassifierArgs(
public val dataAccessRoleArn: Output? = null,
public val inputDataConfig: Output? = null,
public val languageCode: Output? = null,
public val mode: Output? = null,
public val modelKmsKeyId: Output? = null,
public val name: Output? = null,
public val outputDataConfig: Output? = null,
public val tags: Output