|  | // Copyright 2016 Google Inc. | 
|  | // | 
|  | // Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | // you may not use this file except in compliance with the License. | 
|  | // You may obtain a copy of the License at | 
|  | // | 
|  | //     http://www.apache.org/licenses/LICENSE-2.0 | 
|  | // | 
|  | // Unless required by applicable law or agreed to in writing, software | 
|  | // distributed under the License is distributed on an "AS IS" BASIS, | 
|  | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | // See the License for the specific language governing permissions and | 
|  | // limitations under the License. | 
|  |  | 
|  | syntax = "proto3"; | 
|  |  | 
|  | package google.bigtable.admin.v2; | 
|  |  | 
|  | import "google/api/annotations.proto"; | 
|  | import "google/bigtable/admin/v2/common.proto"; | 
|  |  | 
|  | option go_package = "google.golang.org/genproto/googleapis/bigtable/admin/v2;admin"; | 
|  | option java_multiple_files = true; | 
|  | option java_outer_classname = "InstanceProto"; | 
|  | option java_package = "com.google.bigtable.admin.v2"; | 
|  |  | 
|  |  | 
|  | // A collection of Bigtable [Tables][google.bigtable.admin.v2.Table] and | 
|  | // the resources that serve them. | 
|  | // All tables in an instance are served from a single | 
|  | // [Cluster][google.bigtable.admin.v2.Cluster]. | 
|  | message Instance { | 
|  | // Possible states of an instance. | 
|  | enum State { | 
|  | // The state of the instance could not be determined. | 
|  | STATE_NOT_KNOWN = 0; | 
|  |  | 
|  | // The instance has been successfully created and can serve requests | 
|  | // to its tables. | 
|  | READY = 1; | 
|  |  | 
|  | // The instance is currently being created, and may be destroyed | 
|  | // if the creation process encounters an error. | 
|  | CREATING = 2; | 
|  | } | 
|  |  | 
|  | // The type of the instance. | 
|  | enum Type { | 
|  | // The type of the instance is unspecified. If set when creating an | 
|  | // instance, a `PRODUCTION` instance will be created. If set when updating | 
|  | // an instance, the type will be left unchanged. | 
|  | TYPE_UNSPECIFIED = 0; | 
|  |  | 
|  | // An instance meant for production use. `serve_nodes` must be set | 
|  | // on the cluster. | 
|  | PRODUCTION = 1; | 
|  | } | 
|  |  | 
|  | // (`OutputOnly`) | 
|  | // The unique name of the instance. Values are of the form | 
|  | // `projects/<project>/instances/[a-z][a-z0-9\\-]+[a-z0-9]`. | 
|  | string name = 1; | 
|  |  | 
|  | // The descriptive name for this instance as it appears in UIs. | 
|  | // Can be changed at any time, but should be kept globally unique | 
|  | // to avoid confusion. | 
|  | string display_name = 2; | 
|  |  | 
|  | // (`OutputOnly`) | 
|  | // The current state of the instance. | 
|  | State state = 3; | 
|  |  | 
|  | // The type of the instance. Defaults to `PRODUCTION`. | 
|  | Type type = 4; | 
|  | } | 
|  |  | 
|  | // A resizable group of nodes in a particular cloud location, capable | 
|  | // of serving all [Tables][google.bigtable.admin.v2.Table] in the parent | 
|  | // [Instance][google.bigtable.admin.v2.Instance]. | 
|  | message Cluster { | 
|  | // Possible states of a cluster. | 
|  | enum State { | 
|  | // The state of the cluster could not be determined. | 
|  | STATE_NOT_KNOWN = 0; | 
|  |  | 
|  | // The cluster has been successfully created and is ready to serve requests. | 
|  | READY = 1; | 
|  |  | 
|  | // The cluster is currently being created, and may be destroyed | 
|  | // if the creation process encounters an error. | 
|  | // A cluster may not be able to serve requests while being created. | 
|  | CREATING = 2; | 
|  |  | 
|  | // The cluster is currently being resized, and may revert to its previous | 
|  | // node count if the process encounters an error. | 
|  | // A cluster is still capable of serving requests while being resized, | 
|  | // but may exhibit performance as if its number of allocated nodes is | 
|  | // between the starting and requested states. | 
|  | RESIZING = 3; | 
|  |  | 
|  | // The cluster has no backing nodes. The data (tables) still | 
|  | // exist, but no operations can be performed on the cluster. | 
|  | DISABLED = 4; | 
|  | } | 
|  |  | 
|  | // (`OutputOnly`) | 
|  | // The unique name of the cluster. Values are of the form | 
|  | // `projects/<project>/instances/<instance>/clusters/[a-z][-a-z0-9]*`. | 
|  | string name = 1; | 
|  |  | 
|  | // (`CreationOnly`) | 
|  | // The location where this cluster's nodes and storage reside. For best | 
|  | // performance, clients should be located as close as possible to this cluster. | 
|  | // Currently only zones are supported, so values should be of the form | 
|  | // `projects/<project>/locations/<zone>`. | 
|  | string location = 2; | 
|  |  | 
|  | // (`OutputOnly`) | 
|  | // The current state of the cluster. | 
|  | State state = 3; | 
|  |  | 
|  | // The number of nodes allocated to this cluster. More nodes enable higher | 
|  | // throughput and more consistent performance. | 
|  | int32 serve_nodes = 4; | 
|  |  | 
|  | // (`CreationOnly`) | 
|  | // The type of storage used by this cluster to serve its | 
|  | // parent instance's tables, unless explicitly overridden. | 
|  | StorageType default_storage_type = 5; | 
|  | } |