Class: Google::Apis::NetworkservicesV1::EndpointPolicy
- Inherits:
-
Object
- Object
- Google::Apis::NetworkservicesV1::EndpointPolicy
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- lib/google/apis/networkservices_v1/classes.rb,
lib/google/apis/networkservices_v1/representations.rb,
lib/google/apis/networkservices_v1/representations.rb
Overview
EndpointPolicy is a resource that helps apply desired configuration on the endpoints that match specific criteria. For example, this resource can be used to apply "authentication config" an all endpoints that serve on port 8080.
Instance Attribute Summary collapse
-
#authorization_policy ⇒ String
Optional.
-
#client_tls_policy ⇒ String
Optional.
-
#create_time ⇒ String
Output only.
-
#description ⇒ String
Optional.
-
#endpoint_matcher ⇒ Google::Apis::NetworkservicesV1::EndpointMatcher
A definition of a matcher that selects endpoints to which the policies should be applied.
-
#labels ⇒ Hash<String,String>
Optional.
-
#name ⇒ String
Identifier.
-
#server_tls_policy ⇒ String
Optional.
-
#traffic_port_selector ⇒ Google::Apis::NetworkservicesV1::TrafficPortSelector
Specification of a port-based selector.
-
#type ⇒ String
Required.
-
#update_time ⇒ String
Output only.
Instance Method Summary collapse
-
#initialize(**args) ⇒ EndpointPolicy
constructor
A new instance of EndpointPolicy.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ EndpointPolicy
Returns a new instance of EndpointPolicy.
388 389 390 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 388 def initialize(**args) update!(**args) end |
Instance Attribute Details
#authorization_policy ⇒ String
Optional. This field specifies the URL of AuthorizationPolicy resource that
applies authorization policies to the inbound traffic at the matched endpoints.
Refer to Authorization. If this field is not specified, authorization is
disabled(no authz checks) for this endpoint.
Corresponds to the JSON property authorizationPolicy
323 324 325 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 323 def @authorization_policy end |
#client_tls_policy ⇒ String
Optional. A URL referring to a ClientTlsPolicy resource. ClientTlsPolicy can
be set to specify the authentication for traffic from the proxy to the actual
endpoints. More specifically, it is applied to the outgoing traffic from the
proxy to the endpoint. This is typically used for sidecar model where the
proxy identifies itself as endpoint to the control plane, with the connection
between sidecar and endpoint requiring authentication. If this field is not
set, authentication is disabled(open). Applicable only when EndpointPolicyType
is SIDECAR_PROXY.
Corresponds to the JSON property clientTlsPolicy
335 336 337 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 335 def client_tls_policy @client_tls_policy end |
#create_time ⇒ String
Output only. The timestamp when the resource was created.
Corresponds to the JSON property createTime
340 341 342 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 340 def create_time @create_time end |
#description ⇒ String
Optional. A free-text description of the resource. Max length 1024 characters.
Corresponds to the JSON property description
345 346 347 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 345 def description @description end |
#endpoint_matcher ⇒ Google::Apis::NetworkservicesV1::EndpointMatcher
A definition of a matcher that selects endpoints to which the policies should
be applied.
Corresponds to the JSON property endpointMatcher
351 352 353 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 351 def endpoint_matcher @endpoint_matcher end |
#labels ⇒ Hash<String,String>
Optional. Set of label tags associated with the EndpointPolicy resource.
Corresponds to the JSON property labels
356 357 358 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 356 def labels @labels end |
#name ⇒ String
Identifier. Name of the EndpointPolicy resource. It matches pattern projects/
project/locations/global/endpointPolicies/
endpoint_policy`.
Corresponds to the JSON property
name`
362 363 364 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 362 def name @name end |
#server_tls_policy ⇒ String
Optional. A URL referring to ServerTlsPolicy resource. ServerTlsPolicy is used
to determine the authentication policy to be applied to terminate the inbound
traffic at the identified backends. If this field is not set, authentication
is disabled(open) for this endpoint.
Corresponds to the JSON property serverTlsPolicy
370 371 372 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 370 def server_tls_policy @server_tls_policy end |
#traffic_port_selector ⇒ Google::Apis::NetworkservicesV1::TrafficPortSelector
Specification of a port-based selector.
Corresponds to the JSON property trafficPortSelector
375 376 377 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 375 def traffic_port_selector @traffic_port_selector end |
#type ⇒ String
Required. The type of endpoint policy. This is primarily used to validate the
configuration.
Corresponds to the JSON property type
381 382 383 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 381 def type @type end |
#update_time ⇒ String
Output only. The timestamp when the resource was updated.
Corresponds to the JSON property updateTime
386 387 388 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 386 def update_time @update_time end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
393 394 395 396 397 398 399 400 401 402 403 404 405 |
# File 'lib/google/apis/networkservices_v1/classes.rb', line 393 def update!(**args) @authorization_policy = args[:authorization_policy] if args.key?(:authorization_policy) @client_tls_policy = args[:client_tls_policy] if args.key?(:client_tls_policy) @create_time = args[:create_time] if args.key?(:create_time) @description = args[:description] if args.key?(:description) @endpoint_matcher = args[:endpoint_matcher] if args.key?(:endpoint_matcher) @labels = args[:labels] if args.key?(:labels) @name = args[:name] if args.key?(:name) @server_tls_policy = args[:server_tls_policy] if args.key?(:server_tls_policy) @traffic_port_selector = args[:traffic_port_selector] if args.key?(:traffic_port_selector) @type = args[:type] if args.key?(:type) @update_time = args[:update_time] if args.key?(:update_time) end |