import * as pulumi from "@pulumi/pulumi";
import * as inputs from "./types/input";
import * as outputs from "./types/output";
export declare class DiskAnomalyRules extends pulumi.CustomResource {
    /**
     * Get an existing DiskAnomalyRules resource's state with the given name, ID, and optional extra
     * properties used to qualify the lookup.
     *
     * @param name The _unique_ name of the resulting resource.
     * @param id The _unique_ provider ID of the resource to lookup.
     * @param state Any extra arguments used during the lookup.
     * @param opts Optional settings to control the behavior of the CustomResource.
     */
    static get(name: string, id: pulumi.Input<pulumi.ID>, state?: DiskAnomalyRulesState, opts?: pulumi.CustomResourceOptions): DiskAnomalyRules;
    /**
     * Returns true if the given object is an instance of DiskAnomalyRules.  This is designed to work even
     * when multiple copies of the Pulumi SDK have been loaded into the same process.
     */
    static isInstance(obj: any): obj is DiskAnomalyRules;
    /**
     * Only apply to disks whose name matches
     */
    readonly diskNameFilter: pulumi.Output<outputs.DiskAnomalyRulesDiskNameFilter>;
    /**
     * This setting is enabled (`true`) or disabled (`false`)
     */
    readonly enabled: pulumi.Output<boolean>;
    /**
     * The scope of this settings. If the settings should cover the whole environment, just don't specify any scope.
     */
    readonly hostGroupId: pulumi.Output<string | undefined>;
    /**
     * Possible Values: `LOW_DISK_SPACE`, `LOW_INODES`, `READ_TIME_EXCEEDING`, `WRITE_TIME_EXCEEDING`
     */
    readonly metric: pulumi.Output<string>;
    /**
     * Name
     */
    readonly name: pulumi.Output<string>;
    /**
     * Only alert if the threshold was violated in at least *n* of the last *m* samples
     */
    readonly sampleLimit: pulumi.Output<outputs.DiskAnomalyRulesSampleLimit>;
    /**
     * Only apply to hosts that have the following tags
     */
    readonly tagFilters: pulumi.Output<string[] | undefined>;
    /**
     * Alert if higher than
     */
    readonly thresholdMilliseconds: pulumi.Output<number | undefined>;
    /**
     * Alert if lower than
     */
    readonly thresholdPercent: pulumi.Output<number | undefined>;
    /**
     * Create a DiskAnomalyRules resource with the given unique name, arguments, and options.
     *
     * @param name The _unique_ name of the resource.
     * @param args The arguments to use to populate this resource's properties.
     * @param opts A bag of options that control this resource's behavior.
     */
    constructor(name: string, args: DiskAnomalyRulesArgs, opts?: pulumi.CustomResourceOptions);
}
/**
 * Input properties used for looking up and filtering DiskAnomalyRules resources.
 */
export interface DiskAnomalyRulesState {
    /**
     * Only apply to disks whose name matches
     */
    diskNameFilter?: pulumi.Input<inputs.DiskAnomalyRulesDiskNameFilter>;
    /**
     * This setting is enabled (`true`) or disabled (`false`)
     */
    enabled?: pulumi.Input<boolean>;
    /**
     * The scope of this settings. If the settings should cover the whole environment, just don't specify any scope.
     */
    hostGroupId?: pulumi.Input<string>;
    /**
     * Possible Values: `LOW_DISK_SPACE`, `LOW_INODES`, `READ_TIME_EXCEEDING`, `WRITE_TIME_EXCEEDING`
     */
    metric?: pulumi.Input<string>;
    /**
     * Name
     */
    name?: pulumi.Input<string>;
    /**
     * Only alert if the threshold was violated in at least *n* of the last *m* samples
     */
    sampleLimit?: pulumi.Input<inputs.DiskAnomalyRulesSampleLimit>;
    /**
     * Only apply to hosts that have the following tags
     */
    tagFilters?: pulumi.Input<pulumi.Input<string>[]>;
    /**
     * Alert if higher than
     */
    thresholdMilliseconds?: pulumi.Input<number>;
    /**
     * Alert if lower than
     */
    thresholdPercent?: pulumi.Input<number>;
}
/**
 * The set of arguments for constructing a DiskAnomalyRules resource.
 */
export interface DiskAnomalyRulesArgs {
    /**
     * Only apply to disks whose name matches
     */
    diskNameFilter: pulumi.Input<inputs.DiskAnomalyRulesDiskNameFilter>;
    /**
     * This setting is enabled (`true`) or disabled (`false`)
     */
    enabled: pulumi.Input<boolean>;
    /**
     * The scope of this settings. If the settings should cover the whole environment, just don't specify any scope.
     */
    hostGroupId?: pulumi.Input<string>;
    /**
     * Possible Values: `LOW_DISK_SPACE`, `LOW_INODES`, `READ_TIME_EXCEEDING`, `WRITE_TIME_EXCEEDING`
     */
    metric: pulumi.Input<string>;
    /**
     * Name
     */
    name?: pulumi.Input<string>;
    /**
     * Only alert if the threshold was violated in at least *n* of the last *m* samples
     */
    sampleLimit: pulumi.Input<inputs.DiskAnomalyRulesSampleLimit>;
    /**
     * Only apply to hosts that have the following tags
     */
    tagFilters?: pulumi.Input<pulumi.Input<string>[]>;
    /**
     * Alert if higher than
     */
    thresholdMilliseconds?: pulumi.Input<number>;
    /**
     * Alert if lower than
     */
    thresholdPercent?: pulumi.Input<number>;
}
