This repository has been archived by the owner on Oct 6, 2023. It is now read-only.
generated from pulumi/pulumi-tf-provider-boilerplate
/
getComputeInstance.go
251 lines (217 loc) · 11.6 KB
/
getComputeInstance.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
// *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package yandex
import (
"context"
"reflect"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
// Get information about a Yandex Compute instance. For more information, see
// [the official documentation](https://cloud.yandex.com/docs/compute/concepts/vm).
//
// ## Example Usage
//
// ```go
// package main
//
// import (
// "github.com/pulumi/pulumi-yandex/sdk/go/yandex"
// "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
// )
//
// func main() {
// pulumi.Run(func(ctx *pulumi.Context) error {
// opt0 := "some_instance_id"
// myInstance, err := yandex.LookupComputeInstance(ctx, &GetComputeInstanceArgs{
// InstanceId: &opt0,
// }, nil)
// if err != nil {
// return err
// }
// ctx.Export("instanceExternalIp", myInstance.NetworkInterfaces[0].NatIpAddress)
// return nil
// })
// }
// ```
func LookupComputeInstance(ctx *pulumi.Context, args *LookupComputeInstanceArgs, opts ...pulumi.InvokeOption) (*LookupComputeInstanceResult, error) {
var rv LookupComputeInstanceResult
err := ctx.Invoke("yandex:index/getComputeInstance:getComputeInstance", args, &rv, opts...)
if err != nil {
return nil, err
}
return &rv, nil
}
// A collection of arguments for invoking getComputeInstance.
type LookupComputeInstanceArgs struct {
// Folder that the resource belongs to. If value is omitted, the default provider folder is used.
FolderId *string `pulumi:"folderId"`
// The ID of a specific instance.
InstanceId *string `pulumi:"instanceId"`
// Name of the instance.
Name *string `pulumi:"name"`
PlacementPolicy *GetComputeInstancePlacementPolicy `pulumi:"placementPolicy"`
}
// A collection of values returned by getComputeInstance.
type LookupComputeInstanceResult struct {
// The boot disk for the instance. Structure is documented below.
BootDisks []GetComputeInstanceBootDisk `pulumi:"bootDisks"`
// Instance creation timestamp.
CreatedAt string `pulumi:"createdAt"`
// Description of the boot disk.
Description string `pulumi:"description"`
FolderId string `pulumi:"folderId"`
// DNS record FQDN.
Fqdn string `pulumi:"fqdn"`
// The provider-assigned unique ID for this managed resource.
Id string `pulumi:"id"`
InstanceId string `pulumi:"instanceId"`
// A set of key/value label pairs assigned to the instance.
Labels map[string]string `pulumi:"labels"`
// Metadata key/value pairs to make available from
// within the instance.
Metadata map[string]string `pulumi:"metadata"`
// Name of the boot disk.
Name string `pulumi:"name"`
// Type of network acceleration. The default is `standard`. Values: `standard`, `softwareAccelerated`
NetworkAccelerationType string `pulumi:"networkAccelerationType"`
// The networks attached to the instance. Structure is documented below.
// * `network_interface.0.ip_address` - An internal IP address of the instance, either manually or dynamically assigned.
// * `network_interface.0.nat_ip_address` - An assigned external IP address if the instance has NAT enabled.
NetworkInterfaces []GetComputeInstanceNetworkInterface `pulumi:"networkInterfaces"`
PlacementPolicy *GetComputeInstancePlacementPolicy `pulumi:"placementPolicy"`
// Type of virtual machine to create. Default is 'standard-v1'.
PlatformId string `pulumi:"platformId"`
Resources []GetComputeInstanceResource `pulumi:"resources"`
// Scheduling policy configuration. The structure is documented below.
SchedulingPolicies []GetComputeInstanceSchedulingPolicy `pulumi:"schedulingPolicies"`
// List of secondary disks attached to the instance. Structure is documented below.
SecondaryDisks []GetComputeInstanceSecondaryDisk `pulumi:"secondaryDisks"`
// ID of the service account authorized for this instance.
ServiceAccountId string `pulumi:"serviceAccountId"`
// Status of the instance.
// * `resources.0.memory` - Memory size allocated for the instance.
// * `resources.0.cores` - Number of CPU cores allocated for the instance.
// * `resources.0.core_fraction` - Baseline performance for a core, set as a percent.
// * `resources.0.gpus` - Number of GPU cores allocated for the instance.
Status string `pulumi:"status"`
// Availability zone where the instance resides.
Zone string `pulumi:"zone"`
}
func LookupComputeInstanceOutput(ctx *pulumi.Context, args LookupComputeInstanceOutputArgs, opts ...pulumi.InvokeOption) LookupComputeInstanceResultOutput {
return pulumi.ToOutputWithContext(context.Background(), args).
ApplyT(func(v interface{}) (LookupComputeInstanceResult, error) {
args := v.(LookupComputeInstanceArgs)
r, err := LookupComputeInstance(ctx, &args, opts...)
return *r, err
}).(LookupComputeInstanceResultOutput)
}
// A collection of arguments for invoking getComputeInstance.
type LookupComputeInstanceOutputArgs struct {
// Folder that the resource belongs to. If value is omitted, the default provider folder is used.
FolderId pulumi.StringPtrInput `pulumi:"folderId"`
// The ID of a specific instance.
InstanceId pulumi.StringPtrInput `pulumi:"instanceId"`
// Name of the instance.
Name pulumi.StringPtrInput `pulumi:"name"`
PlacementPolicy GetComputeInstancePlacementPolicyPtrInput `pulumi:"placementPolicy"`
}
func (LookupComputeInstanceOutputArgs) ElementType() reflect.Type {
return reflect.TypeOf((*LookupComputeInstanceArgs)(nil)).Elem()
}
// A collection of values returned by getComputeInstance.
type LookupComputeInstanceResultOutput struct{ *pulumi.OutputState }
func (LookupComputeInstanceResultOutput) ElementType() reflect.Type {
return reflect.TypeOf((*LookupComputeInstanceResult)(nil)).Elem()
}
func (o LookupComputeInstanceResultOutput) ToLookupComputeInstanceResultOutput() LookupComputeInstanceResultOutput {
return o
}
func (o LookupComputeInstanceResultOutput) ToLookupComputeInstanceResultOutputWithContext(ctx context.Context) LookupComputeInstanceResultOutput {
return o
}
// The boot disk for the instance. Structure is documented below.
func (o LookupComputeInstanceResultOutput) BootDisks() GetComputeInstanceBootDiskArrayOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) []GetComputeInstanceBootDisk { return v.BootDisks }).(GetComputeInstanceBootDiskArrayOutput)
}
// Instance creation timestamp.
func (o LookupComputeInstanceResultOutput) CreatedAt() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.CreatedAt }).(pulumi.StringOutput)
}
// Description of the boot disk.
func (o LookupComputeInstanceResultOutput) Description() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.Description }).(pulumi.StringOutput)
}
func (o LookupComputeInstanceResultOutput) FolderId() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.FolderId }).(pulumi.StringOutput)
}
// DNS record FQDN.
func (o LookupComputeInstanceResultOutput) Fqdn() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.Fqdn }).(pulumi.StringOutput)
}
// The provider-assigned unique ID for this managed resource.
func (o LookupComputeInstanceResultOutput) Id() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.Id }).(pulumi.StringOutput)
}
func (o LookupComputeInstanceResultOutput) InstanceId() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.InstanceId }).(pulumi.StringOutput)
}
// A set of key/value label pairs assigned to the instance.
func (o LookupComputeInstanceResultOutput) Labels() pulumi.StringMapOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) map[string]string { return v.Labels }).(pulumi.StringMapOutput)
}
// Metadata key/value pairs to make available from
// within the instance.
func (o LookupComputeInstanceResultOutput) Metadata() pulumi.StringMapOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) map[string]string { return v.Metadata }).(pulumi.StringMapOutput)
}
// Name of the boot disk.
func (o LookupComputeInstanceResultOutput) Name() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.Name }).(pulumi.StringOutput)
}
// Type of network acceleration. The default is `standard`. Values: `standard`, `softwareAccelerated`
func (o LookupComputeInstanceResultOutput) NetworkAccelerationType() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.NetworkAccelerationType }).(pulumi.StringOutput)
}
// The networks attached to the instance. Structure is documented below.
// * `network_interface.0.ip_address` - An internal IP address of the instance, either manually or dynamically assigned.
// * `network_interface.0.nat_ip_address` - An assigned external IP address if the instance has NAT enabled.
func (o LookupComputeInstanceResultOutput) NetworkInterfaces() GetComputeInstanceNetworkInterfaceArrayOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) []GetComputeInstanceNetworkInterface { return v.NetworkInterfaces }).(GetComputeInstanceNetworkInterfaceArrayOutput)
}
func (o LookupComputeInstanceResultOutput) PlacementPolicy() GetComputeInstancePlacementPolicyPtrOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) *GetComputeInstancePlacementPolicy { return v.PlacementPolicy }).(GetComputeInstancePlacementPolicyPtrOutput)
}
// Type of virtual machine to create. Default is 'standard-v1'.
func (o LookupComputeInstanceResultOutput) PlatformId() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.PlatformId }).(pulumi.StringOutput)
}
func (o LookupComputeInstanceResultOutput) Resources() GetComputeInstanceResourceArrayOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) []GetComputeInstanceResource { return v.Resources }).(GetComputeInstanceResourceArrayOutput)
}
// Scheduling policy configuration. The structure is documented below.
func (o LookupComputeInstanceResultOutput) SchedulingPolicies() GetComputeInstanceSchedulingPolicyArrayOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) []GetComputeInstanceSchedulingPolicy { return v.SchedulingPolicies }).(GetComputeInstanceSchedulingPolicyArrayOutput)
}
// List of secondary disks attached to the instance. Structure is documented below.
func (o LookupComputeInstanceResultOutput) SecondaryDisks() GetComputeInstanceSecondaryDiskArrayOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) []GetComputeInstanceSecondaryDisk { return v.SecondaryDisks }).(GetComputeInstanceSecondaryDiskArrayOutput)
}
// ID of the service account authorized for this instance.
func (o LookupComputeInstanceResultOutput) ServiceAccountId() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.ServiceAccountId }).(pulumi.StringOutput)
}
// Status of the instance.
// * `resources.0.memory` - Memory size allocated for the instance.
// * `resources.0.cores` - Number of CPU cores allocated for the instance.
// * `resources.0.core_fraction` - Baseline performance for a core, set as a percent.
// * `resources.0.gpus` - Number of GPU cores allocated for the instance.
func (o LookupComputeInstanceResultOutput) Status() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.Status }).(pulumi.StringOutput)
}
// Availability zone where the instance resides.
func (o LookupComputeInstanceResultOutput) Zone() pulumi.StringOutput {
return o.ApplyT(func(v LookupComputeInstanceResult) string { return v.Zone }).(pulumi.StringOutput)
}
func init() {
pulumi.RegisterOutputType(LookupComputeInstanceResultOutput{})
}