Operation(mapping=None, *, ignore_unknown_fields=False, **kwargs)Contains an operation for a resource loosely based on the JSON-PATCH format with support for:
- Custom filters for describing partial array patch.
- Extended path values for describing nested arrays.
- Custom fields for describing the resource for which the operation is being described.
- Allows extension to custom operations not natively supported by RFC6902. See https://tools.ietf.org/html/rfc6902 for details on the original RFC.
This message has oneof_ fields (mutually exclusive fields).
For each oneof, at most one member field can be set at the same time.
Setting any member of the oneof automatically clears all other
members.
.. _oneof: https://proto-plus-python.readthedocs.io/en/stable/fields.html#oneofs-mutually-exclusive-fields
| Attributes | |
|---|---|
| Name | Description | 
| action | strType of this operation. Contains one of 'add', 'remove', 'replace', 'move', 'copy', 'test' and custom operations. This field is case-insensitive and always populated. | 
| resource_type | strType of GCP resource being modified/tested. This field is always populated. Example: cloudresourcemanager.googleapis.com/Project, compute.googleapis.com/Instance | 
| resource | strContains the fully qualified resource name. This field is always populated. ex: //cloudresourcemanager.googleapis.com/projects/foo. | 
| path | strPath to the target field being operated on. If the operation is at the resource level, then path should be "/". This field is always populated. | 
| source_resource | strCan be set with action 'copy' to copy resource configuration across different resources of the same type. Example: A resource clone can be done via action = 'copy', path = "/", from = "/", source_resource = and resource_name = . This field is empty for all other values of action. | 
| source_path | strCan be set with action 'copy' or 'move' to indicate the source field within resource or source_resource, ignored if provided for other operation types. | 
| value | google.protobuf.struct_pb2.ValueValue for the pathfield. Will be set for
   actions:'add'/'replace'. Maybe set for action: 'test'.
   Either this orvalue_matcherwill be set for 'test'
   operation. An exact match must be performed.
   
   This field is a member ofoneof_path_value. | 
| value_matcher | google.cloud.recommender_v1.types.ValueMatcherCan be set for action 'test' for advanced matching for the value of 'path' field. Either this or valuewill be set
   for 'test' operation.
   
   This field is a member ofoneof_path_value. | 
| path_filters | MutableMapping[str, google.protobuf.struct_pb2.Value]Set of filters to apply if pathrefers to array elements
   or nested array elements in order to narrow down to a single
   unique element that is being tested/modified. This is
   intended to be an exact match per filter. To perform
   advanced matching, use path_value_matchers.
   
   -  Example:
   
   ::
   
      {
        "/versions/*/name" : "it-123"
        "/versions/*/targetSize/percent": 20
      }
   
   -  Example:
   
   ::
   
      {
        "/bindings/*/role": "roles/owner"
        "/bindings/*/condition" : null
      }
   
   -  Example:
   
   ::
   
      {
        "/bindings/*/role": "roles/owner"
        "/bindings/*/members/*" : ["x@example.com", "y@example.com"]
      }
   
   When both path_filters and path_value_matchers are set, an
   implicit AND must be performed. | 
| path_value_matchers | MutableMapping[str, google.cloud.recommender_v1.types.ValueMatcher]Similar to path_filters, this contains set of filters to apply if pathfield refers to array elements. This is
   meant to support value matching beyond exact match. To
   perform exact match, use path_filters. When both
   path_filters and path_value_matchers are set, an implicit
   AND must be performed. | 
Classes
PathFiltersEntry
PathFiltersEntry(mapping=None, *, ignore_unknown_fields=False, **kwargs)The abstract base class for a message.
| Parameters | |
|---|---|
| Name | Description | 
| kwargs | dictKeys and values corresponding to the fields of the message. | 
| mapping | Union[dict, A dictionary or message to be used to determine the values for this message. | 
| ignore_unknown_fields | Optional(bool)If True, do not raise errors for unknown fields. Only applied if  | 
PathValueMatchersEntry
PathValueMatchersEntry(mapping=None, *, ignore_unknown_fields=False, **kwargs)The abstract base class for a message.
| Parameters | |
|---|---|
| Name | Description | 
| kwargs | dictKeys and values corresponding to the fields of the message. | 
| mapping | Union[dict, A dictionary or message to be used to determine the values for this message. | 
| ignore_unknown_fields | Optional(bool)If True, do not raise errors for unknown fields. Only applied if  |