/
provider.go
152 lines (127 loc) · 5.27 KB
/
provider.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
// Code generated by the Pulumi Terraform Bridge (tfgen) Tool DO NOT EDIT.
// *** WARNING: Do not edit by hand unless you're certain you know what you are doing! ***
package docker
import (
"context"
"reflect"
"github.com/pulumi/pulumi-docker/sdk/v4/go/docker/internal"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
// The provider type for the docker package. By default, resources use package-wide configuration
// settings, however an explicit `Provider` instance may be created and passed during resource
// construction to achieve fine-grained programmatic control over provider settings. See the
// [documentation](https://www.pulumi.com/docs/reference/programming-model/#providers) for more information.
type Provider struct {
pulumi.ProviderResourceState
// PEM-encoded content of Docker host CA certificate
CaMaterial pulumi.StringPtrOutput `pulumi:"caMaterial"`
// PEM-encoded content of Docker client certificate
CertMaterial pulumi.StringPtrOutput `pulumi:"certMaterial"`
// Path to directory with Docker TLS config
CertPath pulumi.StringPtrOutput `pulumi:"certPath"`
// The Docker daemon address
Host pulumi.StringPtrOutput `pulumi:"host"`
// PEM-encoded content of Docker client private key
KeyMaterial pulumi.StringPtrOutput `pulumi:"keyMaterial"`
}
// NewProvider registers a new resource with the given unique name, arguments, and options.
func NewProvider(ctx *pulumi.Context,
name string, args *ProviderArgs, opts ...pulumi.ResourceOption) (*Provider, error) {
if args == nil {
args = &ProviderArgs{}
}
if args.Host == nil {
if d := internal.GetEnvOrDefault(nil, nil, "DOCKER_HOST"); d != nil {
args.Host = pulumi.StringPtr(d.(string))
}
}
opts = internal.PkgResourceDefaultOpts(opts)
var resource Provider
err := ctx.RegisterResource("pulumi:providers:docker", name, args, &resource, opts...)
if err != nil {
return nil, err
}
return &resource, nil
}
type providerArgs struct {
// PEM-encoded content of Docker host CA certificate
CaMaterial *string `pulumi:"caMaterial"`
// PEM-encoded content of Docker client certificate
CertMaterial *string `pulumi:"certMaterial"`
// Path to directory with Docker TLS config
CertPath *string `pulumi:"certPath"`
// The Docker daemon address
Host *string `pulumi:"host"`
// PEM-encoded content of Docker client private key
KeyMaterial *string `pulumi:"keyMaterial"`
RegistryAuth []ProviderRegistryAuth `pulumi:"registryAuth"`
// Additional SSH option flags to be appended when using `ssh://` protocol
SshOpts []string `pulumi:"sshOpts"`
}
// The set of arguments for constructing a Provider resource.
type ProviderArgs struct {
// PEM-encoded content of Docker host CA certificate
CaMaterial pulumi.StringPtrInput
// PEM-encoded content of Docker client certificate
CertMaterial pulumi.StringPtrInput
// Path to directory with Docker TLS config
CertPath pulumi.StringPtrInput
// The Docker daemon address
Host pulumi.StringPtrInput
// PEM-encoded content of Docker client private key
KeyMaterial pulumi.StringPtrInput
RegistryAuth ProviderRegistryAuthArrayInput
// Additional SSH option flags to be appended when using `ssh://` protocol
SshOpts pulumi.StringArrayInput
}
func (ProviderArgs) ElementType() reflect.Type {
return reflect.TypeOf((*providerArgs)(nil)).Elem()
}
type ProviderInput interface {
pulumi.Input
ToProviderOutput() ProviderOutput
ToProviderOutputWithContext(ctx context.Context) ProviderOutput
}
func (*Provider) ElementType() reflect.Type {
return reflect.TypeOf((**Provider)(nil)).Elem()
}
func (i *Provider) ToProviderOutput() ProviderOutput {
return i.ToProviderOutputWithContext(context.Background())
}
func (i *Provider) ToProviderOutputWithContext(ctx context.Context) ProviderOutput {
return pulumi.ToOutputWithContext(ctx, i).(ProviderOutput)
}
type ProviderOutput struct{ *pulumi.OutputState }
func (ProviderOutput) ElementType() reflect.Type {
return reflect.TypeOf((**Provider)(nil)).Elem()
}
func (o ProviderOutput) ToProviderOutput() ProviderOutput {
return o
}
func (o ProviderOutput) ToProviderOutputWithContext(ctx context.Context) ProviderOutput {
return o
}
// PEM-encoded content of Docker host CA certificate
func (o ProviderOutput) CaMaterial() pulumi.StringPtrOutput {
return o.ApplyT(func(v *Provider) pulumi.StringPtrOutput { return v.CaMaterial }).(pulumi.StringPtrOutput)
}
// PEM-encoded content of Docker client certificate
func (o ProviderOutput) CertMaterial() pulumi.StringPtrOutput {
return o.ApplyT(func(v *Provider) pulumi.StringPtrOutput { return v.CertMaterial }).(pulumi.StringPtrOutput)
}
// Path to directory with Docker TLS config
func (o ProviderOutput) CertPath() pulumi.StringPtrOutput {
return o.ApplyT(func(v *Provider) pulumi.StringPtrOutput { return v.CertPath }).(pulumi.StringPtrOutput)
}
// The Docker daemon address
func (o ProviderOutput) Host() pulumi.StringPtrOutput {
return o.ApplyT(func(v *Provider) pulumi.StringPtrOutput { return v.Host }).(pulumi.StringPtrOutput)
}
// PEM-encoded content of Docker client private key
func (o ProviderOutput) KeyMaterial() pulumi.StringPtrOutput {
return o.ApplyT(func(v *Provider) pulumi.StringPtrOutput { return v.KeyMaterial }).(pulumi.StringPtrOutput)
}
func init() {
pulumi.RegisterInputType(reflect.TypeOf((*ProviderInput)(nil)).Elem(), &Provider{})
pulumi.RegisterOutputType(ProviderOutput{})
}