This repository has been archived by the owner on Mar 11, 2021. It is now read-only.
/
mongoDBResourceMongoDBCollection.go
204 lines (180 loc) · 10.3 KB
/
mongoDBResourceMongoDBCollection.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
// *** WARNING: this file was generated by the Pulumi SDK Generator. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package v20200901
import (
"context"
"reflect"
"github.com/pkg/errors"
"github.com/pulumi/pulumi/sdk/v2/go/pulumi"
)
// An Azure Cosmos DB MongoDB collection.
type MongoDBResourceMongoDBCollection struct {
pulumi.CustomResourceState
// The location of the resource group to which the resource belongs.
Location pulumi.StringPtrOutput `pulumi:"location"`
// The name of the ARM resource.
Name pulumi.StringOutput `pulumi:"name"`
Options MongoDBCollectionGetPropertiesResponseOptionsPtrOutput `pulumi:"options"`
Resource MongoDBCollectionGetPropertiesResponseResourcePtrOutput `pulumi:"resource"`
// Tags are a list of key-value pairs that describe the resource. These tags can be used in viewing and grouping this resource (across resource groups). A maximum of 15 tags can be provided for a resource. Each tag must have a key no greater than 128 characters and value no greater than 256 characters. For example, the default experience for a template type is set with "defaultExperience": "Cassandra". Current "defaultExperience" values also include "Table", "Graph", "DocumentDB", and "MongoDB".
Tags pulumi.StringMapOutput `pulumi:"tags"`
// The type of Azure resource.
Type pulumi.StringOutput `pulumi:"type"`
}
// NewMongoDBResourceMongoDBCollection registers a new resource with the given unique name, arguments, and options.
func NewMongoDBResourceMongoDBCollection(ctx *pulumi.Context,
name string, args *MongoDBResourceMongoDBCollectionArgs, opts ...pulumi.ResourceOption) (*MongoDBResourceMongoDBCollection, error) {
if args == nil {
return nil, errors.New("missing one or more required arguments")
}
if args.AccountName == nil {
return nil, errors.New("invalid value for required argument 'AccountName'")
}
if args.CollectionName == nil {
return nil, errors.New("invalid value for required argument 'CollectionName'")
}
if args.DatabaseName == nil {
return nil, errors.New("invalid value for required argument 'DatabaseName'")
}
if args.Resource == nil {
return nil, errors.New("invalid value for required argument 'Resource'")
}
if args.ResourceGroupName == nil {
return nil, errors.New("invalid value for required argument 'ResourceGroupName'")
}
aliases := pulumi.Aliases([]pulumi.Alias{
{
Type: pulumi.String("azure-nextgen:documentdb/latest:MongoDBResourceMongoDBCollection"),
},
{
Type: pulumi.String("azure-nextgen:documentdb/v20190801:MongoDBResourceMongoDBCollection"),
},
{
Type: pulumi.String("azure-nextgen:documentdb/v20191212:MongoDBResourceMongoDBCollection"),
},
{
Type: pulumi.String("azure-nextgen:documentdb/v20200301:MongoDBResourceMongoDBCollection"),
},
{
Type: pulumi.String("azure-nextgen:documentdb/v20200401:MongoDBResourceMongoDBCollection"),
},
{
Type: pulumi.String("azure-nextgen:documentdb/v20200601preview:MongoDBResourceMongoDBCollection"),
},
})
opts = append(opts, aliases)
var resource MongoDBResourceMongoDBCollection
err := ctx.RegisterResource("azure-nextgen:documentdb/v20200901:MongoDBResourceMongoDBCollection", name, args, &resource, opts...)
if err != nil {
return nil, err
}
return &resource, nil
}
// GetMongoDBResourceMongoDBCollection gets an existing MongoDBResourceMongoDBCollection resource's state with the given name, ID, and optional
// state properties that are used to uniquely qualify the lookup (nil if not required).
func GetMongoDBResourceMongoDBCollection(ctx *pulumi.Context,
name string, id pulumi.IDInput, state *MongoDBResourceMongoDBCollectionState, opts ...pulumi.ResourceOption) (*MongoDBResourceMongoDBCollection, error) {
var resource MongoDBResourceMongoDBCollection
err := ctx.ReadResource("azure-nextgen:documentdb/v20200901:MongoDBResourceMongoDBCollection", name, id, state, &resource, opts...)
if err != nil {
return nil, err
}
return &resource, nil
}
// Input properties used for looking up and filtering MongoDBResourceMongoDBCollection resources.
type mongoDBResourceMongoDBCollectionState struct {
// The location of the resource group to which the resource belongs.
Location *string `pulumi:"location"`
// The name of the ARM resource.
Name *string `pulumi:"name"`
Options *MongoDBCollectionGetPropertiesResponseOptions `pulumi:"options"`
Resource *MongoDBCollectionGetPropertiesResponseResource `pulumi:"resource"`
// Tags are a list of key-value pairs that describe the resource. These tags can be used in viewing and grouping this resource (across resource groups). A maximum of 15 tags can be provided for a resource. Each tag must have a key no greater than 128 characters and value no greater than 256 characters. For example, the default experience for a template type is set with "defaultExperience": "Cassandra". Current "defaultExperience" values also include "Table", "Graph", "DocumentDB", and "MongoDB".
Tags map[string]string `pulumi:"tags"`
// The type of Azure resource.
Type *string `pulumi:"type"`
}
type MongoDBResourceMongoDBCollectionState struct {
// The location of the resource group to which the resource belongs.
Location pulumi.StringPtrInput
// The name of the ARM resource.
Name pulumi.StringPtrInput
Options MongoDBCollectionGetPropertiesResponseOptionsPtrInput
Resource MongoDBCollectionGetPropertiesResponseResourcePtrInput
// Tags are a list of key-value pairs that describe the resource. These tags can be used in viewing and grouping this resource (across resource groups). A maximum of 15 tags can be provided for a resource. Each tag must have a key no greater than 128 characters and value no greater than 256 characters. For example, the default experience for a template type is set with "defaultExperience": "Cassandra". Current "defaultExperience" values also include "Table", "Graph", "DocumentDB", and "MongoDB".
Tags pulumi.StringMapInput
// The type of Azure resource.
Type pulumi.StringPtrInput
}
func (MongoDBResourceMongoDBCollectionState) ElementType() reflect.Type {
return reflect.TypeOf((*mongoDBResourceMongoDBCollectionState)(nil)).Elem()
}
type mongoDBResourceMongoDBCollectionArgs struct {
// Cosmos DB database account name.
AccountName string `pulumi:"accountName"`
// Cosmos DB collection name.
CollectionName string `pulumi:"collectionName"`
// Cosmos DB database name.
DatabaseName string `pulumi:"databaseName"`
// The location of the resource group to which the resource belongs.
Location *string `pulumi:"location"`
// A key-value pair of options to be applied for the request. This corresponds to the headers sent with the request.
Options *CreateUpdateOptions `pulumi:"options"`
// The standard JSON format of a MongoDB collection
Resource MongoDBCollectionResource `pulumi:"resource"`
// The name of the resource group. The name is case insensitive.
ResourceGroupName string `pulumi:"resourceGroupName"`
// Tags are a list of key-value pairs that describe the resource. These tags can be used in viewing and grouping this resource (across resource groups). A maximum of 15 tags can be provided for a resource. Each tag must have a key no greater than 128 characters and value no greater than 256 characters. For example, the default experience for a template type is set with "defaultExperience": "Cassandra". Current "defaultExperience" values also include "Table", "Graph", "DocumentDB", and "MongoDB".
Tags map[string]string `pulumi:"tags"`
}
// The set of arguments for constructing a MongoDBResourceMongoDBCollection resource.
type MongoDBResourceMongoDBCollectionArgs struct {
// Cosmos DB database account name.
AccountName pulumi.StringInput
// Cosmos DB collection name.
CollectionName pulumi.StringInput
// Cosmos DB database name.
DatabaseName pulumi.StringInput
// The location of the resource group to which the resource belongs.
Location pulumi.StringPtrInput
// A key-value pair of options to be applied for the request. This corresponds to the headers sent with the request.
Options CreateUpdateOptionsPtrInput
// The standard JSON format of a MongoDB collection
Resource MongoDBCollectionResourceInput
// The name of the resource group. The name is case insensitive.
ResourceGroupName pulumi.StringInput
// Tags are a list of key-value pairs that describe the resource. These tags can be used in viewing and grouping this resource (across resource groups). A maximum of 15 tags can be provided for a resource. Each tag must have a key no greater than 128 characters and value no greater than 256 characters. For example, the default experience for a template type is set with "defaultExperience": "Cassandra". Current "defaultExperience" values also include "Table", "Graph", "DocumentDB", and "MongoDB".
Tags pulumi.StringMapInput
}
func (MongoDBResourceMongoDBCollectionArgs) ElementType() reflect.Type {
return reflect.TypeOf((*mongoDBResourceMongoDBCollectionArgs)(nil)).Elem()
}
type MongoDBResourceMongoDBCollectionInput interface {
pulumi.Input
ToMongoDBResourceMongoDBCollectionOutput() MongoDBResourceMongoDBCollectionOutput
ToMongoDBResourceMongoDBCollectionOutputWithContext(ctx context.Context) MongoDBResourceMongoDBCollectionOutput
}
func (*MongoDBResourceMongoDBCollection) ElementType() reflect.Type {
return reflect.TypeOf((*MongoDBResourceMongoDBCollection)(nil))
}
func (i *MongoDBResourceMongoDBCollection) ToMongoDBResourceMongoDBCollectionOutput() MongoDBResourceMongoDBCollectionOutput {
return i.ToMongoDBResourceMongoDBCollectionOutputWithContext(context.Background())
}
func (i *MongoDBResourceMongoDBCollection) ToMongoDBResourceMongoDBCollectionOutputWithContext(ctx context.Context) MongoDBResourceMongoDBCollectionOutput {
return pulumi.ToOutputWithContext(ctx, i).(MongoDBResourceMongoDBCollectionOutput)
}
type MongoDBResourceMongoDBCollectionOutput struct {
*pulumi.OutputState
}
func (MongoDBResourceMongoDBCollectionOutput) ElementType() reflect.Type {
return reflect.TypeOf((*MongoDBResourceMongoDBCollection)(nil))
}
func (o MongoDBResourceMongoDBCollectionOutput) ToMongoDBResourceMongoDBCollectionOutput() MongoDBResourceMongoDBCollectionOutput {
return o
}
func (o MongoDBResourceMongoDBCollectionOutput) ToMongoDBResourceMongoDBCollectionOutputWithContext(ctx context.Context) MongoDBResourceMongoDBCollectionOutput {
return o
}
func init() {
pulumi.RegisterOutputType(MongoDBResourceMongoDBCollectionOutput{})
}