diff --git a/clients/eventarc/lib/google_api/eventarc/v1/api/projects.ex b/clients/eventarc/lib/google_api/eventarc/v1/api/projects.ex index c74af4909c..fa4cec72fd 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/api/projects.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/api/projects.ex @@ -827,7 +827,7 @@ defmodule GoogleApi.Eventarc.V1.Api.Projects do * `:uploadType` (*type:* `String.t`) - Legacy upload protocol for media (e.g. "media", "multipart"). * `:upload_protocol` (*type:* `String.t`) - Upload protocol for media (e.g. "raw", "multipart"). * `:channelId` (*type:* `String.t`) - Required. The user-provided ID to be assigned to the channel. - * `:validateOnly` (*type:* `boolean()`) - Required. If set, validate the request and preview the review, but do not post it. + * `:validateOnly` (*type:* `boolean()`) - Optional. If set, validate the request and preview the review, but do not post it. * `:body` (*type:* `GoogleApi.Eventarc.V1.Model.Channel.t`) - * `opts` (*type:* `keyword()`) - Call options @@ -904,7 +904,7 @@ defmodule GoogleApi.Eventarc.V1.Api.Projects do * `:quotaUser` (*type:* `String.t`) - Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters. * `:uploadType` (*type:* `String.t`) - Legacy upload protocol for media (e.g. "media", "multipart"). * `:upload_protocol` (*type:* `String.t`) - Upload protocol for media (e.g. "raw", "multipart"). - * `:validateOnly` (*type:* `boolean()`) - Required. If set, validate the request and preview the review, but do not post it. + * `:validateOnly` (*type:* `boolean()`) - Optional. If set, validate the request and preview the review, but do not post it. * `opts` (*type:* `keyword()`) - Call options ## Returns @@ -1197,7 +1197,7 @@ defmodule GoogleApi.Eventarc.V1.Api.Projects do * `:uploadType` (*type:* `String.t`) - Legacy upload protocol for media (e.g. "media", "multipart"). * `:upload_protocol` (*type:* `String.t`) - Upload protocol for media (e.g. "raw", "multipart"). * `:updateMask` (*type:* `String.t`) - The fields to be updated; only fields explicitly provided are updated. If no field mask is provided, all provided fields in the request are updated. To update all fields, provide a field mask of "*". - * `:validateOnly` (*type:* `boolean()`) - Required. If set, validate the request and preview the review, but do not post it. + * `:validateOnly` (*type:* `boolean()`) - Optional. If set, validate the request and preview the review, but do not post it. * `:body` (*type:* `GoogleApi.Eventarc.V1.Model.Channel.t`) - * `opts` (*type:* `keyword()`) - Call options @@ -1616,7 +1616,7 @@ defmodule GoogleApi.Eventarc.V1.Api.Projects do end @doc """ - Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`. NOTE: the `name` binding allows API services to override the binding to use different resource name schemes, such as `users/*/operations`. To override the binding, API services can add a binding such as `"/v1/{name=users/*}/operations"` to their service configuration. For backwards compatibility, the default name includes the operations collection id, however overriding users must ensure the name binding is the parent resource, without the operations collection id. + Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`. ## Parameters @@ -1861,7 +1861,7 @@ defmodule GoogleApi.Eventarc.V1.Api.Projects do * `:uploadType` (*type:* `String.t`) - Legacy upload protocol for media (e.g. "media", "multipart"). * `:upload_protocol` (*type:* `String.t`) - Upload protocol for media (e.g. "raw", "multipart"). * `:triggerId` (*type:* `String.t`) - Required. The user-provided ID to be assigned to the trigger. - * `:validateOnly` (*type:* `boolean()`) - Required. If set, validate the request and preview the review, but do not post it. + * `:validateOnly` (*type:* `boolean()`) - Optional. If set, validate the request and preview the review, but do not post it. * `:body` (*type:* `GoogleApi.Eventarc.V1.Model.Trigger.t`) - * `opts` (*type:* `keyword()`) - Call options @@ -1940,7 +1940,7 @@ defmodule GoogleApi.Eventarc.V1.Api.Projects do * `:upload_protocol` (*type:* `String.t`) - Upload protocol for media (e.g. "raw", "multipart"). * `:allowMissing` (*type:* `boolean()`) - If set to true, and the trigger is not found, the request will succeed but no action will be taken on the server. * `:etag` (*type:* `String.t`) - If provided, the trigger will only be deleted if the etag matches the current etag on the resource. - * `:validateOnly` (*type:* `boolean()`) - Required. If set, validate the request and preview the review, but do not post it. + * `:validateOnly` (*type:* `boolean()`) - Optional. If set, validate the request and preview the review, but do not post it. * `opts` (*type:* `keyword()`) - Call options ## Returns @@ -2238,7 +2238,7 @@ defmodule GoogleApi.Eventarc.V1.Api.Projects do * `:upload_protocol` (*type:* `String.t`) - Upload protocol for media (e.g. "raw", "multipart"). * `:allowMissing` (*type:* `boolean()`) - If set to true, and the trigger is not found, a new trigger will be created. In this situation, `update_mask` is ignored. * `:updateMask` (*type:* `String.t`) - The fields to be updated; only fields explicitly provided are updated. If no field mask is provided, all provided fields in the request are updated. To update all fields, provide a field mask of "*". - * `:validateOnly` (*type:* `boolean()`) - Required. If set, validate the request and preview the review, but do not post it. + * `:validateOnly` (*type:* `boolean()`) - Optional. If set, validate the request and preview the review, but do not post it. * `:body` (*type:* `GoogleApi.Eventarc.V1.Model.Trigger.t`) - * `opts` (*type:* `keyword()`) - Call options diff --git a/clients/eventarc/lib/google_api/eventarc/v1/metadata.ex b/clients/eventarc/lib/google_api/eventarc/v1/metadata.ex index 01409a7c98..7d4bd0a6c7 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/metadata.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/metadata.ex @@ -20,7 +20,7 @@ defmodule GoogleApi.Eventarc.V1 do API client metadata for GoogleApi.Eventarc.V1. """ - @discovery_revision "20221021" + @discovery_revision "20240229" def discovery_revision(), do: @discovery_revision end diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/binding.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/binding.ex index 27b939aa8c..150eb09099 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/model/binding.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/binding.ex @@ -22,8 +22,8 @@ defmodule GoogleApi.Eventarc.V1.Model.Binding do ## Attributes * `condition` (*type:* `GoogleApi.Eventarc.V1.Model.Expr.t`, *default:* `nil`) - The condition that is associated with this binding. If the condition evaluates to `true`, then this binding applies to the current request. If the condition evaluates to `false`, then this binding does not apply to the current request. However, a different role binding might grant the same role to one or more of the principals in this binding. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). - * `members` (*type:* `list(String.t)`, *default:* `nil`) - Specifies the principals requesting access for a Google Cloud resource. `members` can have the following values: * `allUsers`: A special identifier that represents anyone who is on the internet; with or without a Google account. * `allAuthenticatedUsers`: A special identifier that represents anyone who is authenticated with a Google account or a service account. Does not include identities that come from external identity providers (IdPs) through identity federation. * `user:{emailid}`: An email address that represents a specific Google account. For example, `alice@example.com` . * `serviceAccount:{emailid}`: An email address that represents a Google service account. For example, `my-other-app@appspot.gserviceaccount.com`. * `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`: An identifier for a [Kubernetes service account](https://cloud.google.com/kubernetes-engine/docs/how-to/kubernetes-service-accounts). For example, `my-project.svc.id.goog[my-namespace/my-kubernetes-sa]`. * `group:{emailid}`: An email address that represents a Google group. For example, `admins@example.com`. * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a user that has been recently deleted. For example, `alice@example.com?uid=123456789012345678901`. If the user is recovered, this value reverts to `user:{emailid}` and the recovered user retains the role in the binding. * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a service account that has been recently deleted. For example, `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`. If the service account is undeleted, this value reverts to `serviceAccount:{emailid}` and the undeleted service account retains the role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a Google group that has been recently deleted. For example, `admins@example.com?uid=123456789012345678901`. If the group is recovered, this value reverts to `group:{emailid}` and the recovered group retains the role in the binding. * `domain:{domain}`: The G Suite domain (primary) that represents all the users of that domain. For example, `google.com` or `example.com`. - * `role` (*type:* `String.t`, *default:* `nil`) - Role that is assigned to the list of `members`, or principals. For example, `roles/viewer`, `roles/editor`, or `roles/owner`. + * `members` (*type:* `list(String.t)`, *default:* `nil`) - Specifies the principals requesting access for a Google Cloud resource. `members` can have the following values: * `allUsers`: A special identifier that represents anyone who is on the internet; with or without a Google account. * `allAuthenticatedUsers`: A special identifier that represents anyone who is authenticated with a Google account or a service account. Does not include identities that come from external identity providers (IdPs) through identity federation. * `user:{emailid}`: An email address that represents a specific Google account. For example, `alice@example.com` . * `serviceAccount:{emailid}`: An email address that represents a Google service account. For example, `my-other-app@appspot.gserviceaccount.com`. * `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`: An identifier for a [Kubernetes service account](https://cloud.google.com/kubernetes-engine/docs/how-to/kubernetes-service-accounts). For example, `my-project.svc.id.goog[my-namespace/my-kubernetes-sa]`. * `group:{emailid}`: An email address that represents a Google group. For example, `admins@example.com`. * `domain:{domain}`: The G Suite domain (primary) that represents all the users of that domain. For example, `google.com` or `example.com`. * `principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workforce identity pool. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/group/{group_id}`: All workforce identities in a group. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All workforce identities with a specific attribute value. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/*`: All identities in a workforce identity pool. * `principal://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workload identity pool. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/group/{group_id}`: A workload identity pool group. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All identities in a workload identity pool with a certain attribute. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/*`: All identities in a workload identity pool. * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a user that has been recently deleted. For example, `alice@example.com?uid=123456789012345678901`. If the user is recovered, this value reverts to `user:{emailid}` and the recovered user retains the role in the binding. * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a service account that has been recently deleted. For example, `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`. If the service account is undeleted, this value reverts to `serviceAccount:{emailid}` and the undeleted service account retains the role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a Google group that has been recently deleted. For example, `admins@example.com?uid=123456789012345678901`. If the group is recovered, this value reverts to `group:{emailid}` and the recovered group retains the role in the binding. * `deleted:principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: Deleted single identity in a workforce identity pool. For example, `deleted:principal://iam.googleapis.com/locations/global/workforcePools/my-pool-id/subject/my-subject-attribute-value`. + * `role` (*type:* `String.t`, *default:* `nil`) - Role that is assigned to the list of `members`, or principals. For example, `roles/viewer`, `roles/editor`, or `roles/owner`. For an overview of the IAM roles and permissions, see the [IAM documentation](https://cloud.google.com/iam/docs/roles-overview). For a list of the available pre-defined roles, see [here](https://cloud.google.com/iam/docs/understanding-roles). """ use GoogleApi.Gax.ModelBase diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/channel.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/channel.ex index 3afd0bd178..007b10fc02 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/model/channel.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/channel.ex @@ -23,7 +23,7 @@ defmodule GoogleApi.Eventarc.V1.Model.Channel do * `activationToken` (*type:* `String.t`, *default:* `nil`) - Output only. The activation token for the channel. The token must be used by the provider to register the channel for publishing. * `createTime` (*type:* `DateTime.t`, *default:* `nil`) - Output only. The creation time. - * `cryptoKeyName` (*type:* `String.t`, *default:* `nil`) - Optional. Resource name of a KMS crypto key (managed by the user) used to encrypt/decrypt their event data. It must match the pattern `projects/*/locations/*/keyRings/*/cryptoKeys/*`. + * `cryptoKeyName` (*type:* `String.t`, *default:* `nil`) - Resource name of a KMS crypto key (managed by the user) used to encrypt/decrypt their event data. It must match the pattern `projects/*/locations/*/keyRings/*/cryptoKeys/*`. * `name` (*type:* `String.t`, *default:* `nil`) - Required. The resource name of the channel. Must be unique within the location on the project and must be in `projects/{project}/locations/{location}/channels/{channel_id}` format. * `provider` (*type:* `String.t`, *default:* `nil`) - The name of the event provider (e.g. Eventarc SaaS partner) associated with the channel. This provider will be granted permissions to publish events to the channel. Format: `projects/{project}/locations/{location}/providers/{provider_id}`. * `pubsubTopic` (*type:* `String.t`, *default:* `nil`) - Output only. The name of the Pub/Sub topic created and managed by Eventarc system as a transport for the event delivery. Format: `projects/{project}/topics/{topic_id}`. diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/destination.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/destination.ex index b12ccd9dbd..6e7e20edcd 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/model/destination.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/destination.ex @@ -21,9 +21,11 @@ defmodule GoogleApi.Eventarc.V1.Model.Destination do ## Attributes - * `cloudFunction` (*type:* `String.t`, *default:* `nil`) - The Cloud Function resource name. Only Cloud Functions V2 is supported. Format: `projects/{project}/locations/{location}/functions/{function}` + * `cloudFunction` (*type:* `String.t`, *default:* `nil`) - The Cloud Function resource name. Cloud Functions V1 and V2 are supported. Format: `projects/{project}/locations/{location}/functions/{function}` This is a read-only field. Creating Cloud Functions V1/V2 triggers is only supported via the Cloud Functions product. An error will be returned if the user sets this value. * `cloudRun` (*type:* `GoogleApi.Eventarc.V1.Model.CloudRun.t`, *default:* `nil`) - Cloud Run fully-managed resource that receives the events. The resource should be in the same project as the trigger. * `gke` (*type:* `GoogleApi.Eventarc.V1.Model.GKE.t`, *default:* `nil`) - A GKE service capable of receiving events. The service should be running in the same project as the trigger. + * `httpEndpoint` (*type:* `GoogleApi.Eventarc.V1.Model.HttpEndpoint.t`, *default:* `nil`) - An HTTP endpoint destination described by an URI. + * `networkConfig` (*type:* `GoogleApi.Eventarc.V1.Model.NetworkConfig.t`, *default:* `nil`) - Optional. Network config is used to configure how Eventarc resolves and connect to a destination. This should only be used with HttpEndpoint destination type. * `workflow` (*type:* `String.t`, *default:* `nil`) - The resource name of the Workflow whose Executions are triggered by the events. The Workflow resource should be deployed in the same project as the trigger. Format: `projects/{project}/locations/{location}/workflows/{workflow}` """ @@ -33,12 +35,16 @@ defmodule GoogleApi.Eventarc.V1.Model.Destination do :cloudFunction => String.t() | nil, :cloudRun => GoogleApi.Eventarc.V1.Model.CloudRun.t() | nil, :gke => GoogleApi.Eventarc.V1.Model.GKE.t() | nil, + :httpEndpoint => GoogleApi.Eventarc.V1.Model.HttpEndpoint.t() | nil, + :networkConfig => GoogleApi.Eventarc.V1.Model.NetworkConfig.t() | nil, :workflow => String.t() | nil } field(:cloudFunction) field(:cloudRun, as: GoogleApi.Eventarc.V1.Model.CloudRun) field(:gke, as: GoogleApi.Eventarc.V1.Model.GKE) + field(:httpEndpoint, as: GoogleApi.Eventarc.V1.Model.HttpEndpoint) + field(:networkConfig, as: GoogleApi.Eventarc.V1.Model.NetworkConfig) field(:workflow) end diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/event_filter.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/event_filter.ex index 31862297c1..b722f3027c 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/model/event_filter.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/event_filter.ex @@ -21,8 +21,8 @@ defmodule GoogleApi.Eventarc.V1.Model.EventFilter do ## Attributes - * `attribute` (*type:* `String.t`, *default:* `nil`) - Required. The name of a CloudEvents attribute. Currently, only a subset of attributes are supported for filtering. All triggers MUST provide a filter for the 'type' attribute. - * `operator` (*type:* `String.t`, *default:* `nil`) - Optional. The operator used for matching the events with the value of the filter. If not specified, only events that have an exact key-value pair specified in the filter are matched. The only allowed value is `match-path-pattern`. + * `attribute` (*type:* `String.t`, *default:* `nil`) - Required. The name of a CloudEvents attribute. Currently, only a subset of attributes are supported for filtering. You can [retrieve a specific provider's supported event types](/eventarc/docs/list-providers#describe-provider). All triggers MUST provide a filter for the 'type' attribute. + * `operator` (*type:* `String.t`, *default:* `nil`) - Optional. The operator used for matching the events with the value of the filter. If not specified, only events that have an exact key-value pair specified in the filter are matched. The allowed values are `path_pattern` and `match-path-pattern`. `path_pattern` is only allowed for GCFv1 triggers. * `value` (*type:* `String.t`, *default:* `nil`) - Required. The value for the attribute. """ diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/google_longrunning_operation.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/google_longrunning_operation.ex index 1b5da44ecf..0f845afb49 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/model/google_longrunning_operation.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/google_longrunning_operation.ex @@ -25,7 +25,7 @@ defmodule GoogleApi.Eventarc.V1.Model.GoogleLongrunningOperation do * `error` (*type:* `GoogleApi.Eventarc.V1.Model.GoogleRpcStatus.t`, *default:* `nil`) - The error result of the operation in case of failure or cancellation. * `metadata` (*type:* `map()`, *default:* `nil`) - Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. * `name` (*type:* `String.t`, *default:* `nil`) - The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. - * `response` (*type:* `map()`, *default:* `nil`) - The normal response of the operation in case of success. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + * `response` (*type:* `map()`, *default:* `nil`) - The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. """ use GoogleApi.Gax.ModelBase diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/http_endpoint.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/http_endpoint.ex new file mode 100644 index 0000000000..37682c245c --- /dev/null +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/http_endpoint.ex @@ -0,0 +1,46 @@ +# Copyright 2019 Google LLC +# +# 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. + +# NOTE: This file is auto generated by the elixir code generator program. +# Do not edit this file manually. + +defmodule GoogleApi.Eventarc.V1.Model.HttpEndpoint do + @moduledoc """ + Represents a HTTP endpoint destination. + + ## Attributes + + * `uri` (*type:* `String.t`, *default:* `nil`) - Required. The URI of the HTTP enpdoint. The value must be a RFC2396 URI string. Examples: `http://10.10.10.8:80/route`, `http://svc.us-central1.p.local:8080/`. Only HTTP and HTTPS protocols are supported. The host can be either a static IP addressable from the VPC specified by the network config, or an internal DNS hostname of the service resolvable via Cloud DNS. + """ + + use GoogleApi.Gax.ModelBase + + @type t :: %__MODULE__{ + :uri => String.t() | nil + } + + field(:uri) +end + +defimpl Poison.Decoder, for: GoogleApi.Eventarc.V1.Model.HttpEndpoint do + def decode(value, options) do + GoogleApi.Eventarc.V1.Model.HttpEndpoint.decode(value, options) + end +end + +defimpl Poison.Encoder, for: GoogleApi.Eventarc.V1.Model.HttpEndpoint do + def encode(value, options) do + GoogleApi.Gax.ModelBase.encode(value, options) + end +end diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/location.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/location.ex index 4617424ea3..a4b77708f6 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/model/location.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/location.ex @@ -17,7 +17,7 @@ defmodule GoogleApi.Eventarc.V1.Model.Location do @moduledoc """ - A resource that represents Google Cloud Platform location. + A resource that represents a Google Cloud location. ## Attributes diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/network_config.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/network_config.ex new file mode 100644 index 0000000000..f7e9ac6ddb --- /dev/null +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/network_config.ex @@ -0,0 +1,46 @@ +# Copyright 2019 Google LLC +# +# 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. + +# NOTE: This file is auto generated by the elixir code generator program. +# Do not edit this file manually. + +defmodule GoogleApi.Eventarc.V1.Model.NetworkConfig do + @moduledoc """ + Represents a network config to be used for destination resolution and connectivity. + + ## Attributes + + * `networkAttachment` (*type:* `String.t`, *default:* `nil`) - Required. Name of the NetworkAttachment that allows access to the destination VPC. Format: `projects/{PROJECT_ID}/regions/{REGION}/networkAttachments/{NETWORK_ATTACHMENT_NAME}` + """ + + use GoogleApi.Gax.ModelBase + + @type t :: %__MODULE__{ + :networkAttachment => String.t() | nil + } + + field(:networkAttachment) +end + +defimpl Poison.Decoder, for: GoogleApi.Eventarc.V1.Model.NetworkConfig do + def decode(value, options) do + GoogleApi.Eventarc.V1.Model.NetworkConfig.decode(value, options) + end +end + +defimpl Poison.Encoder, for: GoogleApi.Eventarc.V1.Model.NetworkConfig do + def encode(value, options) do + GoogleApi.Gax.ModelBase.encode(value, options) + end +end diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/policy.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/policy.ex index 25f5348324..ad3fe60c15 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/model/policy.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/policy.ex @@ -17,7 +17,7 @@ defmodule GoogleApi.Eventarc.V1.Model.Policy do @moduledoc """ - An Identity and Access Management (IAM) policy, which specifies access controls for Google Cloud resources. A `Policy` is a collection of `bindings`. A `binding` binds one or more `members`, or principals, to a single `role`. Principals can be user accounts, service accounts, Google groups, and domains (such as G Suite). A `role` is a named list of permissions; each `role` can be an IAM predefined role or a user-created custom role. For some types of Google Cloud resources, a `binding` can also specify a `condition`, which is a logical expression that allows access to a resource only if the expression evaluates to `true`. A condition can add constraints based on attributes of the request, the resource, or both. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). **JSON example:** { "bindings": [ { "role": "roles/resourcemanager.organizationAdmin", "members": [ "user:mike@example.com", "group:admins@example.com", "domain:google.com", "serviceAccount:my-project-id@appspot.gserviceaccount.com" ] }, { "role": "roles/resourcemanager.organizationViewer", "members": [ "user:eve@example.com" ], "condition": { "title": "expirable access", "description": "Does not grant access after Sep 2020", "expression": "request.time < timestamp('2020-10-01T00:00:00.000Z')", } } ], "etag": "BwWWja0YfJA=", "version": 3 } **YAML example:** bindings: - members: - user:mike@example.com - group:admins@example.com - domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com role: roles/resourcemanager.organizationAdmin - members: - user:eve@example.com role: roles/resourcemanager.organizationViewer condition: title: expirable access description: Does not grant access after Sep 2020 expression: request.time < timestamp('2020-10-01T00:00:00.000Z') etag: BwWWja0YfJA= version: 3 For a description of IAM and its features, see the [IAM documentation](https://cloud.google.com/iam/docs/). + An Identity and Access Management (IAM) policy, which specifies access controls for Google Cloud resources. A `Policy` is a collection of `bindings`. A `binding` binds one or more `members`, or principals, to a single `role`. Principals can be user accounts, service accounts, Google groups, and domains (such as G Suite). A `role` is a named list of permissions; each `role` can be an IAM predefined role or a user-created custom role. For some types of Google Cloud resources, a `binding` can also specify a `condition`, which is a logical expression that allows access to a resource only if the expression evaluates to `true`. A condition can add constraints based on attributes of the request, the resource, or both. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). **JSON example:** ``` { "bindings": [ { "role": "roles/resourcemanager.organizationAdmin", "members": [ "user:mike@example.com", "group:admins@example.com", "domain:google.com", "serviceAccount:my-project-id@appspot.gserviceaccount.com" ] }, { "role": "roles/resourcemanager.organizationViewer", "members": [ "user:eve@example.com" ], "condition": { "title": "expirable access", "description": "Does not grant access after Sep 2020", "expression": "request.time < timestamp('2020-10-01T00:00:00.000Z')", } } ], "etag": "BwWWja0YfJA=", "version": 3 } ``` **YAML example:** ``` bindings: - members: - user:mike@example.com - group:admins@example.com - domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com role: roles/resourcemanager.organizationAdmin - members: - user:eve@example.com role: roles/resourcemanager.organizationViewer condition: title: expirable access description: Does not grant access after Sep 2020 expression: request.time < timestamp('2020-10-01T00:00:00.000Z') etag: BwWWja0YfJA= version: 3 ``` For a description of IAM and its features, see the [IAM documentation](https://cloud.google.com/iam/docs/). ## Attributes diff --git a/clients/eventarc/lib/google_api/eventarc/v1/model/trigger.ex b/clients/eventarc/lib/google_api/eventarc/v1/model/trigger.ex index 302da9eaa0..2da816393f 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1/model/trigger.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1/model/trigger.ex @@ -26,11 +26,12 @@ defmodule GoogleApi.Eventarc.V1.Model.Trigger do * `createTime` (*type:* `DateTime.t`, *default:* `nil`) - Output only. The creation time. * `destination` (*type:* `GoogleApi.Eventarc.V1.Model.Destination.t`, *default:* `nil`) - Required. Destination specifies where the events should be sent to. * `etag` (*type:* `String.t`, *default:* `nil`) - Output only. This checksum is computed by the server based on the value of other fields, and might be sent only on create requests to ensure that the client has an up-to-date value before proceeding. + * `eventDataContentType` (*type:* `String.t`, *default:* `nil`) - Optional. EventDataContentType specifies the type of payload in MIME format that is expected from the CloudEvent data field. This is set to `application/json` if the value is not defined. * `eventFilters` (*type:* `list(GoogleApi.Eventarc.V1.Model.EventFilter.t)`, *default:* `nil`) - Required. Unordered list. The list of filters that applies to event attributes. Only events that match all the provided filters are sent to the destination. * `labels` (*type:* `map()`, *default:* `nil`) - Optional. User labels attached to the triggers that can be used to group resources. * `name` (*type:* `String.t`, *default:* `nil`) - Required. The resource name of the trigger. Must be unique within the location of the project and must be in `projects/{project}/locations/{location}/triggers/{trigger}` format. - * `serviceAccount` (*type:* `String.t`, *default:* `nil`) - Optional. The IAM service account email associated with the trigger. The service account represents the identity of the trigger. The principal who calls this API must have the `iam.serviceAccounts.actAs` permission in the service account. See https://cloud.google.com/iam/docs/understanding-service-accounts?hl=en#sa_common for more information. For Cloud Run destinations, this service account is used to generate identity tokens when invoking the service. See https://cloud.google.com/run/docs/triggering/pubsub-push#create-service-account for information on how to invoke authenticated Cloud Run services. To create Audit Log triggers, the service account should also have the `roles/eventarc.eventReceiver` IAM role. - * `transport` (*type:* `GoogleApi.Eventarc.V1.Model.Transport.t`, *default:* `nil`) - Optional. To deliver messages, Eventarc might use other GCP products as a transport intermediary. This field contains a reference to that transport intermediary. This information can be used for debugging purposes. + * `serviceAccount` (*type:* `String.t`, *default:* `nil`) - Optional. The IAM service account email associated with the trigger. The service account represents the identity of the trigger. The `iam.serviceAccounts.actAs` permission must be granted on the service account to allow a principal to impersonate the service account. For more information, see the [Roles and permissions](/eventarc/docs/all-roles-permissions) page specific to the trigger destination. + * `transport` (*type:* `GoogleApi.Eventarc.V1.Model.Transport.t`, *default:* `nil`) - Optional. To deliver messages, Eventarc might use other Google Cloud products as a transport intermediary. This field contains a reference to that transport intermediary. This information can be used for debugging purposes. * `uid` (*type:* `String.t`, *default:* `nil`) - 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. * `updateTime` (*type:* `DateTime.t`, *default:* `nil`) - Output only. The last-modified time. """ @@ -44,6 +45,7 @@ defmodule GoogleApi.Eventarc.V1.Model.Trigger do :createTime => DateTime.t() | nil, :destination => GoogleApi.Eventarc.V1.Model.Destination.t() | nil, :etag => String.t() | nil, + :eventDataContentType => String.t() | nil, :eventFilters => list(GoogleApi.Eventarc.V1.Model.EventFilter.t()) | nil, :labels => map() | nil, :name => String.t() | nil, @@ -58,6 +60,7 @@ defmodule GoogleApi.Eventarc.V1.Model.Trigger do field(:createTime, as: DateTime) field(:destination, as: GoogleApi.Eventarc.V1.Model.Destination) field(:etag) + field(:eventDataContentType) field(:eventFilters, as: GoogleApi.Eventarc.V1.Model.EventFilter, type: :list) field(:labels, type: :map) field(:name) diff --git a/clients/eventarc/lib/google_api/eventarc/v1beta1/api/projects.ex b/clients/eventarc/lib/google_api/eventarc/v1beta1/api/projects.ex index c0f729f6f6..5bfdd65588 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1beta1/api/projects.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1beta1/api/projects.ex @@ -366,7 +366,7 @@ defmodule GoogleApi.Eventarc.V1beta1.Api.Projects do end @doc """ - Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`. NOTE: the `name` binding allows API services to override the binding to use different resource name schemes, such as `users/*/operations`. To override the binding, API services can add a binding such as `"/v1/{name=users/*}/operations"` to their service configuration. For backwards compatibility, the default name includes the operations collection id, however overriding users must ensure the name binding is the parent resource, without the operations collection id. + Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`. ## Parameters diff --git a/clients/eventarc/lib/google_api/eventarc/v1beta1/metadata.ex b/clients/eventarc/lib/google_api/eventarc/v1beta1/metadata.ex index e2a50fc37b..3300181011 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1beta1/metadata.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1beta1/metadata.ex @@ -20,7 +20,7 @@ defmodule GoogleApi.Eventarc.V1beta1 do API client metadata for GoogleApi.Eventarc.V1beta1. """ - @discovery_revision "20221021" + @discovery_revision "20240229" def discovery_revision(), do: @discovery_revision end diff --git a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/binding.ex b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/binding.ex index 724161fe3c..76e656136b 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/binding.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/binding.ex @@ -22,8 +22,8 @@ defmodule GoogleApi.Eventarc.V1beta1.Model.Binding do ## Attributes * `condition` (*type:* `GoogleApi.Eventarc.V1beta1.Model.Expr.t`, *default:* `nil`) - The condition that is associated with this binding. If the condition evaluates to `true`, then this binding applies to the current request. If the condition evaluates to `false`, then this binding does not apply to the current request. However, a different role binding might grant the same role to one or more of the principals in this binding. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). - * `members` (*type:* `list(String.t)`, *default:* `nil`) - Specifies the principals requesting access for a Google Cloud resource. `members` can have the following values: * `allUsers`: A special identifier that represents anyone who is on the internet; with or without a Google account. * `allAuthenticatedUsers`: A special identifier that represents anyone who is authenticated with a Google account or a service account. Does not include identities that come from external identity providers (IdPs) through identity federation. * `user:{emailid}`: An email address that represents a specific Google account. For example, `alice@example.com` . * `serviceAccount:{emailid}`: An email address that represents a Google service account. For example, `my-other-app@appspot.gserviceaccount.com`. * `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`: An identifier for a [Kubernetes service account](https://cloud.google.com/kubernetes-engine/docs/how-to/kubernetes-service-accounts). For example, `my-project.svc.id.goog[my-namespace/my-kubernetes-sa]`. * `group:{emailid}`: An email address that represents a Google group. For example, `admins@example.com`. * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a user that has been recently deleted. For example, `alice@example.com?uid=123456789012345678901`. If the user is recovered, this value reverts to `user:{emailid}` and the recovered user retains the role in the binding. * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a service account that has been recently deleted. For example, `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`. If the service account is undeleted, this value reverts to `serviceAccount:{emailid}` and the undeleted service account retains the role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a Google group that has been recently deleted. For example, `admins@example.com?uid=123456789012345678901`. If the group is recovered, this value reverts to `group:{emailid}` and the recovered group retains the role in the binding. * `domain:{domain}`: The G Suite domain (primary) that represents all the users of that domain. For example, `google.com` or `example.com`. - * `role` (*type:* `String.t`, *default:* `nil`) - Role that is assigned to the list of `members`, or principals. For example, `roles/viewer`, `roles/editor`, or `roles/owner`. + * `members` (*type:* `list(String.t)`, *default:* `nil`) - Specifies the principals requesting access for a Google Cloud resource. `members` can have the following values: * `allUsers`: A special identifier that represents anyone who is on the internet; with or without a Google account. * `allAuthenticatedUsers`: A special identifier that represents anyone who is authenticated with a Google account or a service account. Does not include identities that come from external identity providers (IdPs) through identity federation. * `user:{emailid}`: An email address that represents a specific Google account. For example, `alice@example.com` . * `serviceAccount:{emailid}`: An email address that represents a Google service account. For example, `my-other-app@appspot.gserviceaccount.com`. * `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`: An identifier for a [Kubernetes service account](https://cloud.google.com/kubernetes-engine/docs/how-to/kubernetes-service-accounts). For example, `my-project.svc.id.goog[my-namespace/my-kubernetes-sa]`. * `group:{emailid}`: An email address that represents a Google group. For example, `admins@example.com`. * `domain:{domain}`: The G Suite domain (primary) that represents all the users of that domain. For example, `google.com` or `example.com`. * `principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workforce identity pool. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/group/{group_id}`: All workforce identities in a group. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All workforce identities with a specific attribute value. * `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/*`: All identities in a workforce identity pool. * `principal://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/subject/{subject_attribute_value}`: A single identity in a workload identity pool. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/group/{group_id}`: A workload identity pool group. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/attribute.{attribute_name}/{attribute_value}`: All identities in a workload identity pool with a certain attribute. * `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/*`: All identities in a workload identity pool. * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a user that has been recently deleted. For example, `alice@example.com?uid=123456789012345678901`. If the user is recovered, this value reverts to `user:{emailid}` and the recovered user retains the role in the binding. * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a service account that has been recently deleted. For example, `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`. If the service account is undeleted, this value reverts to `serviceAccount:{emailid}` and the undeleted service account retains the role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique identifier) representing a Google group that has been recently deleted. For example, `admins@example.com?uid=123456789012345678901`. If the group is recovered, this value reverts to `group:{emailid}` and the recovered group retains the role in the binding. * `deleted:principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`: Deleted single identity in a workforce identity pool. For example, `deleted:principal://iam.googleapis.com/locations/global/workforcePools/my-pool-id/subject/my-subject-attribute-value`. + * `role` (*type:* `String.t`, *default:* `nil`) - Role that is assigned to the list of `members`, or principals. For example, `roles/viewer`, `roles/editor`, or `roles/owner`. For an overview of the IAM roles and permissions, see the [IAM documentation](https://cloud.google.com/iam/docs/roles-overview). For a list of the available pre-defined roles, see [here](https://cloud.google.com/iam/docs/understanding-roles). """ use GoogleApi.Gax.ModelBase diff --git a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/cloud_run_service.ex b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/cloud_run_service.ex index 7639b8ccec..69db823583 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/cloud_run_service.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/cloud_run_service.ex @@ -23,7 +23,7 @@ defmodule GoogleApi.Eventarc.V1beta1.Model.CloudRunService do * `path` (*type:* `String.t`, *default:* `nil`) - Optional. The relative path on the Cloud Run service the events should be sent to. The value must conform to the definition of URI path segment (section 3.3 of RFC2396). Examples: "/route", "route", "route/subroute". * `region` (*type:* `String.t`, *default:* `nil`) - Required. The region the Cloud Run service is deployed in. - * `service` (*type:* `String.t`, *default:* `nil`) - Required. The name of the Cloud run service being addressed (see https://cloud.google.com/run/docs/reference/rest/v1/namespaces.services). Only services located in the same project of the trigger object can be addressed. + * `service` (*type:* `String.t`, *default:* `nil`) - Required. The name of the Cloud run service being addressed. See https://cloud.google.com/run/docs/reference/rest/v1/namespaces.services. Only services located in the same project of the trigger object can be addressed. """ use GoogleApi.Gax.ModelBase diff --git a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/location.ex b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/location.ex index 3209f8801f..fba7c81907 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/location.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/location.ex @@ -17,7 +17,7 @@ defmodule GoogleApi.Eventarc.V1beta1.Model.Location do @moduledoc """ - A resource that represents Google Cloud Platform location. + A resource that represents a Google Cloud location. ## Attributes diff --git a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/operation.ex b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/operation.ex index 604c833481..285fd380a7 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/operation.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/operation.ex @@ -25,7 +25,7 @@ defmodule GoogleApi.Eventarc.V1beta1.Model.Operation do * `error` (*type:* `GoogleApi.Eventarc.V1beta1.Model.Status.t`, *default:* `nil`) - The error result of the operation in case of failure or cancellation. * `metadata` (*type:* `map()`, *default:* `nil`) - Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. * `name` (*type:* `String.t`, *default:* `nil`) - The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. - * `response` (*type:* `map()`, *default:* `nil`) - The normal response of the operation in case of success. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + * `response` (*type:* `map()`, *default:* `nil`) - The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. """ use GoogleApi.Gax.ModelBase diff --git a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/policy.ex b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/policy.ex index 9b1822c082..a5e68b02ca 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/policy.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/policy.ex @@ -17,7 +17,7 @@ defmodule GoogleApi.Eventarc.V1beta1.Model.Policy do @moduledoc """ - An Identity and Access Management (IAM) policy, which specifies access controls for Google Cloud resources. A `Policy` is a collection of `bindings`. A `binding` binds one or more `members`, or principals, to a single `role`. Principals can be user accounts, service accounts, Google groups, and domains (such as G Suite). A `role` is a named list of permissions; each `role` can be an IAM predefined role or a user-created custom role. For some types of Google Cloud resources, a `binding` can also specify a `condition`, which is a logical expression that allows access to a resource only if the expression evaluates to `true`. A condition can add constraints based on attributes of the request, the resource, or both. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). **JSON example:** { "bindings": [ { "role": "roles/resourcemanager.organizationAdmin", "members": [ "user:mike@example.com", "group:admins@example.com", "domain:google.com", "serviceAccount:my-project-id@appspot.gserviceaccount.com" ] }, { "role": "roles/resourcemanager.organizationViewer", "members": [ "user:eve@example.com" ], "condition": { "title": "expirable access", "description": "Does not grant access after Sep 2020", "expression": "request.time < timestamp('2020-10-01T00:00:00.000Z')", } } ], "etag": "BwWWja0YfJA=", "version": 3 } **YAML example:** bindings: - members: - user:mike@example.com - group:admins@example.com - domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com role: roles/resourcemanager.organizationAdmin - members: - user:eve@example.com role: roles/resourcemanager.organizationViewer condition: title: expirable access description: Does not grant access after Sep 2020 expression: request.time < timestamp('2020-10-01T00:00:00.000Z') etag: BwWWja0YfJA= version: 3 For a description of IAM and its features, see the [IAM documentation](https://cloud.google.com/iam/docs/). + An Identity and Access Management (IAM) policy, which specifies access controls for Google Cloud resources. A `Policy` is a collection of `bindings`. A `binding` binds one or more `members`, or principals, to a single `role`. Principals can be user accounts, service accounts, Google groups, and domains (such as G Suite). A `role` is a named list of permissions; each `role` can be an IAM predefined role or a user-created custom role. For some types of Google Cloud resources, a `binding` can also specify a `condition`, which is a logical expression that allows access to a resource only if the expression evaluates to `true`. A condition can add constraints based on attributes of the request, the resource, or both. To learn which resources support conditions in their IAM policies, see the [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies). **JSON example:** ``` { "bindings": [ { "role": "roles/resourcemanager.organizationAdmin", "members": [ "user:mike@example.com", "group:admins@example.com", "domain:google.com", "serviceAccount:my-project-id@appspot.gserviceaccount.com" ] }, { "role": "roles/resourcemanager.organizationViewer", "members": [ "user:eve@example.com" ], "condition": { "title": "expirable access", "description": "Does not grant access after Sep 2020", "expression": "request.time < timestamp('2020-10-01T00:00:00.000Z')", } } ], "etag": "BwWWja0YfJA=", "version": 3 } ``` **YAML example:** ``` bindings: - members: - user:mike@example.com - group:admins@example.com - domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com role: roles/resourcemanager.organizationAdmin - members: - user:eve@example.com role: roles/resourcemanager.organizationViewer condition: title: expirable access description: Does not grant access after Sep 2020 expression: request.time < timestamp('2020-10-01T00:00:00.000Z') etag: BwWWja0YfJA= version: 3 ``` For a description of IAM and its features, see the [IAM documentation](https://cloud.google.com/iam/docs/). ## Attributes diff --git a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/trigger.ex b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/trigger.ex index d5c85b8a1c..316633ae28 100644 --- a/clients/eventarc/lib/google_api/eventarc/v1beta1/model/trigger.ex +++ b/clients/eventarc/lib/google_api/eventarc/v1beta1/model/trigger.ex @@ -28,7 +28,7 @@ defmodule GoogleApi.Eventarc.V1beta1.Model.Trigger do * `matchingCriteria` (*type:* `list(GoogleApi.Eventarc.V1beta1.Model.MatchingCriteria.t)`, *default:* `nil`) - Required. Unordered list. The criteria by which events are filtered. Only events that match with this criteria will be sent to the destination. * `name` (*type:* `String.t`, *default:* `nil`) - Required. The resource name of the trigger. Must be unique within the location on the project and must in `projects/{project}/locations/{location}/triggers/{trigger}` format. * `serviceAccount` (*type:* `String.t`, *default:* `nil`) - Optional. The IAM service account email associated with the trigger. The service account represents the identity of the trigger. The principal who calls this API must have `iam.serviceAccounts.actAs` permission in the service account. See https://cloud.google.com/iam/docs/understanding-service-accounts?hl=en#sa_common for more information. For Cloud Run destinations, this service account is used to generate identity tokens when invoking the service. See https://cloud.google.com/run/docs/triggering/pubsub-push#create-service-account for information on how to invoke authenticated Cloud Run services. In order to create Audit Log triggers, the service account should also have 'eventarc.events.receiveAuditLogV1Written' permission. - * `transport` (*type:* `GoogleApi.Eventarc.V1beta1.Model.Transport.t`, *default:* `nil`) - Output only. In order to deliver messages, Eventarc may use other GCP products as transport intermediary. This field contains a reference to that transport intermediary. This information can be used for debugging purposes. + * `transport` (*type:* `GoogleApi.Eventarc.V1beta1.Model.Transport.t`, *default:* `nil`) - Output only. In order to deliver messages, Eventarc may use other Google Cloud products as transport intermediary. This field contains a reference to that transport intermediary. This information can be used for debugging purposes. * `updateTime` (*type:* `DateTime.t`, *default:* `nil`) - Output only. The last-modified time. """