import * as pulumi from "@pulumi/pulumi"; /** * This resource represents load balancer resolver. * * ## Example Usage * * ```typescript * import * as pulumi from "@pulumi/pulumi"; * import * as upcloud from "@upcloud/pulumi-upcloud"; * * const config = new pulumi.Config(); * const lbZone = config.get("lbZone") || "fi-hel2"; * const lbNetwork = new upcloud.Network("lb_network", { * name: "lb-test-net", * zone: lbZone, * ipNetwork: { * address: "10.0.0.0/24", * dhcp: true, * family: "IPv4", * }, * }); * const lb = new upcloud.Loadbalancer("lb", { * configuredStatus: "started", * name: "lb-test", * plan: "development", * zone: lbZone, * network: upcloudNetwork.lbNetwork.id, * }); * const lbResolver1 = new upcloud.LoadbalancerResolver("lb_resolver_1", { * loadbalancer: upcloudLoadbalancer.lb.id, * name: "lb-resolver-1-test", * cacheInvalid: 10, * cacheValid: 100, * retries: 5, * timeout: 10, * timeoutRetry: 10, * nameservers: ["10.0.0.10:53"], * }); * ``` */ export declare class LoadbalancerResolver extends pulumi.CustomResource { /** * Get an existing LoadbalancerResolver 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, state?: LoadbalancerResolverState, opts?: pulumi.CustomResourceOptions): LoadbalancerResolver; /** * Returns true if the given object is an instance of LoadbalancerResolver. 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 LoadbalancerResolver; /** * Time in seconds to cache invalid results. */ readonly cacheInvalid: pulumi.Output; /** * Time in seconds to cache valid results. */ readonly cacheValid: pulumi.Output; /** * ID of the load balancer to which the resolver is connected. */ readonly loadbalancer: pulumi.Output; /** * The name of the resolver. Must be unique within the service. */ readonly name: pulumi.Output; /** * List of nameserver IP addresses. Nameserver can reside in public internet or in customer private network. Port is optional, if missing then default 53 will be used. */ readonly nameservers: pulumi.Output; /** * Number of retries on failure. */ readonly retries: pulumi.Output; /** * Timeout for the query in seconds. */ readonly timeout: pulumi.Output; /** * Timeout for the query retries in seconds. */ readonly timeoutRetry: pulumi.Output; /** * Create a LoadbalancerResolver 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: LoadbalancerResolverArgs, opts?: pulumi.CustomResourceOptions); } /** * Input properties used for looking up and filtering LoadbalancerResolver resources. */ export interface LoadbalancerResolverState { /** * Time in seconds to cache invalid results. */ cacheInvalid?: pulumi.Input; /** * Time in seconds to cache valid results. */ cacheValid?: pulumi.Input; /** * ID of the load balancer to which the resolver is connected. */ loadbalancer?: pulumi.Input; /** * The name of the resolver. Must be unique within the service. */ name?: pulumi.Input; /** * List of nameserver IP addresses. Nameserver can reside in public internet or in customer private network. Port is optional, if missing then default 53 will be used. */ nameservers?: pulumi.Input[]>; /** * Number of retries on failure. */ retries?: pulumi.Input; /** * Timeout for the query in seconds. */ timeout?: pulumi.Input; /** * Timeout for the query retries in seconds. */ timeoutRetry?: pulumi.Input; } /** * The set of arguments for constructing a LoadbalancerResolver resource. */ export interface LoadbalancerResolverArgs { /** * Time in seconds to cache invalid results. */ cacheInvalid: pulumi.Input; /** * Time in seconds to cache valid results. */ cacheValid: pulumi.Input; /** * ID of the load balancer to which the resolver is connected. */ loadbalancer: pulumi.Input; /** * The name of the resolver. Must be unique within the service. */ name?: pulumi.Input; /** * List of nameserver IP addresses. Nameserver can reside in public internet or in customer private network. Port is optional, if missing then default 53 will be used. */ nameservers: pulumi.Input[]>; /** * Number of retries on failure. */ retries: pulumi.Input; /** * Timeout for the query in seconds. */ timeout: pulumi.Input; /** * Timeout for the query retries in seconds. */ timeoutRetry: pulumi.Input; }