import * as pulumi from "@pulumi/pulumi"; import * as inputs from "../types/input"; import * as outputs from "../types/output"; /** * Resource for creating a Harness Infrastructure. * * ## Example Usage * * ```typescript * import * as pulumi from "@pulumi/pulumi"; * import * as harness from "@pulumi/harness"; * * const example = new harness.platform.Infrastructure("example", { * identifier: "identifier", * name: "name", * orgId: "orgIdentifer", * projectId: "projectIdentifier", * envId: "environmentIdentifier", * type: "KubernetesDirect", * deploymentType: "Kubernetes", * gitDetails: { * branchName: "branchName", * commitMessage: "commitMessage", * filePath: "filePath", * connectorRef: "connectorRef", * storeType: "REMOTE", * repoName: "repoName", * }, * yaml: `infrastructureDefinition: * name: name * identifier: identifier * description: \\"\\" * tags: * asda: \\"\\" * orgIdentifier: orgIdentifer * projectIdentifier: projectIdentifier * environmentRef: environmentIdentifier * deploymentType: Kubernetes * type: KubernetesDirect * spec: * connectorRef: account.gfgf * namespace: asdasdsa * releaseName: release-<+INFRA_KEY> * allowSimultaneousDeployments: false * `, * }); * ``` * * ## Import * * The `pulumi import` command can be used, for example: * * Import account level infrastructure * * ```sh * $ pulumi import harness:platform/infrastructure:Infrastructure example / * ``` * * Import org level infrastructure * * ```sh * $ pulumi import harness:platform/infrastructure:Infrastructure example // * ``` * * Import project level infrastructure * * ```sh * $ pulumi import harness:platform/infrastructure:Infrastructure example /// * ``` */ export declare class Infrastructure extends pulumi.CustomResource { /** * Get an existing Infrastructure 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?: InfrastructureState, opts?: pulumi.CustomResourceOptions): Infrastructure; /** * Returns true if the given object is an instance of Infrastructure. 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 Infrastructure; /** * Infrastructure deployment type. Valid values are Kubernetes, NativeHelm, Ssh, WinRm, ServerlessAwsLambda, AzureWebApp, Custom, ECS, GoogleManagedInstanceGroup. */ readonly deploymentType: pulumi.Output; /** * Description of the resource. */ readonly description: pulumi.Output; /** * Environment Identifier. */ readonly envId: pulumi.Output; /** * Enable this flag for force deletion of infrastructure */ readonly forceDelete: pulumi.Output; /** * Contains parameters related to creating an Entity for Git Experience. */ readonly gitDetails: pulumi.Output; /** * Unique identifier of the resource. */ readonly identifier: pulumi.Output; /** * Name of the resource. */ readonly name: pulumi.Output; /** * Unique identifier of the organization. */ readonly orgId: pulumi.Output; /** * Unique identifier of the project. */ readonly projectId: pulumi.Output; /** * Tags to associate with the resource. */ readonly tags: pulumi.Output; /** * Type of Infrastructure. Valid values are KubernetesDirect, KubernetesGcp, ServerlessAwsLambda, Pdc, KubernetesAzure, SshWinRmAzure, SshWinRmAws, AzureWebApp, ECS, GitOps, CustomDeployment, TAS, KubernetesRancher, AWS_SAM, GoogleManagedInstanceGroup. */ readonly type: pulumi.Output; /** * Infrastructure YAML. In YAML, to reference an entity at the organization scope, prefix 'org' to the expression: org.{identifier}. To reference an entity at the account scope, prefix 'account` to the expression: account.{identifier}. For eg, to reference a connector with identifier 'connectorId' at the organization scope in a stage mention it as connectorRef: org.connectorId. */ readonly yaml: pulumi.Output; /** * Create a Infrastructure 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: InfrastructureArgs, opts?: pulumi.CustomResourceOptions); } /** * Input properties used for looking up and filtering Infrastructure resources. */ export interface InfrastructureState { /** * Infrastructure deployment type. Valid values are Kubernetes, NativeHelm, Ssh, WinRm, ServerlessAwsLambda, AzureWebApp, Custom, ECS, GoogleManagedInstanceGroup. */ deploymentType?: pulumi.Input; /** * Description of the resource. */ description?: pulumi.Input; /** * Environment Identifier. */ envId?: pulumi.Input; /** * Enable this flag for force deletion of infrastructure */ forceDelete?: pulumi.Input; /** * Contains parameters related to creating an Entity for Git Experience. */ gitDetails?: pulumi.Input; /** * Unique identifier of the resource. */ identifier?: pulumi.Input; /** * Name of the resource. */ name?: pulumi.Input; /** * Unique identifier of the organization. */ orgId?: pulumi.Input; /** * Unique identifier of the project. */ projectId?: pulumi.Input; /** * Tags to associate with the resource. */ tags?: pulumi.Input[] | undefined>; /** * Type of Infrastructure. Valid values are KubernetesDirect, KubernetesGcp, ServerlessAwsLambda, Pdc, KubernetesAzure, SshWinRmAzure, SshWinRmAws, AzureWebApp, ECS, GitOps, CustomDeployment, TAS, KubernetesRancher, AWS_SAM, GoogleManagedInstanceGroup. */ type?: pulumi.Input; /** * Infrastructure YAML. In YAML, to reference an entity at the organization scope, prefix 'org' to the expression: org.{identifier}. To reference an entity at the account scope, prefix 'account` to the expression: account.{identifier}. For eg, to reference a connector with identifier 'connectorId' at the organization scope in a stage mention it as connectorRef: org.connectorId. */ yaml?: pulumi.Input; } /** * The set of arguments for constructing a Infrastructure resource. */ export interface InfrastructureArgs { /** * Infrastructure deployment type. Valid values are Kubernetes, NativeHelm, Ssh, WinRm, ServerlessAwsLambda, AzureWebApp, Custom, ECS, GoogleManagedInstanceGroup. */ deploymentType?: pulumi.Input; /** * Description of the resource. */ description?: pulumi.Input; /** * Environment Identifier. */ envId: pulumi.Input; /** * Enable this flag for force deletion of infrastructure */ forceDelete?: pulumi.Input; /** * Contains parameters related to creating an Entity for Git Experience. */ gitDetails?: pulumi.Input; /** * Unique identifier of the resource. */ identifier?: pulumi.Input; /** * Name of the resource. */ name?: pulumi.Input; /** * Unique identifier of the organization. */ orgId?: pulumi.Input; /** * Unique identifier of the project. */ projectId?: pulumi.Input; /** * Tags to associate with the resource. */ tags?: pulumi.Input[] | undefined>; /** * Type of Infrastructure. Valid values are KubernetesDirect, KubernetesGcp, ServerlessAwsLambda, Pdc, KubernetesAzure, SshWinRmAzure, SshWinRmAws, AzureWebApp, ECS, GitOps, CustomDeployment, TAS, KubernetesRancher, AWS_SAM, GoogleManagedInstanceGroup. */ type?: pulumi.Input; /** * Infrastructure YAML. In YAML, to reference an entity at the organization scope, prefix 'org' to the expression: org.{identifier}. To reference an entity at the account scope, prefix 'account` to the expression: account.{identifier}. For eg, to reference a connector with identifier 'connectorId' at the organization scope in a stage mention it as connectorRef: org.connectorId. */ yaml?: pulumi.Input; } //# sourceMappingURL=infrastructure.d.ts.map