Class NotificationsRule.Builder

  • All Implemented Interfaces:
    NotificationsRuleOrBuilder, com.google.protobuf.Message.Builder, com.google.protobuf.MessageLite.Builder, com.google.protobuf.MessageLiteOrBuilder, com.google.protobuf.MessageOrBuilder, Cloneable
    Enclosing class:
    NotificationsRule

    public static final class NotificationsRule.Builder
    extends com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
    implements NotificationsRuleOrBuilder
     NotificationsRule defines notifications that are sent based on budget spend
     and thresholds.
     
    Protobuf type google.cloud.billing.budgets.v1.NotificationsRule
    • Method Detail

      • getDescriptor

        public static final com.google.protobuf.Descriptors.Descriptor getDescriptor()
      • internalGetFieldAccessorTable

        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable()
        Specified by:
        internalGetFieldAccessorTable in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • clear

        public NotificationsRule.Builder clear()
        Specified by:
        clear in interface com.google.protobuf.Message.Builder
        Specified by:
        clear in interface com.google.protobuf.MessageLite.Builder
        Overrides:
        clear in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • getDescriptorForType

        public com.google.protobuf.Descriptors.Descriptor getDescriptorForType()
        Specified by:
        getDescriptorForType in interface com.google.protobuf.Message.Builder
        Specified by:
        getDescriptorForType in interface com.google.protobuf.MessageOrBuilder
        Overrides:
        getDescriptorForType in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • getDefaultInstanceForType

        public NotificationsRule getDefaultInstanceForType()
        Specified by:
        getDefaultInstanceForType in interface com.google.protobuf.MessageLiteOrBuilder
        Specified by:
        getDefaultInstanceForType in interface com.google.protobuf.MessageOrBuilder
      • build

        public NotificationsRule build()
        Specified by:
        build in interface com.google.protobuf.Message.Builder
        Specified by:
        build in interface com.google.protobuf.MessageLite.Builder
      • buildPartial

        public NotificationsRule buildPartial()
        Specified by:
        buildPartial in interface com.google.protobuf.Message.Builder
        Specified by:
        buildPartial in interface com.google.protobuf.MessageLite.Builder
      • clone

        public NotificationsRule.Builder clone()
        Specified by:
        clone in interface com.google.protobuf.Message.Builder
        Specified by:
        clone in interface com.google.protobuf.MessageLite.Builder
        Overrides:
        clone in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • setField

        public NotificationsRule.Builder setField​(com.google.protobuf.Descriptors.FieldDescriptor field,
                                                  Object value)
        Specified by:
        setField in interface com.google.protobuf.Message.Builder
        Overrides:
        setField in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • clearField

        public NotificationsRule.Builder clearField​(com.google.protobuf.Descriptors.FieldDescriptor field)
        Specified by:
        clearField in interface com.google.protobuf.Message.Builder
        Overrides:
        clearField in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • clearOneof

        public NotificationsRule.Builder clearOneof​(com.google.protobuf.Descriptors.OneofDescriptor oneof)
        Specified by:
        clearOneof in interface com.google.protobuf.Message.Builder
        Overrides:
        clearOneof in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • setRepeatedField

        public NotificationsRule.Builder setRepeatedField​(com.google.protobuf.Descriptors.FieldDescriptor field,
                                                          int index,
                                                          Object value)
        Specified by:
        setRepeatedField in interface com.google.protobuf.Message.Builder
        Overrides:
        setRepeatedField in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • addRepeatedField

        public NotificationsRule.Builder addRepeatedField​(com.google.protobuf.Descriptors.FieldDescriptor field,
                                                          Object value)
        Specified by:
        addRepeatedField in interface com.google.protobuf.Message.Builder
        Overrides:
        addRepeatedField in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • mergeFrom

        public NotificationsRule.Builder mergeFrom​(com.google.protobuf.Message other)
        Specified by:
        mergeFrom in interface com.google.protobuf.Message.Builder
        Overrides:
        mergeFrom in class com.google.protobuf.AbstractMessage.Builder<NotificationsRule.Builder>
      • isInitialized

        public final boolean isInitialized()
        Specified by:
        isInitialized in interface com.google.protobuf.MessageLiteOrBuilder
        Overrides:
        isInitialized in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • mergeFrom

        public NotificationsRule.Builder mergeFrom​(com.google.protobuf.CodedInputStream input,
                                                   com.google.protobuf.ExtensionRegistryLite extensionRegistry)
                                            throws IOException
        Specified by:
        mergeFrom in interface com.google.protobuf.Message.Builder
        Specified by:
        mergeFrom in interface com.google.protobuf.MessageLite.Builder
        Overrides:
        mergeFrom in class com.google.protobuf.AbstractMessage.Builder<NotificationsRule.Builder>
        Throws:
        IOException
      • getPubsubTopic

        public String getPubsubTopic()
         Optional. The name of the Pub/Sub topic where budget-related messages are
         published, in the form `projects/{project_id}/topics/{topic_id}`. Updates
         are sent to the topic at regular intervals; the timing of the updates is
         not dependent on the [threshold rules](#thresholdrule) you've set.
        
         Note that if you want your
         [Pub/Sub JSON
         object](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format)
         to contain data for `alertThresholdExceeded`, you need at least one
         [alert threshold rule](#thresholdrule). When you set threshold rules, you
         must also enable at least one of the email notification options, either
         using the default IAM recipients or Cloud Monitoring email notification
         channels.
        
         To use Pub/Sub topics with budgets, you must do the following:
        
         1. Create the Pub/Sub topic
         before connecting it to your budget. For guidance, see
         [Manage programmatic budget alert
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
        
         2. Grant the API caller the `pubsub.topics.setIamPolicy` permission on
         the Pub/Sub topic. If not set, the API call fails with PERMISSION_DENIED.
         For additional details on Pub/Sub roles and permissions, see
         [Permissions required for this
         task](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#permissions_required_for_this_task).
         
        string pubsub_topic = 1 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getPubsubTopic in interface NotificationsRuleOrBuilder
        Returns:
        The pubsubTopic.
      • getPubsubTopicBytes

        public com.google.protobuf.ByteString getPubsubTopicBytes()
         Optional. The name of the Pub/Sub topic where budget-related messages are
         published, in the form `projects/{project_id}/topics/{topic_id}`. Updates
         are sent to the topic at regular intervals; the timing of the updates is
         not dependent on the [threshold rules](#thresholdrule) you've set.
        
         Note that if you want your
         [Pub/Sub JSON
         object](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format)
         to contain data for `alertThresholdExceeded`, you need at least one
         [alert threshold rule](#thresholdrule). When you set threshold rules, you
         must also enable at least one of the email notification options, either
         using the default IAM recipients or Cloud Monitoring email notification
         channels.
        
         To use Pub/Sub topics with budgets, you must do the following:
        
         1. Create the Pub/Sub topic
         before connecting it to your budget. For guidance, see
         [Manage programmatic budget alert
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
        
         2. Grant the API caller the `pubsub.topics.setIamPolicy` permission on
         the Pub/Sub topic. If not set, the API call fails with PERMISSION_DENIED.
         For additional details on Pub/Sub roles and permissions, see
         [Permissions required for this
         task](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#permissions_required_for_this_task).
         
        string pubsub_topic = 1 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getPubsubTopicBytes in interface NotificationsRuleOrBuilder
        Returns:
        The bytes for pubsubTopic.
      • setPubsubTopic

        public NotificationsRule.Builder setPubsubTopic​(String value)
         Optional. The name of the Pub/Sub topic where budget-related messages are
         published, in the form `projects/{project_id}/topics/{topic_id}`. Updates
         are sent to the topic at regular intervals; the timing of the updates is
         not dependent on the [threshold rules](#thresholdrule) you've set.
        
         Note that if you want your
         [Pub/Sub JSON
         object](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format)
         to contain data for `alertThresholdExceeded`, you need at least one
         [alert threshold rule](#thresholdrule). When you set threshold rules, you
         must also enable at least one of the email notification options, either
         using the default IAM recipients or Cloud Monitoring email notification
         channels.
        
         To use Pub/Sub topics with budgets, you must do the following:
        
         1. Create the Pub/Sub topic
         before connecting it to your budget. For guidance, see
         [Manage programmatic budget alert
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
        
         2. Grant the API caller the `pubsub.topics.setIamPolicy` permission on
         the Pub/Sub topic. If not set, the API call fails with PERMISSION_DENIED.
         For additional details on Pub/Sub roles and permissions, see
         [Permissions required for this
         task](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#permissions_required_for_this_task).
         
        string pubsub_topic = 1 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        value - The pubsubTopic to set.
        Returns:
        This builder for chaining.
      • clearPubsubTopic

        public NotificationsRule.Builder clearPubsubTopic()
         Optional. The name of the Pub/Sub topic where budget-related messages are
         published, in the form `projects/{project_id}/topics/{topic_id}`. Updates
         are sent to the topic at regular intervals; the timing of the updates is
         not dependent on the [threshold rules](#thresholdrule) you've set.
        
         Note that if you want your
         [Pub/Sub JSON
         object](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format)
         to contain data for `alertThresholdExceeded`, you need at least one
         [alert threshold rule](#thresholdrule). When you set threshold rules, you
         must also enable at least one of the email notification options, either
         using the default IAM recipients or Cloud Monitoring email notification
         channels.
        
         To use Pub/Sub topics with budgets, you must do the following:
        
         1. Create the Pub/Sub topic
         before connecting it to your budget. For guidance, see
         [Manage programmatic budget alert
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
        
         2. Grant the API caller the `pubsub.topics.setIamPolicy` permission on
         the Pub/Sub topic. If not set, the API call fails with PERMISSION_DENIED.
         For additional details on Pub/Sub roles and permissions, see
         [Permissions required for this
         task](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#permissions_required_for_this_task).
         
        string pubsub_topic = 1 [(.google.api.field_behavior) = OPTIONAL];
        Returns:
        This builder for chaining.
      • setPubsubTopicBytes

        public NotificationsRule.Builder setPubsubTopicBytes​(com.google.protobuf.ByteString value)
         Optional. The name of the Pub/Sub topic where budget-related messages are
         published, in the form `projects/{project_id}/topics/{topic_id}`. Updates
         are sent to the topic at regular intervals; the timing of the updates is
         not dependent on the [threshold rules](#thresholdrule) you've set.
        
         Note that if you want your
         [Pub/Sub JSON
         object](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format)
         to contain data for `alertThresholdExceeded`, you need at least one
         [alert threshold rule](#thresholdrule). When you set threshold rules, you
         must also enable at least one of the email notification options, either
         using the default IAM recipients or Cloud Monitoring email notification
         channels.
        
         To use Pub/Sub topics with budgets, you must do the following:
        
         1. Create the Pub/Sub topic
         before connecting it to your budget. For guidance, see
         [Manage programmatic budget alert
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
        
         2. Grant the API caller the `pubsub.topics.setIamPolicy` permission on
         the Pub/Sub topic. If not set, the API call fails with PERMISSION_DENIED.
         For additional details on Pub/Sub roles and permissions, see
         [Permissions required for this
         task](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#permissions_required_for_this_task).
         
        string pubsub_topic = 1 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        value - The bytes for pubsubTopic to set.
        Returns:
        This builder for chaining.
      • getSchemaVersion

        public String getSchemaVersion()
         Optional. Required when
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic]
         is set. The schema version of the notification sent to
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic].
         Only "1.0" is accepted. It represents the JSON schema as defined in
         https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format.
         
        string schema_version = 2 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getSchemaVersion in interface NotificationsRuleOrBuilder
        Returns:
        The schemaVersion.
      • getSchemaVersionBytes

        public com.google.protobuf.ByteString getSchemaVersionBytes()
         Optional. Required when
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic]
         is set. The schema version of the notification sent to
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic].
         Only "1.0" is accepted. It represents the JSON schema as defined in
         https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format.
         
        string schema_version = 2 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getSchemaVersionBytes in interface NotificationsRuleOrBuilder
        Returns:
        The bytes for schemaVersion.
      • setSchemaVersion

        public NotificationsRule.Builder setSchemaVersion​(String value)
         Optional. Required when
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic]
         is set. The schema version of the notification sent to
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic].
         Only "1.0" is accepted. It represents the JSON schema as defined in
         https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format.
         
        string schema_version = 2 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        value - The schemaVersion to set.
        Returns:
        This builder for chaining.
      • clearSchemaVersion

        public NotificationsRule.Builder clearSchemaVersion()
         Optional. Required when
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic]
         is set. The schema version of the notification sent to
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic].
         Only "1.0" is accepted. It represents the JSON schema as defined in
         https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format.
         
        string schema_version = 2 [(.google.api.field_behavior) = OPTIONAL];
        Returns:
        This builder for chaining.
      • setSchemaVersionBytes

        public NotificationsRule.Builder setSchemaVersionBytes​(com.google.protobuf.ByteString value)
         Optional. Required when
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic]
         is set. The schema version of the notification sent to
         [NotificationsRule.pubsub_topic][google.cloud.billing.budgets.v1.NotificationsRule.pubsub_topic].
         Only "1.0" is accepted. It represents the JSON schema as defined in
         https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications#notification_format.
         
        string schema_version = 2 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        value - The bytes for schemaVersion to set.
        Returns:
        This builder for chaining.
      • getMonitoringNotificationChannelsList

        public com.google.protobuf.ProtocolStringList getMonitoringNotificationChannelsList()
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getMonitoringNotificationChannelsList in interface NotificationsRuleOrBuilder
        Returns:
        A list containing the monitoringNotificationChannels.
      • getMonitoringNotificationChannelsCount

        public int getMonitoringNotificationChannelsCount()
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getMonitoringNotificationChannelsCount in interface NotificationsRuleOrBuilder
        Returns:
        The count of monitoringNotificationChannels.
      • getMonitoringNotificationChannels

        public String getMonitoringNotificationChannels​(int index)
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getMonitoringNotificationChannels in interface NotificationsRuleOrBuilder
        Parameters:
        index - The index of the element to return.
        Returns:
        The monitoringNotificationChannels at the given index.
      • getMonitoringNotificationChannelsBytes

        public com.google.protobuf.ByteString getMonitoringNotificationChannelsBytes​(int index)
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getMonitoringNotificationChannelsBytes in interface NotificationsRuleOrBuilder
        Parameters:
        index - The index of the value to return.
        Returns:
        The bytes of the monitoringNotificationChannels at the given index.
      • setMonitoringNotificationChannels

        public NotificationsRule.Builder setMonitoringNotificationChannels​(int index,
                                                                           String value)
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        index - The index to set the value at.
        value - The monitoringNotificationChannels to set.
        Returns:
        This builder for chaining.
      • addMonitoringNotificationChannels

        public NotificationsRule.Builder addMonitoringNotificationChannels​(String value)
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        value - The monitoringNotificationChannels to add.
        Returns:
        This builder for chaining.
      • addAllMonitoringNotificationChannels

        public NotificationsRule.Builder addAllMonitoringNotificationChannels​(Iterable<String> values)
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        values - The monitoringNotificationChannels to add.
        Returns:
        This builder for chaining.
      • clearMonitoringNotificationChannels

        public NotificationsRule.Builder clearMonitoringNotificationChannels()
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Returns:
        This builder for chaining.
      • addMonitoringNotificationChannelsBytes

        public NotificationsRule.Builder addMonitoringNotificationChannelsBytes​(com.google.protobuf.ByteString value)
         Optional. Email targets to send notifications to when a threshold is
         exceeded. This is in addition to the `DefaultIamRecipients` who receive
         alert emails based on their billing account IAM role. The value is the full
         REST resource name of a Cloud Monitoring email notification channel with
         the form `projects/{project_id}/notificationChannels/{channel_id}`. A
         maximum of 5 email notifications are allowed.
        
         To customize budget alert email recipients with monitoring notification
         channels, you _must create the monitoring notification channels before
         you link them to a budget_. For guidance on setting up notification
         channels to use with budgets, see
         [Customize budget alert email
         recipients](https://cloud.google.com/billing/docs/how-to/budgets-notification-recipients).
        
         For Cloud Billing budget alerts, you _must use email notification
         channels_. The other types of notification channels are _not_
         supported, such as Slack, SMS, or PagerDuty. If you want to
         [send budget notifications to
         Slack](https://cloud.google.com/billing/docs/how-to/notify#send_notifications_to_slack),
         use a pubsubTopic and configure
         [programmatic
         notifications](https://cloud.google.com/billing/docs/how-to/budgets-programmatic-notifications).
         
        repeated string monitoring_notification_channels = 3 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        value - The bytes of the monitoringNotificationChannels to add.
        Returns:
        This builder for chaining.
      • getDisableDefaultIamRecipients

        public boolean getDisableDefaultIamRecipients()
         Optional. When set to true, disables default notifications sent when a
         threshold is exceeded. Default notifications are sent to those with Billing
         Account Administrator and Billing Account User IAM roles for the target
         account.
         
        bool disable_default_iam_recipients = 4 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getDisableDefaultIamRecipients in interface NotificationsRuleOrBuilder
        Returns:
        The disableDefaultIamRecipients.
      • setDisableDefaultIamRecipients

        public NotificationsRule.Builder setDisableDefaultIamRecipients​(boolean value)
         Optional. When set to true, disables default notifications sent when a
         threshold is exceeded. Default notifications are sent to those with Billing
         Account Administrator and Billing Account User IAM roles for the target
         account.
         
        bool disable_default_iam_recipients = 4 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        value - The disableDefaultIamRecipients to set.
        Returns:
        This builder for chaining.
      • clearDisableDefaultIamRecipients

        public NotificationsRule.Builder clearDisableDefaultIamRecipients()
         Optional. When set to true, disables default notifications sent when a
         threshold is exceeded. Default notifications are sent to those with Billing
         Account Administrator and Billing Account User IAM roles for the target
         account.
         
        bool disable_default_iam_recipients = 4 [(.google.api.field_behavior) = OPTIONAL];
        Returns:
        This builder for chaining.
      • getEnableProjectLevelRecipients

        public boolean getEnableProjectLevelRecipients()
         Optional. When set to true, and when the budget has a single project
         configured, notifications will be sent to project level recipients of that
         project. This field will be ignored if the budget has multiple or no
         project configured.
        
         Currently, project level recipients are the users with `Owner` role on a
         cloud project.
         
        bool enable_project_level_recipients = 5 [(.google.api.field_behavior) = OPTIONAL];
        Specified by:
        getEnableProjectLevelRecipients in interface NotificationsRuleOrBuilder
        Returns:
        The enableProjectLevelRecipients.
      • setEnableProjectLevelRecipients

        public NotificationsRule.Builder setEnableProjectLevelRecipients​(boolean value)
         Optional. When set to true, and when the budget has a single project
         configured, notifications will be sent to project level recipients of that
         project. This field will be ignored if the budget has multiple or no
         project configured.
        
         Currently, project level recipients are the users with `Owner` role on a
         cloud project.
         
        bool enable_project_level_recipients = 5 [(.google.api.field_behavior) = OPTIONAL];
        Parameters:
        value - The enableProjectLevelRecipients to set.
        Returns:
        This builder for chaining.
      • clearEnableProjectLevelRecipients

        public NotificationsRule.Builder clearEnableProjectLevelRecipients()
         Optional. When set to true, and when the budget has a single project
         configured, notifications will be sent to project level recipients of that
         project. This field will be ignored if the budget has multiple or no
         project configured.
        
         Currently, project level recipients are the users with `Owner` role on a
         cloud project.
         
        bool enable_project_level_recipients = 5 [(.google.api.field_behavior) = OPTIONAL];
        Returns:
        This builder for chaining.
      • setUnknownFields

        public final NotificationsRule.Builder setUnknownFields​(com.google.protobuf.UnknownFieldSet unknownFields)
        Specified by:
        setUnknownFields in interface com.google.protobuf.Message.Builder
        Overrides:
        setUnknownFields in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>
      • mergeUnknownFields

        public final NotificationsRule.Builder mergeUnknownFields​(com.google.protobuf.UnknownFieldSet unknownFields)
        Specified by:
        mergeUnknownFields in interface com.google.protobuf.Message.Builder
        Overrides:
        mergeUnknownFields in class com.google.protobuf.GeneratedMessageV3.Builder<NotificationsRule.Builder>