1# -*- coding: utf-8 -*-
2# Copyright 2025 Google LLC
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15#
16from __future__ import annotations
17
18from typing import MutableMapping, MutableSequence
19
20from google.protobuf import timestamp_pb2 # type: ignore
21import proto # type: ignore
22
23__protobuf__ = proto.module(
24 package="google.cloud.secrets.v1beta1",
25 manifest={
26 "Secret",
27 "SecretVersion",
28 "Replication",
29 "SecretPayload",
30 },
31)
32
33
34class Secret(proto.Message):
35 r"""A [Secret][google.cloud.secrets.v1beta1.Secret] is a logical secret
36 whose value and versions can be accessed.
37
38 A [Secret][google.cloud.secrets.v1beta1.Secret] is made up of zero
39 or more [SecretVersions][google.cloud.secrets.v1beta1.SecretVersion]
40 that represent the secret data.
41
42 Attributes:
43 name (str):
44 Output only. The resource name of the
45 [Secret][google.cloud.secrets.v1beta1.Secret] in the format
46 ``projects/*/secrets/*``.
47 replication (google.cloud.secretmanager_v1beta1.types.Replication):
48 Required. Immutable. The replication policy of the secret
49 data attached to the
50 [Secret][google.cloud.secrets.v1beta1.Secret].
51
52 The replication policy cannot be changed after the Secret
53 has been created.
54 create_time (google.protobuf.timestamp_pb2.Timestamp):
55 Output only. The time at which the
56 [Secret][google.cloud.secrets.v1beta1.Secret] was created.
57 labels (MutableMapping[str, str]):
58 The labels assigned to this Secret.
59
60 Label keys must be between 1 and 63 characters long, have a
61 UTF-8 encoding of maximum 128 bytes, and must conform to the
62 following PCRE regular expression:
63 ``[\p{Ll}\p{Lo}][\p{Ll}\p{Lo}\p{N}_-]{0,62}``
64
65 Label values must be between 0 and 63 characters long, have
66 a UTF-8 encoding of maximum 128 bytes, and must conform to
67 the following PCRE regular expression:
68 ``[\p{Ll}\p{Lo}\p{N}_-]{0,63}``
69
70 No more than 64 labels can be assigned to a given resource.
71 """
72
73 name: str = proto.Field(
74 proto.STRING,
75 number=1,
76 )
77 replication: "Replication" = proto.Field(
78 proto.MESSAGE,
79 number=2,
80 message="Replication",
81 )
82 create_time: timestamp_pb2.Timestamp = proto.Field(
83 proto.MESSAGE,
84 number=3,
85 message=timestamp_pb2.Timestamp,
86 )
87 labels: MutableMapping[str, str] = proto.MapField(
88 proto.STRING,
89 proto.STRING,
90 number=4,
91 )
92
93
94class SecretVersion(proto.Message):
95 r"""A secret version resource in the Secret Manager API.
96
97 Attributes:
98 name (str):
99 Output only. The resource name of the
100 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion]
101 in the format ``projects/*/secrets/*/versions/*``.
102
103 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion]
104 IDs in a [Secret][google.cloud.secrets.v1beta1.Secret] start
105 at 1 and are incremented for each subsequent version of the
106 secret.
107 create_time (google.protobuf.timestamp_pb2.Timestamp):
108 Output only. The time at which the
109 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion]
110 was created.
111 destroy_time (google.protobuf.timestamp_pb2.Timestamp):
112 Output only. The time this
113 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion]
114 was destroyed. Only present if
115 [state][google.cloud.secrets.v1beta1.SecretVersion.state] is
116 [DESTROYED][google.cloud.secrets.v1beta1.SecretVersion.State.DESTROYED].
117 state (google.cloud.secretmanager_v1beta1.types.SecretVersion.State):
118 Output only. The current state of the
119 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion].
120 """
121
122 class State(proto.Enum):
123 r"""The state of a
124 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion],
125 indicating if it can be accessed.
126
127 Values:
128 STATE_UNSPECIFIED (0):
129 Not specified. This value is unused and
130 invalid.
131 ENABLED (1):
132 The
133 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion]
134 may be accessed.
135 DISABLED (2):
136 The
137 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion]
138 may not be accessed, but the secret data is still available
139 and can be placed back into the
140 [ENABLED][google.cloud.secrets.v1beta1.SecretVersion.State.ENABLED]
141 state.
142 DESTROYED (3):
143 The
144 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion]
145 is destroyed and the secret data is no longer stored. A
146 version may not leave this state once entered.
147 """
148 STATE_UNSPECIFIED = 0
149 ENABLED = 1
150 DISABLED = 2
151 DESTROYED = 3
152
153 name: str = proto.Field(
154 proto.STRING,
155 number=1,
156 )
157 create_time: timestamp_pb2.Timestamp = proto.Field(
158 proto.MESSAGE,
159 number=2,
160 message=timestamp_pb2.Timestamp,
161 )
162 destroy_time: timestamp_pb2.Timestamp = proto.Field(
163 proto.MESSAGE,
164 number=3,
165 message=timestamp_pb2.Timestamp,
166 )
167 state: State = proto.Field(
168 proto.ENUM,
169 number=4,
170 enum=State,
171 )
172
173
174class Replication(proto.Message):
175 r"""A policy that defines the replication configuration of data.
176
177 This message has `oneof`_ fields (mutually exclusive fields).
178 For each oneof, at most one member field can be set at the same time.
179 Setting any member of the oneof automatically clears all other
180 members.
181
182 .. _oneof: https://proto-plus-python.readthedocs.io/en/stable/fields.html#oneofs-mutually-exclusive-fields
183
184 Attributes:
185 automatic (google.cloud.secretmanager_v1beta1.types.Replication.Automatic):
186 The [Secret][google.cloud.secrets.v1beta1.Secret] will
187 automatically be replicated without any restrictions.
188
189 This field is a member of `oneof`_ ``replication``.
190 user_managed (google.cloud.secretmanager_v1beta1.types.Replication.UserManaged):
191 The [Secret][google.cloud.secrets.v1beta1.Secret] will only
192 be replicated into the locations specified.
193
194 This field is a member of `oneof`_ ``replication``.
195 """
196
197 class Automatic(proto.Message):
198 r"""A replication policy that replicates the
199 [Secret][google.cloud.secrets.v1beta1.Secret] payload without any
200 restrictions.
201
202 """
203
204 class UserManaged(proto.Message):
205 r"""A replication policy that replicates the
206 [Secret][google.cloud.secrets.v1beta1.Secret] payload into the
207 locations specified in
208 [Replication.UserManaged.replicas][google.cloud.secrets.v1beta1.Replication.UserManaged.replicas]
209
210 Attributes:
211 replicas (MutableSequence[google.cloud.secretmanager_v1beta1.types.Replication.UserManaged.Replica]):
212 Required. The list of Replicas for this
213 [Secret][google.cloud.secrets.v1beta1.Secret].
214
215 Cannot be empty.
216 """
217
218 class Replica(proto.Message):
219 r"""Represents a Replica for this
220 [Secret][google.cloud.secrets.v1beta1.Secret].
221
222 Attributes:
223 location (str):
224 The canonical IDs of the location to replicate data. For
225 example: ``"us-east1"``.
226 """
227
228 location: str = proto.Field(
229 proto.STRING,
230 number=1,
231 )
232
233 replicas: MutableSequence[
234 "Replication.UserManaged.Replica"
235 ] = proto.RepeatedField(
236 proto.MESSAGE,
237 number=1,
238 message="Replication.UserManaged.Replica",
239 )
240
241 automatic: Automatic = proto.Field(
242 proto.MESSAGE,
243 number=1,
244 oneof="replication",
245 message=Automatic,
246 )
247 user_managed: UserManaged = proto.Field(
248 proto.MESSAGE,
249 number=2,
250 oneof="replication",
251 message=UserManaged,
252 )
253
254
255class SecretPayload(proto.Message):
256 r"""A secret payload resource in the Secret Manager API. This contains
257 the sensitive secret data that is associated with a
258 [SecretVersion][google.cloud.secrets.v1beta1.SecretVersion].
259
260 Attributes:
261 data (bytes):
262 The secret data. Must be no larger than
263 64KiB.
264 """
265
266 data: bytes = proto.Field(
267 proto.BYTES,
268 number=1,
269 )
270
271
272__all__ = tuple(sorted(__protobuf__.manifest))