1. Packages
  2. Google Cloud (GCP) Classic
  3. API Docs
  4. compute
  5. ProjectMetadata
Google Cloud Classic v7.2.2 published on Monday, Jan 1, 0001 by Pulumi

gcp.compute.ProjectMetadata

Explore with Pulumi AI

gcp logo
Google Cloud Classic v7.2.2 published on Monday, Jan 1, 0001 by Pulumi

    Authoritatively manages metadata common to all instances for a project in GCE. For more information see the official documentation and API.

    Note: This resource manages all project-level metadata including project-level ssh keys. Keys unset in config but set on the server will be removed. If you want to manage only single key/value pairs within the project metadata rather than the entire set, then use google_compute_project_metadata_item.

    Example Usage

    using System.Collections.Generic;
    using System.Linq;
    using Pulumi;
    using Gcp = Pulumi.Gcp;
    
    return await Deployment.RunAsync(() => 
    {
        var @default = new Gcp.Compute.ProjectMetadata("default", new()
        {
            Metadata = 
            {
                { "13", "42" },
                { "fizz", "buzz" },
                { "foo", "bar" },
            },
        });
    
    });
    
    package main
    
    import (
    	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
    	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
    )
    
    func main() {
    	pulumi.Run(func(ctx *pulumi.Context) error {
    		_, err := compute.NewProjectMetadata(ctx, "default", &compute.ProjectMetadataArgs{
    			Metadata: pulumi.StringMap{
    				"13":   pulumi.String("42"),
    				"fizz": pulumi.String("buzz"),
    				"foo":  pulumi.String("bar"),
    			},
    		})
    		if err != nil {
    			return err
    		}
    		return nil
    	})
    }
    
    package generated_program;
    
    import com.pulumi.Context;
    import com.pulumi.Pulumi;
    import com.pulumi.core.Output;
    import com.pulumi.gcp.compute.ProjectMetadata;
    import com.pulumi.gcp.compute.ProjectMetadataArgs;
    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 default_ = new ProjectMetadata("default", ProjectMetadataArgs.builder()        
                .metadata(Map.ofEntries(
                    Map.entry("13", "42"),
                    Map.entry("fizz", "buzz"),
                    Map.entry("foo", "bar")
                ))
                .build());
    
        }
    }
    
    import pulumi
    import pulumi_gcp as gcp
    
    default = gcp.compute.ProjectMetadata("default", metadata={
        "13": "42",
        "fizz": "buzz",
        "foo": "bar",
    })
    
    import * as pulumi from "@pulumi/pulumi";
    import * as gcp from "@pulumi/gcp";
    
    const _default = new gcp.compute.ProjectMetadata("default", {metadata: {
        "13": "42",
        fizz: "buzz",
        foo: "bar",
    }});
    
    resources:
      default:
        type: gcp:compute:ProjectMetadata
        properties:
          metadata:
            '13': '42'
            fizz: buzz
            foo: bar
    

    Adding An SSH Key

    using System.Collections.Generic;
    using System.Linq;
    using Pulumi;
    using Gcp = Pulumi.Gcp;
    
    return await Deployment.RunAsync(() => 
    {
        //A key set in project metadata is propagated to every instance in the project.
        //This resource configuration is prone to causing frequent diffs as Google adds SSH Keys when the SSH Button is pressed in the console.
        //It is better to use OS Login instead.
        var mySshKey = new Gcp.Compute.ProjectMetadata("mySshKey", new()
        {
            Metadata = 
            {
                { "ssh-keys", @"      dev:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT dev
          foo:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT bar
        
    " },
            },
        });
    
    });
    
    package main
    
    import (
    	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
    	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
    )
    
    func main() {
    	pulumi.Run(func(ctx *pulumi.Context) error {
    		_, err := compute.NewProjectMetadata(ctx, "mySshKey", &compute.ProjectMetadataArgs{
    			Metadata: pulumi.StringMap{
    				"ssh-keys": pulumi.String("      dev:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT dev\n      foo:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT bar\n    \n"),
    			},
    		})
    		if err != nil {
    			return err
    		}
    		return nil
    	})
    }
    
    package generated_program;
    
    import com.pulumi.Context;
    import com.pulumi.Pulumi;
    import com.pulumi.core.Output;
    import com.pulumi.gcp.compute.ProjectMetadata;
    import com.pulumi.gcp.compute.ProjectMetadataArgs;
    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 mySshKey = new ProjectMetadata("mySshKey", ProjectMetadataArgs.builder()        
                .metadata(Map.of("ssh-keys", """
          dev:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT dev
          foo:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT bar
        
                """))
                .build());
    
        }
    }
    
    import pulumi
    import pulumi_gcp as gcp
    
    #A key set in project metadata is propagated to every instance in the project.
    #This resource configuration is prone to causing frequent diffs as Google adds SSH Keys when the SSH Button is pressed in the console.
    #It is better to use OS Login instead.
    my_ssh_key = gcp.compute.ProjectMetadata("mySshKey", metadata={
        "ssh-keys": """      dev:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT dev
          foo:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT bar
        
    """,
    })
    
    import * as pulumi from "@pulumi/pulumi";
    import * as gcp from "@pulumi/gcp";
    
    //A key set in project metadata is propagated to every instance in the project.
    //This resource configuration is prone to causing frequent diffs as Google adds SSH Keys when the SSH Button is pressed in the console.
    //It is better to use OS Login instead.
    const mySshKey = new gcp.compute.ProjectMetadata("mySshKey", {metadata: {
        "ssh-keys": `      dev:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT dev
          foo:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT bar
        
    `,
    }});
    
    resources:
      # A key set in project metadata is propagated to every instance in the project.
      # //This resource configuration is prone to causing frequent diffs as Google adds SSH Keys when the SSH Button is pressed in the console.
      # //It is better to use OS Login instead.
      mySshKey:
        type: gcp:compute:ProjectMetadata
        properties:
          metadata:
            ssh-keys: "      dev:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT dev\n      foo:ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILg6UtHDNyMNAh0GjaytsJdrUxjtLy3APXqZfNZhvCeT bar\n    \n"
    

    Create ProjectMetadata Resource

    new ProjectMetadata(name: string, args: ProjectMetadataArgs, opts?: CustomResourceOptions);
    @overload
    def ProjectMetadata(resource_name: str,
                        opts: Optional[ResourceOptions] = None,
                        metadata: Optional[Mapping[str, str]] = None,
                        project: Optional[str] = None)
    @overload
    def ProjectMetadata(resource_name: str,
                        args: ProjectMetadataArgs,
                        opts: Optional[ResourceOptions] = None)
    func NewProjectMetadata(ctx *Context, name string, args ProjectMetadataArgs, opts ...ResourceOption) (*ProjectMetadata, error)
    public ProjectMetadata(string name, ProjectMetadataArgs args, CustomResourceOptions? opts = null)
    public ProjectMetadata(String name, ProjectMetadataArgs args)
    public ProjectMetadata(String name, ProjectMetadataArgs args, CustomResourceOptions options)
    
    type: gcp:compute:ProjectMetadata
    properties: # The arguments to resource properties.
    options: # Bag of options to control resource's behavior.
    
    
    name string
    The unique name of the resource.
    args ProjectMetadataArgs
    The arguments to resource properties.
    opts CustomResourceOptions
    Bag of options to control resource's behavior.
    resource_name str
    The unique name of the resource.
    args ProjectMetadataArgs
    The arguments to resource properties.
    opts ResourceOptions
    Bag of options to control resource's behavior.
    ctx Context
    Context object for the current deployment.
    name string
    The unique name of the resource.
    args ProjectMetadataArgs
    The arguments to resource properties.
    opts ResourceOption
    Bag of options to control resource's behavior.
    name string
    The unique name of the resource.
    args ProjectMetadataArgs
    The arguments to resource properties.
    opts CustomResourceOptions
    Bag of options to control resource's behavior.
    name String
    The unique name of the resource.
    args ProjectMetadataArgs
    The arguments to resource properties.
    options CustomResourceOptions
    Bag of options to control resource's behavior.

    ProjectMetadata Resource Properties

    To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.

    Inputs

    The ProjectMetadata resource accepts the following input properties:

    Metadata Dictionary<string, string>

    A series of key value pairs.


    Project string

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    Metadata map[string]string

    A series of key value pairs.


    Project string

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    metadata Map<String,String>

    A series of key value pairs.


    project String

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    metadata {[key: string]: string}

    A series of key value pairs.


    project string

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    metadata Mapping[str, str]

    A series of key value pairs.


    project str

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    metadata Map<String>

    A series of key value pairs.


    project String

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    Outputs

    All input properties are implicitly available as output properties. Additionally, the ProjectMetadata resource produces the following output properties:

    Id string

    The provider-assigned unique ID for this managed resource.

    Id string

    The provider-assigned unique ID for this managed resource.

    id String

    The provider-assigned unique ID for this managed resource.

    id string

    The provider-assigned unique ID for this managed resource.

    id str

    The provider-assigned unique ID for this managed resource.

    id String

    The provider-assigned unique ID for this managed resource.

    Look up Existing ProjectMetadata Resource

    Get an existing ProjectMetadata resource’s state with the given name, ID, and optional extra properties used to qualify the lookup.

    public static get(name: string, id: Input<ID>, state?: ProjectMetadataState, opts?: CustomResourceOptions): ProjectMetadata
    @staticmethod
    def get(resource_name: str,
            id: str,
            opts: Optional[ResourceOptions] = None,
            metadata: Optional[Mapping[str, str]] = None,
            project: Optional[str] = None) -> ProjectMetadata
    func GetProjectMetadata(ctx *Context, name string, id IDInput, state *ProjectMetadataState, opts ...ResourceOption) (*ProjectMetadata, error)
    public static ProjectMetadata Get(string name, Input<string> id, ProjectMetadataState? state, CustomResourceOptions? opts = null)
    public static ProjectMetadata get(String name, Output<String> id, ProjectMetadataState state, CustomResourceOptions options)
    Resource lookup is not supported in YAML
    name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    state
    Any extra arguments used during the lookup.
    opts
    A bag of options that control this resource's behavior.
    resource_name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    state
    Any extra arguments used during the lookup.
    opts
    A bag of options that control this resource's behavior.
    name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    state
    Any extra arguments used during the lookup.
    opts
    A bag of options that control this resource's behavior.
    name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    state
    Any extra arguments used during the lookup.
    opts
    A bag of options that control this resource's behavior.
    The following state arguments are supported:
    Metadata Dictionary<string, string>

    A series of key value pairs.


    Project string

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    Metadata map[string]string

    A series of key value pairs.


    Project string

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    metadata Map<String,String>

    A series of key value pairs.


    project String

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    metadata {[key: string]: string}

    A series of key value pairs.


    project string

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    metadata Mapping[str, str]

    A series of key value pairs.


    project str

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    metadata Map<String>

    A series of key value pairs.


    project String

    The ID of the project in which the resource belongs. If it is not provided, the provider project is used.

    Import

    Project metadata can be imported using the project ID* {{project_id}} In Terraform v1.5.0 and later, use an import block to import project metadata using one of the formats above. For exampletf import {

    id = “{{project_id}}”

    to = google_compute_project_metadata.default }

     $ pulumi import gcp:compute/projectMetadata:ProjectMetadata When using the [`terraform import` command](https://developer.hashicorp.com/terraform/cli/commands/import), project metadata can be imported using one of the formats above. For example
    
     $ pulumi import gcp:compute/projectMetadata:ProjectMetadata default {{project_id}}
    

    Package Details

    Repository
    Google Cloud (GCP) Classic pulumi/pulumi-gcp
    License
    Apache-2.0
    Notes

    This Pulumi package is based on the google-beta Terraform Provider.

    gcp logo
    Google Cloud Classic v7.2.2 published on Monday, Jan 1, 0001 by Pulumi