Class: Google::Apis::RunV2::GoogleCloudRunV2Service
- Inherits:
-
Object
- Object
- Google::Apis::RunV2::GoogleCloudRunV2Service
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- lib/google/apis/run_v2/classes.rb,
lib/google/apis/run_v2/representations.rb,
lib/google/apis/run_v2/representations.rb
Overview
Service acts as a top-level container that manages a set of configurations and revision templates which implement a network service. Service exists to provide a singular abstraction which can be access controlled, reasoned about, and which encapsulates software lifecycle decisions such as rollout policy and team resource ownership.
Instance Attribute Summary collapse
-
#annotations ⇒ Hash<String,String>
Optional.
-
#binary_authorization ⇒ Google::Apis::RunV2::GoogleCloudRunV2BinaryAuthorization
Settings for Binary Authorization feature.
-
#client ⇒ String
Arbitrary identifier for the API client.
-
#client_version ⇒ String
Arbitrary version identifier for the API client.
-
#conditions ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2Condition>
Output only.
-
#create_time ⇒ String
Output only.
-
#creator ⇒ String
Output only.
-
#custom_audiences ⇒ Array<String>
One or more custom audiences that you want this service to support.
-
#default_uri_disabled ⇒ Boolean
(also: #default_uri_disabled?)
Optional.
-
#delete_time ⇒ String
Output only.
-
#description ⇒ String
User-provided description of the Service.
-
#etag ⇒ String
Output only.
-
#expire_time ⇒ String
Output only.
-
#generation ⇒ Fixnum
Output only.
-
#ingress ⇒ String
Provides the ingress settings for this Service.
-
#labels ⇒ Hash<String,String>
Optional.
-
#last_modifier ⇒ String
Output only.
-
#latest_created_revision ⇒ String
Output only.
-
#latest_ready_revision ⇒ String
Output only.
-
#launch_stage ⇒ String
The launch stage as defined by Google Cloud Platform Launch Stages.
-
#name ⇒ String
The fully qualified name of this Service.
-
#observed_generation ⇒ Fixnum
Output only.
-
#reconciling ⇒ Boolean
(also: #reconciling?)
Output only.
-
#satisfies_pzs ⇒ Boolean
(also: #satisfies_pzs?)
Output only.
-
#scaling ⇒ Google::Apis::RunV2::GoogleCloudRunV2ServiceScaling
Scaling settings applied at the service level rather than at the revision level.
-
#template ⇒ Google::Apis::RunV2::GoogleCloudRunV2RevisionTemplate
RevisionTemplate describes the data a revision should have when created from a template.
-
#terminal_condition ⇒ Google::Apis::RunV2::GoogleCloudRunV2Condition
Defines a status condition for a resource.
-
#traffic ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTarget>
Specifies how to distribute traffic over a collection of Revisions belonging to the Service.
-
#traffic_statuses ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTargetStatus>
Output only.
-
#uid ⇒ String
Output only.
-
#update_time ⇒ String
Output only.
-
#uri ⇒ String
Output only.
Instance Method Summary collapse
-
#initialize(**args) ⇒ GoogleCloudRunV2Service
constructor
A new instance of GoogleCloudRunV2Service.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ GoogleCloudRunV2Service
Returns a new instance of GoogleCloudRunV2Service.
2139 2140 2141 |
# File 'lib/google/apis/run_v2/classes.rb', line 2139 def initialize(**args) update!(**args) end |
Instance Attribute Details
#annotations ⇒ Hash<String,String>
Optional. Unstructured key value map that may be set by external tools to
store and arbitrary metadata. They are not queryable and should be preserved
when modifying objects. Cloud Run API v2 does not support annotations with
run.googleapis.com, cloud.googleapis.com, serving.knative.dev, or
autoscaling.knative.dev namespaces, and they will be rejected in new
resources. All system annotations in v1 now have a corresponding field in v2
Service. This field follows Kubernetes annotations' namespacing, limits, and
rules.
Corresponds to the JSON property annotations
1918 1919 1920 |
# File 'lib/google/apis/run_v2/classes.rb', line 1918 def annotations @annotations end |
#binary_authorization ⇒ Google::Apis::RunV2::GoogleCloudRunV2BinaryAuthorization
Settings for Binary Authorization feature.
Corresponds to the JSON property binaryAuthorization
1923 1924 1925 |
# File 'lib/google/apis/run_v2/classes.rb', line 1923 def end |
#client ⇒ String
Arbitrary identifier for the API client.
Corresponds to the JSON property client
1928 1929 1930 |
# File 'lib/google/apis/run_v2/classes.rb', line 1928 def client @client end |
#client_version ⇒ String
Arbitrary version identifier for the API client.
Corresponds to the JSON property clientVersion
1933 1934 1935 |
# File 'lib/google/apis/run_v2/classes.rb', line 1933 def client_version @client_version end |
#conditions ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2Condition>
Output only. The Conditions of all other associated sub-resources. They
contain additional diagnostics information in case the Service does not reach
its Serving state. See comments in reconciling for additional information on
reconciliation process in Cloud Run.
Corresponds to the JSON property conditions
1941 1942 1943 |
# File 'lib/google/apis/run_v2/classes.rb', line 1941 def conditions @conditions end |
#create_time ⇒ String
Output only. The creation time.
Corresponds to the JSON property createTime
1946 1947 1948 |
# File 'lib/google/apis/run_v2/classes.rb', line 1946 def create_time @create_time end |
#creator ⇒ String
Output only. Email address of the authenticated creator.
Corresponds to the JSON property creator
1951 1952 1953 |
# File 'lib/google/apis/run_v2/classes.rb', line 1951 def creator @creator end |
#custom_audiences ⇒ Array<String>
One or more custom audiences that you want this service to support. Specify
each custom audience as the full URL in a string. The custom audiences are
encoded in the token and used to authenticate requests. For more information,
see https://cloud.google.com/run/docs/configuring/custom-audiences.
Corresponds to the JSON property customAudiences
1959 1960 1961 |
# File 'lib/google/apis/run_v2/classes.rb', line 1959 def custom_audiences @custom_audiences end |
#default_uri_disabled ⇒ Boolean Also known as: default_uri_disabled?
Optional. Disables public resolution of the default URI of this service.
Corresponds to the JSON property defaultUriDisabled
1964 1965 1966 |
# File 'lib/google/apis/run_v2/classes.rb', line 1964 def default_uri_disabled @default_uri_disabled end |
#delete_time ⇒ String
Output only. The deletion time.
Corresponds to the JSON property deleteTime
1970 1971 1972 |
# File 'lib/google/apis/run_v2/classes.rb', line 1970 def delete_time @delete_time end |
#description ⇒ String
User-provided description of the Service. This field currently has a 512-
character limit.
Corresponds to the JSON property description
1976 1977 1978 |
# File 'lib/google/apis/run_v2/classes.rb', line 1976 def description @description end |
#etag ⇒ String
Output only. A system-generated fingerprint for this version of the resource.
May be used to detect modification conflict during updates.
Corresponds to the JSON property etag
1982 1983 1984 |
# File 'lib/google/apis/run_v2/classes.rb', line 1982 def etag @etag end |
#expire_time ⇒ String
Output only. For a deleted resource, the time after which it will be
permamently deleted.
Corresponds to the JSON property expireTime
1988 1989 1990 |
# File 'lib/google/apis/run_v2/classes.rb', line 1988 def expire_time @expire_time end |
#generation ⇒ Fixnum
Output only. A number that monotonically increases every time the user
modifies the desired state. Please note that unlike v1, this is an int64 value.
As with most Google APIs, its JSON representation will be a string instead
of an integer.
Corresponds to the JSON property generation
1996 1997 1998 |
# File 'lib/google/apis/run_v2/classes.rb', line 1996 def generation @generation end |
#ingress ⇒ String
Provides the ingress settings for this Service. On output, returns the
currently observed ingress settings, or INGRESS_TRAFFIC_UNSPECIFIED if no
revision is active.
Corresponds to the JSON property ingress
2003 2004 2005 |
# File 'lib/google/apis/run_v2/classes.rb', line 2003 def ingress @ingress end |
#labels ⇒ Hash<String,String>
Optional. Unstructured key value map that can be used to organize and
categorize objects. User-provided labels are shared with Google's billing
system, so they can be used to filter, or break down billing charges by team,
component, environment, state, etc. For more information, visit https://cloud.
google.com/resource-manager/docs/creating-managing-labels or https://cloud.
google.com/run/docs/configuring/labels. Cloud Run API v2 does not support
labels with run.googleapis.com, cloud.googleapis.com, serving.knative.dev
, or autoscaling.knative.dev namespaces, and they will be rejected. All
system labels in v1 now have a corresponding field in v2 Service.
Corresponds to the JSON property labels
2016 2017 2018 |
# File 'lib/google/apis/run_v2/classes.rb', line 2016 def labels @labels end |
#last_modifier ⇒ String
Output only. Email address of the last authenticated modifier.
Corresponds to the JSON property lastModifier
2021 2022 2023 |
# File 'lib/google/apis/run_v2/classes.rb', line 2021 def last_modifier @last_modifier end |
#latest_created_revision ⇒ String
Output only. Name of the last created revision. See comments in reconciling
for additional information on reconciliation process in Cloud Run.
Corresponds to the JSON property latestCreatedRevision
2027 2028 2029 |
# File 'lib/google/apis/run_v2/classes.rb', line 2027 def latest_created_revision @latest_created_revision end |
#latest_ready_revision ⇒ String
Output only. Name of the latest revision that is serving traffic. See comments
in reconciling for additional information on reconciliation process in Cloud
Run.
Corresponds to the JSON property latestReadyRevision
2034 2035 2036 |
# File 'lib/google/apis/run_v2/classes.rb', line 2034 def latest_ready_revision @latest_ready_revision end |
#launch_stage ⇒ String
The launch stage as defined by Google Cloud Platform Launch Stages. Cloud Run supports ALPHA, BETA, and
GA. If no value is specified, GA is assumed. Set the launch stage to a
preview stage on input to allow use of preview features in that stage. On read
(or output), describes whether the resource uses preview features. For example,
if ALPHA is provided as input, but only BETA and GA-level features are used,
this field will be BETA on output.
Corresponds to the JSON property launchStage
2045 2046 2047 |
# File 'lib/google/apis/run_v2/classes.rb', line 2045 def launch_stage @launch_stage end |
#name ⇒ String
The fully qualified name of this Service. In CreateServiceRequest, this field
is ignored, and instead composed from CreateServiceRequest.parent and
CreateServiceRequest.service_id. Format: projects/project/locations/
location/services/service_id
Corresponds to the JSON property name
2053 2054 2055 |
# File 'lib/google/apis/run_v2/classes.rb', line 2053 def name @name end |
#observed_generation ⇒ Fixnum
Output only. The generation of this Service currently serving traffic. See
comments in reconciling for additional information on reconciliation process
in Cloud Run. Please note that unlike v1, this is an int64 value. As with most
Google APIs, its JSON representation will be a string instead of an integer
.
Corresponds to the JSON property observedGeneration
2062 2063 2064 |
# File 'lib/google/apis/run_v2/classes.rb', line 2062 def observed_generation @observed_generation end |
#reconciling ⇒ Boolean Also known as: reconciling?
Output only. Returns true if the Service is currently being acted upon by the
system to bring it into the desired state. When a new Service is created, or
an existing one is updated, Cloud Run will asynchronously perform all
necessary steps to bring the Service to the desired serving state. This
process is called reconciliation. While reconciliation is in process,
observed_generation, latest_ready_revison, traffic_statuses, and uri
will have transient values that might mismatch the intended state: Once
reconciliation is over (and this field is false), there are two possible
outcomes: reconciliation succeeded and the serving state matches the Service,
or there was an error, and reconciliation failed. This state can be found in
terminal_condition.state. If reconciliation succeeded, the following fields
will match: traffic and traffic_statuses, observed_generation and
generation, latest_ready_revision and latest_created_revision. If
reconciliation failed, traffic_statuses, observed_generation, and
latest_ready_revision will have the state of the last serving revision, or
empty for newly created Services. Additional information on the failure can be
found in terminal_condition and conditions.
Corresponds to the JSON property reconciling
2083 2084 2085 |
# File 'lib/google/apis/run_v2/classes.rb', line 2083 def reconciling @reconciling end |
#satisfies_pzs ⇒ Boolean Also known as: satisfies_pzs?
Output only. Reserved for future use.
Corresponds to the JSON property satisfiesPzs
2089 2090 2091 |
# File 'lib/google/apis/run_v2/classes.rb', line 2089 def satisfies_pzs @satisfies_pzs end |
#scaling ⇒ Google::Apis::RunV2::GoogleCloudRunV2ServiceScaling
Scaling settings applied at the service level rather than at the revision
level.
Corresponds to the JSON property scaling
2096 2097 2098 |
# File 'lib/google/apis/run_v2/classes.rb', line 2096 def scaling @scaling end |
#template ⇒ Google::Apis::RunV2::GoogleCloudRunV2RevisionTemplate
RevisionTemplate describes the data a revision should have when created from a
template.
Corresponds to the JSON property template
2102 2103 2104 |
# File 'lib/google/apis/run_v2/classes.rb', line 2102 def template @template end |
#terminal_condition ⇒ Google::Apis::RunV2::GoogleCloudRunV2Condition
Defines a status condition for a resource.
Corresponds to the JSON property terminalCondition
2107 2108 2109 |
# File 'lib/google/apis/run_v2/classes.rb', line 2107 def terminal_condition @terminal_condition end |
#traffic ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTarget>
Specifies how to distribute traffic over a collection of Revisions belonging
to the Service. If traffic is empty or not provided, defaults to 100% traffic
to the latest Ready Revision.
Corresponds to the JSON property traffic
2114 2115 2116 |
# File 'lib/google/apis/run_v2/classes.rb', line 2114 def traffic @traffic end |
#traffic_statuses ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTargetStatus>
Output only. Detailed status information for corresponding traffic targets.
See comments in reconciling for additional information on reconciliation
process in Cloud Run.
Corresponds to the JSON property trafficStatuses
2121 2122 2123 |
# File 'lib/google/apis/run_v2/classes.rb', line 2121 def traffic_statuses @traffic_statuses end |
#uid ⇒ String
Output only. Server assigned unique identifier for the trigger. The value is a
UUID4 string and guaranteed to remain unchanged until the resource is deleted.
Corresponds to the JSON property uid
2127 2128 2129 |
# File 'lib/google/apis/run_v2/classes.rb', line 2127 def uid @uid end |
#update_time ⇒ String
Output only. The last-modified time.
Corresponds to the JSON property updateTime
2132 2133 2134 |
# File 'lib/google/apis/run_v2/classes.rb', line 2132 def update_time @update_time end |
#uri ⇒ String
Output only. The main URI in which this Service is serving traffic.
Corresponds to the JSON property uri
2137 2138 2139 |
# File 'lib/google/apis/run_v2/classes.rb', line 2137 def uri @uri end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
2144 2145 2146 2147 2148 2149 2150 2151 2152 2153 2154 2155 2156 2157 2158 2159 2160 2161 2162 2163 2164 2165 2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 |
# File 'lib/google/apis/run_v2/classes.rb', line 2144 def update!(**args) @annotations = args[:annotations] if args.key?(:annotations) = args[:binary_authorization] if args.key?(:binary_authorization) @client = args[:client] if args.key?(:client) @client_version = args[:client_version] if args.key?(:client_version) @conditions = args[:conditions] if args.key?(:conditions) @create_time = args[:create_time] if args.key?(:create_time) @creator = args[:creator] if args.key?(:creator) @custom_audiences = args[:custom_audiences] if args.key?(:custom_audiences) @default_uri_disabled = args[:default_uri_disabled] if args.key?(:default_uri_disabled) @delete_time = args[:delete_time] if args.key?(:delete_time) @description = args[:description] if args.key?(:description) @etag = args[:etag] if args.key?(:etag) @expire_time = args[:expire_time] if args.key?(:expire_time) @generation = args[:generation] if args.key?(:generation) @ingress = args[:ingress] if args.key?(:ingress) @labels = args[:labels] if args.key?(:labels) @last_modifier = args[:last_modifier] if args.key?(:last_modifier) @latest_created_revision = args[:latest_created_revision] if args.key?(:latest_created_revision) @latest_ready_revision = args[:latest_ready_revision] if args.key?(:latest_ready_revision) @launch_stage = args[:launch_stage] if args.key?(:launch_stage) @name = args[:name] if args.key?(:name) @observed_generation = args[:observed_generation] if args.key?(:observed_generation) @reconciling = args[:reconciling] if args.key?(:reconciling) @satisfies_pzs = args[:satisfies_pzs] if args.key?(:satisfies_pzs) @scaling = args[:scaling] if args.key?(:scaling) @template = args[:template] if args.key?(:template) @terminal_condition = args[:terminal_condition] if args.key?(:terminal_condition) @traffic = args[:traffic] if args.key?(:traffic) @traffic_statuses = args[:traffic_statuses] if args.key?(:traffic_statuses) @uid = args[:uid] if args.key?(:uid) @update_time = args[:update_time] if args.key?(:update_time) @uri = args[:uri] if args.key?(:uri) end |