1/*
2Copyright The Kubernetes Authors.
3
4Licensed under the Apache License, Version 2.0 (the "License");
5you may not use this file except in compliance with the License.
6You may obtain a copy of the License at
7
8    http://www.apache.org/licenses/LICENSE-2.0
9
10Unless required by applicable law or agreed to in writing, software
11distributed under the License is distributed on an "AS IS" BASIS,
12WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13See the License for the specific language governing permissions and
14limitations under the License.
15*/
16
17// Code generated by applyconfiguration-gen. DO NOT EDIT.
18
19package v1
20
21// CSIPersistentVolumeSourceApplyConfiguration represents an declarative configuration of the CSIPersistentVolumeSource type for use
22// with apply.
23type CSIPersistentVolumeSourceApplyConfiguration struct {
24	Driver                     *string                            `json:"driver,omitempty"`
25	VolumeHandle               *string                            `json:"volumeHandle,omitempty"`
26	ReadOnly                   *bool                              `json:"readOnly,omitempty"`
27	FSType                     *string                            `json:"fsType,omitempty"`
28	VolumeAttributes           map[string]string                  `json:"volumeAttributes,omitempty"`
29	ControllerPublishSecretRef *SecretReferenceApplyConfiguration `json:"controllerPublishSecretRef,omitempty"`
30	NodeStageSecretRef         *SecretReferenceApplyConfiguration `json:"nodeStageSecretRef,omitempty"`
31	NodePublishSecretRef       *SecretReferenceApplyConfiguration `json:"nodePublishSecretRef,omitempty"`
32	ControllerExpandSecretRef  *SecretReferenceApplyConfiguration `json:"controllerExpandSecretRef,omitempty"`
33}
34
35// CSIPersistentVolumeSourceApplyConfiguration constructs an declarative configuration of the CSIPersistentVolumeSource type for use with
36// apply.
37func CSIPersistentVolumeSource() *CSIPersistentVolumeSourceApplyConfiguration {
38	return &CSIPersistentVolumeSourceApplyConfiguration{}
39}
40
41// WithDriver sets the Driver field in the declarative configuration to the given value
42// and returns the receiver, so that objects can be built by chaining "With" function invocations.
43// If called multiple times, the Driver field is set to the value of the last call.
44func (b *CSIPersistentVolumeSourceApplyConfiguration) WithDriver(value string) *CSIPersistentVolumeSourceApplyConfiguration {
45	b.Driver = &value
46	return b
47}
48
49// WithVolumeHandle sets the VolumeHandle field in the declarative configuration to the given value
50// and returns the receiver, so that objects can be built by chaining "With" function invocations.
51// If called multiple times, the VolumeHandle field is set to the value of the last call.
52func (b *CSIPersistentVolumeSourceApplyConfiguration) WithVolumeHandle(value string) *CSIPersistentVolumeSourceApplyConfiguration {
53	b.VolumeHandle = &value
54	return b
55}
56
57// WithReadOnly sets the ReadOnly field in the declarative configuration to the given value
58// and returns the receiver, so that objects can be built by chaining "With" function invocations.
59// If called multiple times, the ReadOnly field is set to the value of the last call.
60func (b *CSIPersistentVolumeSourceApplyConfiguration) WithReadOnly(value bool) *CSIPersistentVolumeSourceApplyConfiguration {
61	b.ReadOnly = &value
62	return b
63}
64
65// WithFSType sets the FSType field in the declarative configuration to the given value
66// and returns the receiver, so that objects can be built by chaining "With" function invocations.
67// If called multiple times, the FSType field is set to the value of the last call.
68func (b *CSIPersistentVolumeSourceApplyConfiguration) WithFSType(value string) *CSIPersistentVolumeSourceApplyConfiguration {
69	b.FSType = &value
70	return b
71}
72
73// WithVolumeAttributes puts the entries into the VolumeAttributes field in the declarative configuration
74// and returns the receiver, so that objects can be build by chaining "With" function invocations.
75// If called multiple times, the entries provided by each call will be put on the VolumeAttributes field,
76// overwriting an existing map entries in VolumeAttributes field with the same key.
77func (b *CSIPersistentVolumeSourceApplyConfiguration) WithVolumeAttributes(entries map[string]string) *CSIPersistentVolumeSourceApplyConfiguration {
78	if b.VolumeAttributes == nil && len(entries) > 0 {
79		b.VolumeAttributes = make(map[string]string, len(entries))
80	}
81	for k, v := range entries {
82		b.VolumeAttributes[k] = v
83	}
84	return b
85}
86
87// WithControllerPublishSecretRef sets the ControllerPublishSecretRef field in the declarative configuration to the given value
88// and returns the receiver, so that objects can be built by chaining "With" function invocations.
89// If called multiple times, the ControllerPublishSecretRef field is set to the value of the last call.
90func (b *CSIPersistentVolumeSourceApplyConfiguration) WithControllerPublishSecretRef(value *SecretReferenceApplyConfiguration) *CSIPersistentVolumeSourceApplyConfiguration {
91	b.ControllerPublishSecretRef = value
92	return b
93}
94
95// WithNodeStageSecretRef sets the NodeStageSecretRef field in the declarative configuration to the given value
96// and returns the receiver, so that objects can be built by chaining "With" function invocations.
97// If called multiple times, the NodeStageSecretRef field is set to the value of the last call.
98func (b *CSIPersistentVolumeSourceApplyConfiguration) WithNodeStageSecretRef(value *SecretReferenceApplyConfiguration) *CSIPersistentVolumeSourceApplyConfiguration {
99	b.NodeStageSecretRef = value
100	return b
101}
102
103// WithNodePublishSecretRef sets the NodePublishSecretRef field in the declarative configuration to the given value
104// and returns the receiver, so that objects can be built by chaining "With" function invocations.
105// If called multiple times, the NodePublishSecretRef field is set to the value of the last call.
106func (b *CSIPersistentVolumeSourceApplyConfiguration) WithNodePublishSecretRef(value *SecretReferenceApplyConfiguration) *CSIPersistentVolumeSourceApplyConfiguration {
107	b.NodePublishSecretRef = value
108	return b
109}
110
111// WithControllerExpandSecretRef sets the ControllerExpandSecretRef field in the declarative configuration to the given value
112// and returns the receiver, so that objects can be built by chaining "With" function invocations.
113// If called multiple times, the ControllerExpandSecretRef field is set to the value of the last call.
114func (b *CSIPersistentVolumeSourceApplyConfiguration) WithControllerExpandSecretRef(value *SecretReferenceApplyConfiguration) *CSIPersistentVolumeSourceApplyConfiguration {
115	b.ControllerExpandSecretRef = value
116	return b
117}
118