gcp.compute.ProjectMetadata
Explore with Pulumi AI
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:
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.
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.