xref: /aosp_15_r20/external/googleapis/google/cloud/netapp/v1/backup.proto (revision d5c09012810ac0c9f33fe448fb6da8260d444cc9)
1*d5c09012SAndroid Build Coastguard Worker// Copyright 2023 Google LLC
2*d5c09012SAndroid Build Coastguard Worker//
3*d5c09012SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*d5c09012SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*d5c09012SAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*d5c09012SAndroid Build Coastguard Worker//
7*d5c09012SAndroid Build Coastguard Worker//     http://www.apache.org/licenses/LICENSE-2.0
8*d5c09012SAndroid Build Coastguard Worker//
9*d5c09012SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*d5c09012SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*d5c09012SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*d5c09012SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*d5c09012SAndroid Build Coastguard Worker// limitations under the License.
14*d5c09012SAndroid Build Coastguard Worker
15*d5c09012SAndroid Build Coastguard Workersyntax = "proto3";
16*d5c09012SAndroid Build Coastguard Worker
17*d5c09012SAndroid Build Coastguard Workerpackage google.cloud.netapp.v1;
18*d5c09012SAndroid Build Coastguard Worker
19*d5c09012SAndroid Build Coastguard Workerimport "google/api/field_behavior.proto";
20*d5c09012SAndroid Build Coastguard Workerimport "google/api/resource.proto";
21*d5c09012SAndroid Build Coastguard Workerimport "google/protobuf/field_mask.proto";
22*d5c09012SAndroid Build Coastguard Workerimport "google/protobuf/timestamp.proto";
23*d5c09012SAndroid Build Coastguard Worker
24*d5c09012SAndroid Build Coastguard Workeroption csharp_namespace = "Google.Cloud.NetApp.V1";
25*d5c09012SAndroid Build Coastguard Workeroption go_package = "cloud.google.com/go/netapp/apiv1/netapppb;netapppb";
26*d5c09012SAndroid Build Coastguard Workeroption java_multiple_files = true;
27*d5c09012SAndroid Build Coastguard Workeroption java_outer_classname = "BackupProto";
28*d5c09012SAndroid Build Coastguard Workeroption java_package = "com.google.cloud.netapp.v1";
29*d5c09012SAndroid Build Coastguard Workeroption php_namespace = "Google\\Cloud\\NetApp\\V1";
30*d5c09012SAndroid Build Coastguard Workeroption ruby_package = "Google::Cloud::NetApp::V1";
31*d5c09012SAndroid Build Coastguard Worker
32*d5c09012SAndroid Build Coastguard Worker// A NetApp Backup.
33*d5c09012SAndroid Build Coastguard Workermessage Backup {
34*d5c09012SAndroid Build Coastguard Worker  option (google.api.resource) = {
35*d5c09012SAndroid Build Coastguard Worker    type: "netapp.googleapis.com/Backup"
36*d5c09012SAndroid Build Coastguard Worker    pattern: "projects/{project}/locations/{location}/backupVaults/{backup_vault}/backups/{backup}"
37*d5c09012SAndroid Build Coastguard Worker    plural: "backups"
38*d5c09012SAndroid Build Coastguard Worker    singular: "backup"
39*d5c09012SAndroid Build Coastguard Worker  };
40*d5c09012SAndroid Build Coastguard Worker
41*d5c09012SAndroid Build Coastguard Worker  // The Backup States
42*d5c09012SAndroid Build Coastguard Worker  enum State {
43*d5c09012SAndroid Build Coastguard Worker    // State not set.
44*d5c09012SAndroid Build Coastguard Worker    STATE_UNSPECIFIED = 0;
45*d5c09012SAndroid Build Coastguard Worker
46*d5c09012SAndroid Build Coastguard Worker    // Backup is being created. While in this state, the snapshot for the backup
47*d5c09012SAndroid Build Coastguard Worker    // point-in-time may not have been created yet, and so the point-in-time may
48*d5c09012SAndroid Build Coastguard Worker    // not have been fixed.
49*d5c09012SAndroid Build Coastguard Worker    CREATING = 1;
50*d5c09012SAndroid Build Coastguard Worker
51*d5c09012SAndroid Build Coastguard Worker    // Backup is being uploaded. While in this state, none of the writes to the
52*d5c09012SAndroid Build Coastguard Worker    // volume will be included in the backup.
53*d5c09012SAndroid Build Coastguard Worker    UPLOADING = 2;
54*d5c09012SAndroid Build Coastguard Worker
55*d5c09012SAndroid Build Coastguard Worker    // Backup is available for use.
56*d5c09012SAndroid Build Coastguard Worker    READY = 3;
57*d5c09012SAndroid Build Coastguard Worker
58*d5c09012SAndroid Build Coastguard Worker    // Backup is being deleted.
59*d5c09012SAndroid Build Coastguard Worker    DELETING = 4;
60*d5c09012SAndroid Build Coastguard Worker
61*d5c09012SAndroid Build Coastguard Worker    // Backup is not valid and cannot be used for creating new volumes or
62*d5c09012SAndroid Build Coastguard Worker    // restoring existing volumes.
63*d5c09012SAndroid Build Coastguard Worker    ERROR = 5;
64*d5c09012SAndroid Build Coastguard Worker
65*d5c09012SAndroid Build Coastguard Worker    // Backup is being updated.
66*d5c09012SAndroid Build Coastguard Worker    UPDATING = 6;
67*d5c09012SAndroid Build Coastguard Worker  }
68*d5c09012SAndroid Build Coastguard Worker
69*d5c09012SAndroid Build Coastguard Worker  // Backup types.
70*d5c09012SAndroid Build Coastguard Worker  enum Type {
71*d5c09012SAndroid Build Coastguard Worker    // Unspecified backup type.
72*d5c09012SAndroid Build Coastguard Worker    TYPE_UNSPECIFIED = 0;
73*d5c09012SAndroid Build Coastguard Worker
74*d5c09012SAndroid Build Coastguard Worker    // Manual backup type.
75*d5c09012SAndroid Build Coastguard Worker    MANUAL = 1;
76*d5c09012SAndroid Build Coastguard Worker
77*d5c09012SAndroid Build Coastguard Worker    // Scheduled backup type.
78*d5c09012SAndroid Build Coastguard Worker    SCHEDULED = 2;
79*d5c09012SAndroid Build Coastguard Worker  }
80*d5c09012SAndroid Build Coastguard Worker
81*d5c09012SAndroid Build Coastguard Worker  // Identifier. The resource name of the backup.
82*d5c09012SAndroid Build Coastguard Worker  // Format:
83*d5c09012SAndroid Build Coastguard Worker  // `projects/{project_id}/locations/{location}/backupVaults/{backup_vault_id}/backups/{backup_id}`.
84*d5c09012SAndroid Build Coastguard Worker  string name = 1 [(google.api.field_behavior) = IDENTIFIER];
85*d5c09012SAndroid Build Coastguard Worker
86*d5c09012SAndroid Build Coastguard Worker  // Output only. The backup state.
87*d5c09012SAndroid Build Coastguard Worker  State state = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
88*d5c09012SAndroid Build Coastguard Worker
89*d5c09012SAndroid Build Coastguard Worker  // A description of the backup with 2048 characters or less.
90*d5c09012SAndroid Build Coastguard Worker  // Requests with longer descriptions will be rejected.
91*d5c09012SAndroid Build Coastguard Worker  string description = 3;
92*d5c09012SAndroid Build Coastguard Worker
93*d5c09012SAndroid Build Coastguard Worker  // Output only. Size of the file system when the backup was created. When
94*d5c09012SAndroid Build Coastguard Worker  // creating a new volume from the backup, the volume capacity will have to be
95*d5c09012SAndroid Build Coastguard Worker  // at least as big.
96*d5c09012SAndroid Build Coastguard Worker  int64 volume_usage_bytes = 4 [(google.api.field_behavior) = OUTPUT_ONLY];
97*d5c09012SAndroid Build Coastguard Worker
98*d5c09012SAndroid Build Coastguard Worker  // Output only. Type of backup, manually created or created by a backup
99*d5c09012SAndroid Build Coastguard Worker  // policy.
100*d5c09012SAndroid Build Coastguard Worker  Type backup_type = 5 [(google.api.field_behavior) = OUTPUT_ONLY];
101*d5c09012SAndroid Build Coastguard Worker
102*d5c09012SAndroid Build Coastguard Worker  // Volume full name of this backup belongs to.
103*d5c09012SAndroid Build Coastguard Worker  // Format:
104*d5c09012SAndroid Build Coastguard Worker  // `projects/{projects_id}/locations/{location}/volumes/{volume_id}`
105*d5c09012SAndroid Build Coastguard Worker  string source_volume = 6 [
106*d5c09012SAndroid Build Coastguard Worker    (google.api.resource_reference) = { type: "netapp.googleapis.com/Volume" }
107*d5c09012SAndroid Build Coastguard Worker  ];
108*d5c09012SAndroid Build Coastguard Worker
109*d5c09012SAndroid Build Coastguard Worker  // If specified, backup will be created from the given snapshot.
110*d5c09012SAndroid Build Coastguard Worker  // If not specified, there will be a new snapshot taken to initiate the backup
111*d5c09012SAndroid Build Coastguard Worker  // creation. Format:
112*d5c09012SAndroid Build Coastguard Worker  // `projects/{project_id}/locations/{location}/volumes/{volume_id}/snapshots/{snapshot_id}`
113*d5c09012SAndroid Build Coastguard Worker  optional string source_snapshot = 7 [
114*d5c09012SAndroid Build Coastguard Worker    (google.api.resource_reference) = { type: "netapp.googleapis.com/Snapshot" }
115*d5c09012SAndroid Build Coastguard Worker  ];
116*d5c09012SAndroid Build Coastguard Worker
117*d5c09012SAndroid Build Coastguard Worker  // Output only. The time when the backup was created.
118*d5c09012SAndroid Build Coastguard Worker  google.protobuf.Timestamp create_time = 8
119*d5c09012SAndroid Build Coastguard Worker      [(google.api.field_behavior) = OUTPUT_ONLY];
120*d5c09012SAndroid Build Coastguard Worker
121*d5c09012SAndroid Build Coastguard Worker  // Resource labels to represent user provided metadata.
122*d5c09012SAndroid Build Coastguard Worker  map<string, string> labels = 9;
123*d5c09012SAndroid Build Coastguard Worker
124*d5c09012SAndroid Build Coastguard Worker  // Output only. Total size of all backups in a chain in bytes = baseline
125*d5c09012SAndroid Build Coastguard Worker  // backup size + sum(incremental backup size)
126*d5c09012SAndroid Build Coastguard Worker  int64 chain_storage_bytes = 10 [(google.api.field_behavior) = OUTPUT_ONLY];
127*d5c09012SAndroid Build Coastguard Worker}
128*d5c09012SAndroid Build Coastguard Worker
129*d5c09012SAndroid Build Coastguard Worker// ListBackupsRequest lists backups.
130*d5c09012SAndroid Build Coastguard Workermessage ListBackupsRequest {
131*d5c09012SAndroid Build Coastguard Worker  // Required. The backupVault for which to retrieve backup information,
132*d5c09012SAndroid Build Coastguard Worker  // in the format
133*d5c09012SAndroid Build Coastguard Worker  // `projects/{project_id}/locations/{location}/backupVaults/{backup_vault_id}`.
134*d5c09012SAndroid Build Coastguard Worker  // To retrieve backup information for all locations, use "-" for the
135*d5c09012SAndroid Build Coastguard Worker  // `{location}` value.
136*d5c09012SAndroid Build Coastguard Worker  // To retrieve backup information for all backupVaults, use "-" for the
137*d5c09012SAndroid Build Coastguard Worker  // `{backup_vault_id}` value.
138*d5c09012SAndroid Build Coastguard Worker  // To retrieve backup information for a volume, use "-" for the
139*d5c09012SAndroid Build Coastguard Worker  // `{backup_vault_id}` value and specify volume full name with the filter.
140*d5c09012SAndroid Build Coastguard Worker  string parent = 1 [
141*d5c09012SAndroid Build Coastguard Worker    (google.api.field_behavior) = REQUIRED,
142*d5c09012SAndroid Build Coastguard Worker    (google.api.resource_reference) = {
143*d5c09012SAndroid Build Coastguard Worker      child_type: "netapp.googleapis.com/Backup"
144*d5c09012SAndroid Build Coastguard Worker    }
145*d5c09012SAndroid Build Coastguard Worker  ];
146*d5c09012SAndroid Build Coastguard Worker
147*d5c09012SAndroid Build Coastguard Worker  // The maximum number of items to return. The service may return fewer
148*d5c09012SAndroid Build Coastguard Worker  // than this value. The maximum value
149*d5c09012SAndroid Build Coastguard Worker  // is 1000; values above 1000 will be coerced to 1000.
150*d5c09012SAndroid Build Coastguard Worker  int32 page_size = 2;
151*d5c09012SAndroid Build Coastguard Worker
152*d5c09012SAndroid Build Coastguard Worker  // The next_page_token value to use if there are additional
153*d5c09012SAndroid Build Coastguard Worker  // results to retrieve for this list request.
154*d5c09012SAndroid Build Coastguard Worker  string page_token = 3;
155*d5c09012SAndroid Build Coastguard Worker
156*d5c09012SAndroid Build Coastguard Worker  // Sort results. Supported values are "name", "name desc" or "" (unsorted).
157*d5c09012SAndroid Build Coastguard Worker  string order_by = 4;
158*d5c09012SAndroid Build Coastguard Worker
159*d5c09012SAndroid Build Coastguard Worker  // The standard list filter.
160*d5c09012SAndroid Build Coastguard Worker  // If specified, backups will be returned based on the attribute name that
161*d5c09012SAndroid Build Coastguard Worker  // matches the filter expression. If empty, then no backups are filtered out.
162*d5c09012SAndroid Build Coastguard Worker  // See https://google.aip.dev/160
163*d5c09012SAndroid Build Coastguard Worker  string filter = 5;
164*d5c09012SAndroid Build Coastguard Worker}
165*d5c09012SAndroid Build Coastguard Worker
166*d5c09012SAndroid Build Coastguard Worker// ListBackupsResponse is the result of ListBackupsRequest.
167*d5c09012SAndroid Build Coastguard Workermessage ListBackupsResponse {
168*d5c09012SAndroid Build Coastguard Worker  // A list of backups in the project.
169*d5c09012SAndroid Build Coastguard Worker  repeated Backup backups = 1;
170*d5c09012SAndroid Build Coastguard Worker
171*d5c09012SAndroid Build Coastguard Worker  // The token you can use to retrieve the next page of results. Not returned
172*d5c09012SAndroid Build Coastguard Worker  // if there are no more results in the list.
173*d5c09012SAndroid Build Coastguard Worker  string next_page_token = 2;
174*d5c09012SAndroid Build Coastguard Worker
175*d5c09012SAndroid Build Coastguard Worker  // Locations that could not be reached.
176*d5c09012SAndroid Build Coastguard Worker  repeated string unreachable = 3;
177*d5c09012SAndroid Build Coastguard Worker}
178*d5c09012SAndroid Build Coastguard Worker
179*d5c09012SAndroid Build Coastguard Worker// GetBackupRequest gets the state of a backup.
180*d5c09012SAndroid Build Coastguard Workermessage GetBackupRequest {
181*d5c09012SAndroid Build Coastguard Worker  // Required. The backup resource name, in the format
182*d5c09012SAndroid Build Coastguard Worker  // `projects/{project_id}/locations/{location}/backupVaults/{backup_vault_id}/backups/{backup_id}`
183*d5c09012SAndroid Build Coastguard Worker  string name = 1 [
184*d5c09012SAndroid Build Coastguard Worker    (google.api.field_behavior) = REQUIRED,
185*d5c09012SAndroid Build Coastguard Worker    (google.api.resource_reference) = { type: "netapp.googleapis.com/Backup" }
186*d5c09012SAndroid Build Coastguard Worker  ];
187*d5c09012SAndroid Build Coastguard Worker}
188*d5c09012SAndroid Build Coastguard Worker
189*d5c09012SAndroid Build Coastguard Worker// CreateBackupRequest creates a backup.
190*d5c09012SAndroid Build Coastguard Workermessage CreateBackupRequest {
191*d5c09012SAndroid Build Coastguard Worker  // Required. The NetApp backupVault to create the backups of, in the format
192*d5c09012SAndroid Build Coastguard Worker  // `projects/*/locations/*/backupVaults/{backup_vault_id}`
193*d5c09012SAndroid Build Coastguard Worker  string parent = 1 [
194*d5c09012SAndroid Build Coastguard Worker    (google.api.field_behavior) = REQUIRED,
195*d5c09012SAndroid Build Coastguard Worker    (google.api.resource_reference) = {
196*d5c09012SAndroid Build Coastguard Worker      child_type: "netapp.googleapis.com/Backup"
197*d5c09012SAndroid Build Coastguard Worker    }
198*d5c09012SAndroid Build Coastguard Worker  ];
199*d5c09012SAndroid Build Coastguard Worker
200*d5c09012SAndroid Build Coastguard Worker  // Required. The ID to use for the backup.
201*d5c09012SAndroid Build Coastguard Worker  // The ID must be unique within the specified backupVault.
202*d5c09012SAndroid Build Coastguard Worker  // This value must start with a lowercase letter followed by up to 62
203*d5c09012SAndroid Build Coastguard Worker  // lowercase letters, numbers, or hyphens, and cannot end with a hyphen.
204*d5c09012SAndroid Build Coastguard Worker  // Values that do not match this pattern will trigger an INVALID_ARGUMENT
205*d5c09012SAndroid Build Coastguard Worker  // error.
206*d5c09012SAndroid Build Coastguard Worker  string backup_id = 2 [(google.api.field_behavior) = REQUIRED];
207*d5c09012SAndroid Build Coastguard Worker
208*d5c09012SAndroid Build Coastguard Worker  // Required. A backup resource
209*d5c09012SAndroid Build Coastguard Worker  Backup backup = 3 [(google.api.field_behavior) = REQUIRED];
210*d5c09012SAndroid Build Coastguard Worker}
211*d5c09012SAndroid Build Coastguard Worker
212*d5c09012SAndroid Build Coastguard Worker// DeleteBackupRequest deletes a backup.
213*d5c09012SAndroid Build Coastguard Workermessage DeleteBackupRequest {
214*d5c09012SAndroid Build Coastguard Worker  // Required. The backup resource name, in the format
215*d5c09012SAndroid Build Coastguard Worker  // `projects/{project_id}/locations/{location}/backupVaults/{backup_vault_id}/backups/{backup_id}`
216*d5c09012SAndroid Build Coastguard Worker  string name = 1 [
217*d5c09012SAndroid Build Coastguard Worker    (google.api.field_behavior) = REQUIRED,
218*d5c09012SAndroid Build Coastguard Worker    (google.api.resource_reference) = { type: "netapp.googleapis.com/Backup" }
219*d5c09012SAndroid Build Coastguard Worker  ];
220*d5c09012SAndroid Build Coastguard Worker}
221*d5c09012SAndroid Build Coastguard Worker
222*d5c09012SAndroid Build Coastguard Worker// UpdateBackupRequest updates description and/or labels for a backup.
223*d5c09012SAndroid Build Coastguard Workermessage UpdateBackupRequest {
224*d5c09012SAndroid Build Coastguard Worker  // Required. Field mask is used to specify the fields to be overwritten in the
225*d5c09012SAndroid Build Coastguard Worker  // Backup resource to be updated.
226*d5c09012SAndroid Build Coastguard Worker  // The fields specified in the update_mask are relative to the resource, not
227*d5c09012SAndroid Build Coastguard Worker  // the full request. A field will be overwritten if it is in the mask. If the
228*d5c09012SAndroid Build Coastguard Worker  // user does not provide a mask then all fields will be overwritten.
229*d5c09012SAndroid Build Coastguard Worker  google.protobuf.FieldMask update_mask = 1
230*d5c09012SAndroid Build Coastguard Worker      [(google.api.field_behavior) = REQUIRED];
231*d5c09012SAndroid Build Coastguard Worker
232*d5c09012SAndroid Build Coastguard Worker  // Required. The backup being updated
233*d5c09012SAndroid Build Coastguard Worker  Backup backup = 2 [(google.api.field_behavior) = REQUIRED];
234*d5c09012SAndroid Build Coastguard Worker}
235