
com.pulumi.aws.guardduty.IPSet Maven / Gradle / Ivy
// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package com.pulumi.aws.guardduty;
import com.pulumi.aws.Utilities;
import com.pulumi.aws.guardduty.IPSetArgs;
import com.pulumi.aws.guardduty.inputs.IPSetState;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Export;
import com.pulumi.core.annotations.ResourceType;
import com.pulumi.core.internal.Codegen;
import java.lang.Boolean;
import java.lang.String;
import java.util.Map;
import java.util.Optional;
import javax.annotation.Nullable;
/**
* Provides a resource to manage a GuardDuty IPSet.
*
* > **Note:** Currently in GuardDuty, users from member accounts cannot upload and further manage IPSets. IPSets that are uploaded by the primary account are imposed on GuardDuty functionality in its member accounts. See the [GuardDuty API Documentation](https://docs.aws.amazon.com/guardduty/latest/ug/create-ip-set.html)
*
* ## Example Usage
*
* <!--Start PulumiCodeChooser -->
*
* {@code
* package generated_program;
*
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.aws.guardduty.Detector;
* import com.pulumi.aws.guardduty.DetectorArgs;
* import com.pulumi.aws.s3.BucketV2;
* import com.pulumi.aws.s3.BucketObjectv2;
* import com.pulumi.aws.s3.BucketObjectv2Args;
* import com.pulumi.aws.guardduty.IPSet;
* import com.pulumi.aws.guardduty.IPSetArgs;
* import com.pulumi.aws.s3.BucketAclV2;
* import com.pulumi.aws.s3.BucketAclV2Args;
* 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 primary = new Detector("primary", DetectorArgs.builder()
* .enable(true)
* .build());
*
* var bucket = new BucketV2("bucket");
*
* var myIPSet = new BucketObjectv2("myIPSet", BucketObjectv2Args.builder()
* .content("""
* 10.0.0.0/8
* """)
* .bucket(bucket.id())
* .key("MyIPSet")
* .build());
*
* var example = new IPSet("example", IPSetArgs.builder()
* .activate(true)
* .detectorId(primary.id())
* .format("TXT")
* .location(Output.tuple(myIPSet.bucket(), myIPSet.key()).applyValue(values -> {
* var bucket = values.t1;
* var key = values.t2;
* return String.format("https://s3.amazonaws.com/%s/%s", bucket,key);
* }))
* .name("MyIPSet")
* .build());
*
* var bucketAcl = new BucketAclV2("bucketAcl", BucketAclV2Args.builder()
* .bucket(bucket.id())
* .acl("private")
* .build());
*
* }
* }
* }
*
* <!--End PulumiCodeChooser -->
*
* ## Import
*
* Using `pulumi import`, import GuardDuty IPSet using the primary GuardDuty detector ID and IPSet ID. For example:
*
* ```sh
* $ pulumi import aws:guardduty/iPSet:IPSet MyIPSet 00b00fd5aecc0ab60a708659477e9617:123456789012
* ```
*
*/
@ResourceType(type="aws:guardduty/iPSet:IPSet")
public class IPSet extends com.pulumi.resources.CustomResource {
/**
* Specifies whether GuardDuty is to start using the uploaded IPSet.
*
*/
@Export(name="activate", refs={Boolean.class}, tree="[0]")
private Output activate;
/**
* @return Specifies whether GuardDuty is to start using the uploaded IPSet.
*
*/
public Output activate() {
return this.activate;
}
/**
* Amazon Resource Name (ARN) of the GuardDuty IPSet.
*
*/
@Export(name="arn", refs={String.class}, tree="[0]")
private Output arn;
/**
* @return Amazon Resource Name (ARN) of the GuardDuty IPSet.
*
*/
public Output arn() {
return this.arn;
}
/**
* The detector ID of the GuardDuty.
*
*/
@Export(name="detectorId", refs={String.class}, tree="[0]")
private Output detectorId;
/**
* @return The detector ID of the GuardDuty.
*
*/
public Output detectorId() {
return this.detectorId;
}
/**
* The format of the file that contains the IPSet. Valid values: `TXT` | `STIX` | `OTX_CSV` | `ALIEN_VAULT` | `PROOF_POINT` | `FIRE_EYE`
*
*/
@Export(name="format", refs={String.class}, tree="[0]")
private Output format;
/**
* @return The format of the file that contains the IPSet. Valid values: `TXT` | `STIX` | `OTX_CSV` | `ALIEN_VAULT` | `PROOF_POINT` | `FIRE_EYE`
*
*/
public Output format() {
return this.format;
}
/**
* The URI of the file that contains the IPSet.
*
*/
@Export(name="location", refs={String.class}, tree="[0]")
private Output location;
/**
* @return The URI of the file that contains the IPSet.
*
*/
public Output location() {
return this.location;
}
/**
* The friendly name to identify the IPSet.
*
*/
@Export(name="name", refs={String.class}, tree="[0]")
private Output name;
/**
* @return The friendly name to identify the IPSet.
*
*/
public Output name() {
return this.name;
}
/**
* Key-value map of resource tags. .If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*
*/
@Export(name="tags", refs={Map.class,String.class}, tree="[0,1,1]")
private Output* @Nullable */ Map> tags;
/**
* @return Key-value map of resource tags. .If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*
*/
public Output>> tags() {
return Codegen.optional(this.tags);
}
/**
* A map of tags assigned to the resource, including those inherited from the provider `default_tags` configuration block.
*
* @deprecated
* Please use `tags` instead.
*
*/
@Deprecated /* Please use `tags` instead. */
@Export(name="tagsAll", refs={Map.class,String.class}, tree="[0,1,1]")
private Output
© 2015 - 2025 Weber Informatics LLC | Privacy Policy