/*
 * Copyright 2020 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
 *
 *     https://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.
 */
// Generated by the protocol buffer compiler.  DO NOT EDIT!
// source: google/cloud/securitycenter/v1/mute_config.proto

package com.google.cloud.securitycenter.v1;

public interface MuteConfigOrBuilder
    extends
    // @@protoc_insertion_point(interface_extends:google.cloud.securitycenter.v1.MuteConfig)
    com.google.protobuf.MessageOrBuilder {

  /**
   *
   *
   * <pre>
   * This field will be ignored if provided on config creation. Format
   * "organizations/{organization}/muteConfigs/{mute_config}"
   * "folders/{folder}/muteConfigs/{mute_config}"
   * "projects/{project}/muteConfigs/{mute_config}"
   * </pre>
   *
   * <code>string name = 1;</code>
   *
   * @return The name.
   */
  java.lang.String getName();
  /**
   *
   *
   * <pre>
   * This field will be ignored if provided on config creation. Format
   * "organizations/{organization}/muteConfigs/{mute_config}"
   * "folders/{folder}/muteConfigs/{mute_config}"
   * "projects/{project}/muteConfigs/{mute_config}"
   * </pre>
   *
   * <code>string name = 1;</code>
   *
   * @return The bytes for name.
   */
  com.google.protobuf.ByteString getNameBytes();

  /**
   *
   *
   * <pre>
   * The human readable name to be displayed for the mute config.
   * </pre>
   *
   * <code>string display_name = 2 [deprecated = true];</code>
   *
   * @deprecated google.cloud.securitycenter.v1.MuteConfig.display_name is deprecated. See
   *     google/cloud/securitycenter/v1/mute_config.proto;l=47
   * @return The displayName.
   */
  @java.lang.Deprecated
  java.lang.String getDisplayName();
  /**
   *
   *
   * <pre>
   * The human readable name to be displayed for the mute config.
   * </pre>
   *
   * <code>string display_name = 2 [deprecated = true];</code>
   *
   * @deprecated google.cloud.securitycenter.v1.MuteConfig.display_name is deprecated. See
   *     google/cloud/securitycenter/v1/mute_config.proto;l=47
   * @return The bytes for displayName.
   */
  @java.lang.Deprecated
  com.google.protobuf.ByteString getDisplayNameBytes();

  /**
   *
   *
   * <pre>
   * A description of the mute config.
   * </pre>
   *
   * <code>string description = 3;</code>
   *
   * @return The description.
   */
  java.lang.String getDescription();
  /**
   *
   *
   * <pre>
   * A description of the mute config.
   * </pre>
   *
   * <code>string description = 3;</code>
   *
   * @return The bytes for description.
   */
  com.google.protobuf.ByteString getDescriptionBytes();

  /**
   *
   *
   * <pre>
   * Required. An expression that defines the filter to apply across
   * create/update events of findings. While creating a filter string, be
   * mindful of the scope in which the mute configuration is being created.
   * E.g., If a filter contains project = X but is created under the project = Y
   * scope, it might not match any findings.
   * The following field and operator combinations are supported:
   * * severity: `=`, `:`
   * * category: `=`, `:`
   * * resource.name: `=`, `:`
   * * resource.project_name: `=`, `:`
   * * resource.project_display_name: `=`, `:`
   * * resource.folders.resource_folder: `=`, `:`
   * * resource.parent_name: `=`, `:`
   * * resource.parent_display_name: `=`, `:`
   * * resource.type: `=`, `:`
   * * finding_class: `=`, `:`
   * * indicator.ip_addresses: `=`, `:`
   * * indicator.domains: `=`, `:`
   * </pre>
   *
   * <code>string filter = 4 [(.google.api.field_behavior) = REQUIRED];</code>
   *
   * @return The filter.
   */
  java.lang.String getFilter();
  /**
   *
   *
   * <pre>
   * Required. An expression that defines the filter to apply across
   * create/update events of findings. While creating a filter string, be
   * mindful of the scope in which the mute configuration is being created.
   * E.g., If a filter contains project = X but is created under the project = Y
   * scope, it might not match any findings.
   * The following field and operator combinations are supported:
   * * severity: `=`, `:`
   * * category: `=`, `:`
   * * resource.name: `=`, `:`
   * * resource.project_name: `=`, `:`
   * * resource.project_display_name: `=`, `:`
   * * resource.folders.resource_folder: `=`, `:`
   * * resource.parent_name: `=`, `:`
   * * resource.parent_display_name: `=`, `:`
   * * resource.type: `=`, `:`
   * * finding_class: `=`, `:`
   * * indicator.ip_addresses: `=`, `:`
   * * indicator.domains: `=`, `:`
   * </pre>
   *
   * <code>string filter = 4 [(.google.api.field_behavior) = REQUIRED];</code>
   *
   * @return The bytes for filter.
   */
  com.google.protobuf.ByteString getFilterBytes();

  /**
   *
   *
   * <pre>
   * Output only. The time at which the mute config was created.
   * This field is set by the server and will be ignored if provided on config
   * creation.
   * </pre>
   *
   * <code>.google.protobuf.Timestamp create_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY];
   * </code>
   *
   * @return Whether the createTime field is set.
   */
  boolean hasCreateTime();
  /**
   *
   *
   * <pre>
   * Output only. The time at which the mute config was created.
   * This field is set by the server and will be ignored if provided on config
   * creation.
   * </pre>
   *
   * <code>.google.protobuf.Timestamp create_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY];
   * </code>
   *
   * @return The createTime.
   */
  com.google.protobuf.Timestamp getCreateTime();
  /**
   *
   *
   * <pre>
   * Output only. The time at which the mute config was created.
   * This field is set by the server and will be ignored if provided on config
   * creation.
   * </pre>
   *
   * <code>.google.protobuf.Timestamp create_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY];
   * </code>
   */
  com.google.protobuf.TimestampOrBuilder getCreateTimeOrBuilder();

  /**
   *
   *
   * <pre>
   * Output only. The most recent time at which the mute config was updated.
   * This field is set by the server and will be ignored if provided on config
   * creation or update.
   * </pre>
   *
   * <code>.google.protobuf.Timestamp update_time = 6 [(.google.api.field_behavior) = OUTPUT_ONLY];
   * </code>
   *
   * @return Whether the updateTime field is set.
   */
  boolean hasUpdateTime();
  /**
   *
   *
   * <pre>
   * Output only. The most recent time at which the mute config was updated.
   * This field is set by the server and will be ignored if provided on config
   * creation or update.
   * </pre>
   *
   * <code>.google.protobuf.Timestamp update_time = 6 [(.google.api.field_behavior) = OUTPUT_ONLY];
   * </code>
   *
   * @return The updateTime.
   */
  com.google.protobuf.Timestamp getUpdateTime();
  /**
   *
   *
   * <pre>
   * Output only. The most recent time at which the mute config was updated.
   * This field is set by the server and will be ignored if provided on config
   * creation or update.
   * </pre>
   *
   * <code>.google.protobuf.Timestamp update_time = 6 [(.google.api.field_behavior) = OUTPUT_ONLY];
   * </code>
   */
  com.google.protobuf.TimestampOrBuilder getUpdateTimeOrBuilder();

  /**
   *
   *
   * <pre>
   * Output only. Email address of the user who last edited the mute config.
   * This field is set by the server and will be ignored if provided on config
   * creation or update.
   * </pre>
   *
   * <code>string most_recent_editor = 7 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
   *
   * @return The mostRecentEditor.
   */
  java.lang.String getMostRecentEditor();
  /**
   *
   *
   * <pre>
   * Output only. Email address of the user who last edited the mute config.
   * This field is set by the server and will be ignored if provided on config
   * creation or update.
   * </pre>
   *
   * <code>string most_recent_editor = 7 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
   *
   * @return The bytes for mostRecentEditor.
   */
  com.google.protobuf.ByteString getMostRecentEditorBytes();
}
