All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.cloud.securitycenter.v2.MuteConfig Maven / Gradle / Ivy

There is a newer version: 2.62.0
Show newest version
/*
 * Copyright 2024 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/v2/mute_config.proto

// Protobuf Java Version: 3.25.5
package com.google.cloud.securitycenter.v2;

/**
 *
 *
 * 
 * A mute config is a Cloud SCC resource that contains the configuration
 * to mute create/update events of findings.
 * 
* * Protobuf type {@code google.cloud.securitycenter.v2.MuteConfig} */ public final class MuteConfig extends com.google.protobuf.GeneratedMessageV3 implements // @@protoc_insertion_point(message_implements:google.cloud.securitycenter.v2.MuteConfig) MuteConfigOrBuilder { private static final long serialVersionUID = 0L; // Use MuteConfig.newBuilder() to construct. private MuteConfig(com.google.protobuf.GeneratedMessageV3.Builder builder) { super(builder); } private MuteConfig() { name_ = ""; description_ = ""; filter_ = ""; mostRecentEditor_ = ""; type_ = 0; } @java.lang.Override @SuppressWarnings({"unused"}) protected java.lang.Object newInstance(UnusedPrivateParameter unused) { return new MuteConfig(); } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.cloud.securitycenter.v2.MuteConfigProto .internal_static_google_cloud_securitycenter_v2_MuteConfig_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.cloud.securitycenter.v2.MuteConfigProto .internal_static_google_cloud_securitycenter_v2_MuteConfig_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.cloud.securitycenter.v2.MuteConfig.class, com.google.cloud.securitycenter.v2.MuteConfig.Builder.class); } /** * * *
   * The type of MuteConfig.
   * 
* * Protobuf enum {@code google.cloud.securitycenter.v2.MuteConfig.MuteConfigType} */ public enum MuteConfigType implements com.google.protobuf.ProtocolMessageEnum { /** * * *
     * Unused.
     * 
* * MUTE_CONFIG_TYPE_UNSPECIFIED = 0; */ MUTE_CONFIG_TYPE_UNSPECIFIED(0), /** * * *
     * A static mute config, which sets the static mute state of future matching
     * findings to muted. Once the static mute state has been set, finding or
     * config modifications will not affect the state.
     * 
* * STATIC = 1; */ STATIC(1), /** * * *
     * A dynamic mute config, which is applied to existing and future matching
     * findings, setting their dynamic mute state to "muted". If the config is
     * updated or deleted, or a matching finding is updated, such that the
     * finding doesn't match the config, the config will be removed from the
     * finding, and the finding's dynamic mute state may become "unmuted"
     * (unless other configs still match).
     * 
* * DYNAMIC = 2; */ DYNAMIC(2), UNRECOGNIZED(-1), ; /** * * *
     * Unused.
     * 
* * MUTE_CONFIG_TYPE_UNSPECIFIED = 0; */ public static final int MUTE_CONFIG_TYPE_UNSPECIFIED_VALUE = 0; /** * * *
     * A static mute config, which sets the static mute state of future matching
     * findings to muted. Once the static mute state has been set, finding or
     * config modifications will not affect the state.
     * 
* * STATIC = 1; */ public static final int STATIC_VALUE = 1; /** * * *
     * A dynamic mute config, which is applied to existing and future matching
     * findings, setting their dynamic mute state to "muted". If the config is
     * updated or deleted, or a matching finding is updated, such that the
     * finding doesn't match the config, the config will be removed from the
     * finding, and the finding's dynamic mute state may become "unmuted"
     * (unless other configs still match).
     * 
* * DYNAMIC = 2; */ public static final int DYNAMIC_VALUE = 2; public final int getNumber() { if (this == UNRECOGNIZED) { throw new java.lang.IllegalArgumentException( "Can't get the number of an unknown enum value."); } return value; } /** * @param value The numeric wire value of the corresponding enum entry. * @return The enum associated with the given numeric wire value. * @deprecated Use {@link #forNumber(int)} instead. */ @java.lang.Deprecated public static MuteConfigType valueOf(int value) { return forNumber(value); } /** * @param value The numeric wire value of the corresponding enum entry. * @return The enum associated with the given numeric wire value. */ public static MuteConfigType forNumber(int value) { switch (value) { case 0: return MUTE_CONFIG_TYPE_UNSPECIFIED; case 1: return STATIC; case 2: return DYNAMIC; default: return null; } } public static com.google.protobuf.Internal.EnumLiteMap internalGetValueMap() { return internalValueMap; } private static final com.google.protobuf.Internal.EnumLiteMap internalValueMap = new com.google.protobuf.Internal.EnumLiteMap() { public MuteConfigType findValueByNumber(int number) { return MuteConfigType.forNumber(number); } }; public final com.google.protobuf.Descriptors.EnumValueDescriptor getValueDescriptor() { if (this == UNRECOGNIZED) { throw new java.lang.IllegalStateException( "Can't get the descriptor of an unrecognized enum value."); } return getDescriptor().getValues().get(ordinal()); } public final com.google.protobuf.Descriptors.EnumDescriptor getDescriptorForType() { return getDescriptor(); } public static final com.google.protobuf.Descriptors.EnumDescriptor getDescriptor() { return com.google.cloud.securitycenter.v2.MuteConfig.getDescriptor().getEnumTypes().get(0); } private static final MuteConfigType[] VALUES = values(); public static MuteConfigType valueOf(com.google.protobuf.Descriptors.EnumValueDescriptor desc) { if (desc.getType() != getDescriptor()) { throw new java.lang.IllegalArgumentException("EnumValueDescriptor is not for this type."); } if (desc.getIndex() == -1) { return UNRECOGNIZED; } return VALUES[desc.getIndex()]; } private final int value; private MuteConfigType(int value) { this.value = value; } // @@protoc_insertion_point(enum_scope:google.cloud.securitycenter.v2.MuteConfig.MuteConfigType) } private int bitField0_; public static final int NAME_FIELD_NUMBER = 1; @SuppressWarnings("serial") private volatile java.lang.Object name_ = ""; /** * * *
   * Identifier. This field will be ignored if provided on config creation. The
   * following list shows some examples of the format:
   *
   * + `organizations/{organization}/muteConfigs/{mute_config}`
   * +
   * `organizations/{organization}locations/{location}//muteConfigs/{mute_config}`
   * + `folders/{folder}/muteConfigs/{mute_config}`
   * + `folders/{folder}/locations/{location}/muteConfigs/{mute_config}`
   * + `projects/{project}/muteConfigs/{mute_config}`
   * + `projects/{project}/locations/{location}/muteConfigs/{mute_config}`
   * 
* * string name = 1 [(.google.api.field_behavior) = IDENTIFIER]; * * @return The name. */ @java.lang.Override public java.lang.String getName() { java.lang.Object ref = name_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); name_ = s; return s; } } /** * * *
   * Identifier. This field will be ignored if provided on config creation. The
   * following list shows some examples of the format:
   *
   * + `organizations/{organization}/muteConfigs/{mute_config}`
   * +
   * `organizations/{organization}locations/{location}//muteConfigs/{mute_config}`
   * + `folders/{folder}/muteConfigs/{mute_config}`
   * + `folders/{folder}/locations/{location}/muteConfigs/{mute_config}`
   * + `projects/{project}/muteConfigs/{mute_config}`
   * + `projects/{project}/locations/{location}/muteConfigs/{mute_config}`
   * 
* * string name = 1 [(.google.api.field_behavior) = IDENTIFIER]; * * @return The bytes for name. */ @java.lang.Override public com.google.protobuf.ByteString getNameBytes() { java.lang.Object ref = name_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); name_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int DESCRIPTION_FIELD_NUMBER = 2; @SuppressWarnings("serial") private volatile java.lang.Object description_ = ""; /** * * *
   * A description of the mute config.
   * 
* * string description = 2; * * @return The description. */ @java.lang.Override public java.lang.String getDescription() { java.lang.Object ref = description_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); description_ = s; return s; } } /** * * *
   * A description of the mute config.
   * 
* * string description = 2; * * @return The bytes for description. */ @java.lang.Override public com.google.protobuf.ByteString getDescriptionBytes() { java.lang.Object ref = description_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); description_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int FILTER_FIELD_NUMBER = 3; @SuppressWarnings("serial") private volatile java.lang.Object filter_ = ""; /** * * *
   * 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: `=`, `:`
   * 
* * string filter = 3 [(.google.api.field_behavior) = REQUIRED]; * * @return The filter. */ @java.lang.Override public java.lang.String getFilter() { java.lang.Object ref = filter_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); filter_ = s; return s; } } /** * * *
   * 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: `=`, `:`
   * 
* * string filter = 3 [(.google.api.field_behavior) = REQUIRED]; * * @return The bytes for filter. */ @java.lang.Override public com.google.protobuf.ByteString getFilterBytes() { java.lang.Object ref = filter_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); filter_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int CREATE_TIME_FIELD_NUMBER = 4; private com.google.protobuf.Timestamp createTime_; /** * * *
   * 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.
   * 
* * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * * @return Whether the createTime field is set. */ @java.lang.Override public boolean hasCreateTime() { return ((bitField0_ & 0x00000001) != 0); } /** * * *
   * 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.
   * 
* * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * * @return The createTime. */ @java.lang.Override public com.google.protobuf.Timestamp getCreateTime() { return createTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : createTime_; } /** * * *
   * 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.
   * 
* * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ @java.lang.Override public com.google.protobuf.TimestampOrBuilder getCreateTimeOrBuilder() { return createTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : createTime_; } public static final int UPDATE_TIME_FIELD_NUMBER = 5; private com.google.protobuf.Timestamp updateTime_; /** * * *
   * 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.
   * 
* * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * * @return Whether the updateTime field is set. */ @java.lang.Override public boolean hasUpdateTime() { return ((bitField0_ & 0x00000002) != 0); } /** * * *
   * 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.
   * 
* * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * * @return The updateTime. */ @java.lang.Override public com.google.protobuf.Timestamp getUpdateTime() { return updateTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : updateTime_; } /** * * *
   * 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.
   * 
* * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ @java.lang.Override public com.google.protobuf.TimestampOrBuilder getUpdateTimeOrBuilder() { return updateTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : updateTime_; } public static final int MOST_RECENT_EDITOR_FIELD_NUMBER = 6; @SuppressWarnings("serial") private volatile java.lang.Object mostRecentEditor_ = ""; /** * * *
   * 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.
   * 
* * string most_recent_editor = 6 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * @return The mostRecentEditor. */ @java.lang.Override public java.lang.String getMostRecentEditor() { java.lang.Object ref = mostRecentEditor_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); mostRecentEditor_ = s; return s; } } /** * * *
   * 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.
   * 
* * string most_recent_editor = 6 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * @return The bytes for mostRecentEditor. */ @java.lang.Override public com.google.protobuf.ByteString getMostRecentEditorBytes() { java.lang.Object ref = mostRecentEditor_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); mostRecentEditor_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int TYPE_FIELD_NUMBER = 8; private int type_ = 0; /** * * *
   * Required. The type of the mute config, which determines what type of mute
   * state the config affects. Immutable after creation.
   * 
* * * .google.cloud.securitycenter.v2.MuteConfig.MuteConfigType type = 8 [(.google.api.field_behavior) = REQUIRED]; * * * @return The enum numeric value on the wire for type. */ @java.lang.Override public int getTypeValue() { return type_; } /** * * *
   * Required. The type of the mute config, which determines what type of mute
   * state the config affects. Immutable after creation.
   * 
* * * .google.cloud.securitycenter.v2.MuteConfig.MuteConfigType type = 8 [(.google.api.field_behavior) = REQUIRED]; * * * @return The type. */ @java.lang.Override public com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType getType() { com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType result = com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType.forNumber(type_); return result == null ? com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType.UNRECOGNIZED : result; } public static final int EXPIRY_TIME_FIELD_NUMBER = 9; private com.google.protobuf.Timestamp expiryTime_; /** * * *
   * Optional. The expiry of the mute config. Only applicable for dynamic
   * configs. If the expiry is set, when the config expires, it is removed from
   * all findings.
   * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * * * @return Whether the expiryTime field is set. */ @java.lang.Override public boolean hasExpiryTime() { return ((bitField0_ & 0x00000004) != 0); } /** * * *
   * Optional. The expiry of the mute config. Only applicable for dynamic
   * configs. If the expiry is set, when the config expires, it is removed from
   * all findings.
   * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * * * @return The expiryTime. */ @java.lang.Override public com.google.protobuf.Timestamp getExpiryTime() { return expiryTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : expiryTime_; } /** * * *
   * Optional. The expiry of the mute config. Only applicable for dynamic
   * configs. If the expiry is set, when the config expires, it is removed from
   * all findings.
   * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * */ @java.lang.Override public com.google.protobuf.TimestampOrBuilder getExpiryTimeOrBuilder() { return expiryTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : expiryTime_; } private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { byte isInitialized = memoizedIsInitialized; if (isInitialized == 1) return true; if (isInitialized == 0) return false; memoizedIsInitialized = 1; return true; } @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 1, name_); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(description_)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 2, description_); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(filter_)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 3, filter_); } if (((bitField0_ & 0x00000001) != 0)) { output.writeMessage(4, getCreateTime()); } if (((bitField0_ & 0x00000002) != 0)) { output.writeMessage(5, getUpdateTime()); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(mostRecentEditor_)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 6, mostRecentEditor_); } if (type_ != com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType.MUTE_CONFIG_TYPE_UNSPECIFIED .getNumber()) { output.writeEnum(8, type_); } if (((bitField0_ & 0x00000004) != 0)) { output.writeMessage(9, getExpiryTime()); } getUnknownFields().writeTo(output); } @java.lang.Override public int getSerializedSize() { int size = memoizedSize; if (size != -1) return size; size = 0; if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, name_); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(description_)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(2, description_); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(filter_)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(3, filter_); } if (((bitField0_ & 0x00000001) != 0)) { size += com.google.protobuf.CodedOutputStream.computeMessageSize(4, getCreateTime()); } if (((bitField0_ & 0x00000002) != 0)) { size += com.google.protobuf.CodedOutputStream.computeMessageSize(5, getUpdateTime()); } if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(mostRecentEditor_)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(6, mostRecentEditor_); } if (type_ != com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType.MUTE_CONFIG_TYPE_UNSPECIFIED .getNumber()) { size += com.google.protobuf.CodedOutputStream.computeEnumSize(8, type_); } if (((bitField0_ & 0x00000004) != 0)) { size += com.google.protobuf.CodedOutputStream.computeMessageSize(9, getExpiryTime()); } size += getUnknownFields().getSerializedSize(); memoizedSize = size; return size; } @java.lang.Override public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } if (!(obj instanceof com.google.cloud.securitycenter.v2.MuteConfig)) { return super.equals(obj); } com.google.cloud.securitycenter.v2.MuteConfig other = (com.google.cloud.securitycenter.v2.MuteConfig) obj; if (!getName().equals(other.getName())) return false; if (!getDescription().equals(other.getDescription())) return false; if (!getFilter().equals(other.getFilter())) return false; if (hasCreateTime() != other.hasCreateTime()) return false; if (hasCreateTime()) { if (!getCreateTime().equals(other.getCreateTime())) return false; } if (hasUpdateTime() != other.hasUpdateTime()) return false; if (hasUpdateTime()) { if (!getUpdateTime().equals(other.getUpdateTime())) return false; } if (!getMostRecentEditor().equals(other.getMostRecentEditor())) return false; if (type_ != other.type_) return false; if (hasExpiryTime() != other.hasExpiryTime()) return false; if (hasExpiryTime()) { if (!getExpiryTime().equals(other.getExpiryTime())) return false; } if (!getUnknownFields().equals(other.getUnknownFields())) return false; return true; } @java.lang.Override public int hashCode() { if (memoizedHashCode != 0) { return memoizedHashCode; } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); hash = (37 * hash) + NAME_FIELD_NUMBER; hash = (53 * hash) + getName().hashCode(); hash = (37 * hash) + DESCRIPTION_FIELD_NUMBER; hash = (53 * hash) + getDescription().hashCode(); hash = (37 * hash) + FILTER_FIELD_NUMBER; hash = (53 * hash) + getFilter().hashCode(); if (hasCreateTime()) { hash = (37 * hash) + CREATE_TIME_FIELD_NUMBER; hash = (53 * hash) + getCreateTime().hashCode(); } if (hasUpdateTime()) { hash = (37 * hash) + UPDATE_TIME_FIELD_NUMBER; hash = (53 * hash) + getUpdateTime().hashCode(); } hash = (37 * hash) + MOST_RECENT_EDITOR_FIELD_NUMBER; hash = (53 * hash) + getMostRecentEditor().hashCode(); hash = (37 * hash) + TYPE_FIELD_NUMBER; hash = (53 * hash) + type_; if (hasExpiryTime()) { hash = (37 * hash) + EXPIRY_TIME_FIELD_NUMBER; hash = (53 * hash) + getExpiryTime().hashCode(); } hash = (29 * hash) + getUnknownFields().hashCode(); memoizedHashCode = hash; return hash; } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom(java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseWithIOException(PARSER, input); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseWithIOException( PARSER, input, extensionRegistry); } public static com.google.cloud.securitycenter.v2.MuteConfig parseDelimitedFrom( java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseDelimitedWithIOException(PARSER, input); } public static com.google.cloud.securitycenter.v2.MuteConfig parseDelimitedFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseDelimitedWithIOException( PARSER, input, extensionRegistry); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseWithIOException(PARSER, input); } public static com.google.cloud.securitycenter.v2.MuteConfig parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3.parseWithIOException( PARSER, input, extensionRegistry); } @java.lang.Override public Builder newBuilderForType() { return newBuilder(); } public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } public static Builder newBuilder(com.google.cloud.securitycenter.v2.MuteConfig prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override public Builder toBuilder() { return this == DEFAULT_INSTANCE ? new Builder() : new Builder().mergeFrom(this); } @java.lang.Override protected Builder newBuilderForType(com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { Builder builder = new Builder(parent); return builder; } /** * * *
   * A mute config is a Cloud SCC resource that contains the configuration
   * to mute create/update events of findings.
   * 
* * Protobuf type {@code google.cloud.securitycenter.v2.MuteConfig} */ public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements // @@protoc_insertion_point(builder_implements:google.cloud.securitycenter.v2.MuteConfig) com.google.cloud.securitycenter.v2.MuteConfigOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.cloud.securitycenter.v2.MuteConfigProto .internal_static_google_cloud_securitycenter_v2_MuteConfig_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.cloud.securitycenter.v2.MuteConfigProto .internal_static_google_cloud_securitycenter_v2_MuteConfig_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.cloud.securitycenter.v2.MuteConfig.class, com.google.cloud.securitycenter.v2.MuteConfig.Builder.class); } // Construct using com.google.cloud.securitycenter.v2.MuteConfig.newBuilder() private Builder() { maybeForceBuilderInitialization(); } private Builder(com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { super(parent); maybeForceBuilderInitialization(); } private void maybeForceBuilderInitialization() { if (com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders) { getCreateTimeFieldBuilder(); getUpdateTimeFieldBuilder(); getExpiryTimeFieldBuilder(); } } @java.lang.Override public Builder clear() { super.clear(); bitField0_ = 0; name_ = ""; description_ = ""; filter_ = ""; createTime_ = null; if (createTimeBuilder_ != null) { createTimeBuilder_.dispose(); createTimeBuilder_ = null; } updateTime_ = null; if (updateTimeBuilder_ != null) { updateTimeBuilder_.dispose(); updateTimeBuilder_ = null; } mostRecentEditor_ = ""; type_ = 0; expiryTime_ = null; if (expiryTimeBuilder_ != null) { expiryTimeBuilder_.dispose(); expiryTimeBuilder_ = null; } return this; } @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { return com.google.cloud.securitycenter.v2.MuteConfigProto .internal_static_google_cloud_securitycenter_v2_MuteConfig_descriptor; } @java.lang.Override public com.google.cloud.securitycenter.v2.MuteConfig getDefaultInstanceForType() { return com.google.cloud.securitycenter.v2.MuteConfig.getDefaultInstance(); } @java.lang.Override public com.google.cloud.securitycenter.v2.MuteConfig build() { com.google.cloud.securitycenter.v2.MuteConfig result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } return result; } @java.lang.Override public com.google.cloud.securitycenter.v2.MuteConfig buildPartial() { com.google.cloud.securitycenter.v2.MuteConfig result = new com.google.cloud.securitycenter.v2.MuteConfig(this); if (bitField0_ != 0) { buildPartial0(result); } onBuilt(); return result; } private void buildPartial0(com.google.cloud.securitycenter.v2.MuteConfig result) { int from_bitField0_ = bitField0_; if (((from_bitField0_ & 0x00000001) != 0)) { result.name_ = name_; } if (((from_bitField0_ & 0x00000002) != 0)) { result.description_ = description_; } if (((from_bitField0_ & 0x00000004) != 0)) { result.filter_ = filter_; } int to_bitField0_ = 0; if (((from_bitField0_ & 0x00000008) != 0)) { result.createTime_ = createTimeBuilder_ == null ? createTime_ : createTimeBuilder_.build(); to_bitField0_ |= 0x00000001; } if (((from_bitField0_ & 0x00000010) != 0)) { result.updateTime_ = updateTimeBuilder_ == null ? updateTime_ : updateTimeBuilder_.build(); to_bitField0_ |= 0x00000002; } if (((from_bitField0_ & 0x00000020) != 0)) { result.mostRecentEditor_ = mostRecentEditor_; } if (((from_bitField0_ & 0x00000040) != 0)) { result.type_ = type_; } if (((from_bitField0_ & 0x00000080) != 0)) { result.expiryTime_ = expiryTimeBuilder_ == null ? expiryTime_ : expiryTimeBuilder_.build(); to_bitField0_ |= 0x00000004; } result.bitField0_ |= to_bitField0_; } @java.lang.Override public Builder clone() { return super.clone(); } @java.lang.Override public Builder setField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.setField(field, value); } @java.lang.Override public Builder clearField(com.google.protobuf.Descriptors.FieldDescriptor field) { return super.clearField(field); } @java.lang.Override public Builder clearOneof(com.google.protobuf.Descriptors.OneofDescriptor oneof) { return super.clearOneof(oneof); } @java.lang.Override public Builder setRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, int index, java.lang.Object value) { return super.setRepeatedField(field, index, value); } @java.lang.Override public Builder addRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.addRepeatedField(field, value); } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { if (other instanceof com.google.cloud.securitycenter.v2.MuteConfig) { return mergeFrom((com.google.cloud.securitycenter.v2.MuteConfig) other); } else { super.mergeFrom(other); return this; } } public Builder mergeFrom(com.google.cloud.securitycenter.v2.MuteConfig other) { if (other == com.google.cloud.securitycenter.v2.MuteConfig.getDefaultInstance()) return this; if (!other.getName().isEmpty()) { name_ = other.name_; bitField0_ |= 0x00000001; onChanged(); } if (!other.getDescription().isEmpty()) { description_ = other.description_; bitField0_ |= 0x00000002; onChanged(); } if (!other.getFilter().isEmpty()) { filter_ = other.filter_; bitField0_ |= 0x00000004; onChanged(); } if (other.hasCreateTime()) { mergeCreateTime(other.getCreateTime()); } if (other.hasUpdateTime()) { mergeUpdateTime(other.getUpdateTime()); } if (!other.getMostRecentEditor().isEmpty()) { mostRecentEditor_ = other.mostRecentEditor_; bitField0_ |= 0x00000020; onChanged(); } if (other.type_ != 0) { setTypeValue(other.getTypeValue()); } if (other.hasExpiryTime()) { mergeExpiryTime(other.getExpiryTime()); } this.mergeUnknownFields(other.getUnknownFields()); onChanged(); return this; } @java.lang.Override public final boolean isInitialized() { return true; } @java.lang.Override public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { if (extensionRegistry == null) { throw new java.lang.NullPointerException(); } try { boolean done = false; while (!done) { int tag = input.readTag(); switch (tag) { case 0: done = true; break; case 10: { name_ = input.readStringRequireUtf8(); bitField0_ |= 0x00000001; break; } // case 10 case 18: { description_ = input.readStringRequireUtf8(); bitField0_ |= 0x00000002; break; } // case 18 case 26: { filter_ = input.readStringRequireUtf8(); bitField0_ |= 0x00000004; break; } // case 26 case 34: { input.readMessage(getCreateTimeFieldBuilder().getBuilder(), extensionRegistry); bitField0_ |= 0x00000008; break; } // case 34 case 42: { input.readMessage(getUpdateTimeFieldBuilder().getBuilder(), extensionRegistry); bitField0_ |= 0x00000010; break; } // case 42 case 50: { mostRecentEditor_ = input.readStringRequireUtf8(); bitField0_ |= 0x00000020; break; } // case 50 case 64: { type_ = input.readEnum(); bitField0_ |= 0x00000040; break; } // case 64 case 74: { input.readMessage(getExpiryTimeFieldBuilder().getBuilder(), extensionRegistry); bitField0_ |= 0x00000080; break; } // case 74 default: { if (!super.parseUnknownField(input, extensionRegistry, tag)) { done = true; // was an endgroup tag } break; } // default: } // switch (tag) } // while (!done) } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.unwrapIOException(); } finally { onChanged(); } // finally return this; } private int bitField0_; private java.lang.Object name_ = ""; /** * * *
     * Identifier. This field will be ignored if provided on config creation. The
     * following list shows some examples of the format:
     *
     * + `organizations/{organization}/muteConfigs/{mute_config}`
     * +
     * `organizations/{organization}locations/{location}//muteConfigs/{mute_config}`
     * + `folders/{folder}/muteConfigs/{mute_config}`
     * + `folders/{folder}/locations/{location}/muteConfigs/{mute_config}`
     * + `projects/{project}/muteConfigs/{mute_config}`
     * + `projects/{project}/locations/{location}/muteConfigs/{mute_config}`
     * 
* * string name = 1 [(.google.api.field_behavior) = IDENTIFIER]; * * @return The name. */ public java.lang.String getName() { java.lang.Object ref = name_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); name_ = s; return s; } else { return (java.lang.String) ref; } } /** * * *
     * Identifier. This field will be ignored if provided on config creation. The
     * following list shows some examples of the format:
     *
     * + `organizations/{organization}/muteConfigs/{mute_config}`
     * +
     * `organizations/{organization}locations/{location}//muteConfigs/{mute_config}`
     * + `folders/{folder}/muteConfigs/{mute_config}`
     * + `folders/{folder}/locations/{location}/muteConfigs/{mute_config}`
     * + `projects/{project}/muteConfigs/{mute_config}`
     * + `projects/{project}/locations/{location}/muteConfigs/{mute_config}`
     * 
* * string name = 1 [(.google.api.field_behavior) = IDENTIFIER]; * * @return The bytes for name. */ public com.google.protobuf.ByteString getNameBytes() { java.lang.Object ref = name_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); name_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** * * *
     * Identifier. This field will be ignored if provided on config creation. The
     * following list shows some examples of the format:
     *
     * + `organizations/{organization}/muteConfigs/{mute_config}`
     * +
     * `organizations/{organization}locations/{location}//muteConfigs/{mute_config}`
     * + `folders/{folder}/muteConfigs/{mute_config}`
     * + `folders/{folder}/locations/{location}/muteConfigs/{mute_config}`
     * + `projects/{project}/muteConfigs/{mute_config}`
     * + `projects/{project}/locations/{location}/muteConfigs/{mute_config}`
     * 
* * string name = 1 [(.google.api.field_behavior) = IDENTIFIER]; * * @param value The name to set. * @return This builder for chaining. */ public Builder setName(java.lang.String value) { if (value == null) { throw new NullPointerException(); } name_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } /** * * *
     * Identifier. This field will be ignored if provided on config creation. The
     * following list shows some examples of the format:
     *
     * + `organizations/{organization}/muteConfigs/{mute_config}`
     * +
     * `organizations/{organization}locations/{location}//muteConfigs/{mute_config}`
     * + `folders/{folder}/muteConfigs/{mute_config}`
     * + `folders/{folder}/locations/{location}/muteConfigs/{mute_config}`
     * + `projects/{project}/muteConfigs/{mute_config}`
     * + `projects/{project}/locations/{location}/muteConfigs/{mute_config}`
     * 
* * string name = 1 [(.google.api.field_behavior) = IDENTIFIER]; * * @return This builder for chaining. */ public Builder clearName() { name_ = getDefaultInstance().getName(); bitField0_ = (bitField0_ & ~0x00000001); onChanged(); return this; } /** * * *
     * Identifier. This field will be ignored if provided on config creation. The
     * following list shows some examples of the format:
     *
     * + `organizations/{organization}/muteConfigs/{mute_config}`
     * +
     * `organizations/{organization}locations/{location}//muteConfigs/{mute_config}`
     * + `folders/{folder}/muteConfigs/{mute_config}`
     * + `folders/{folder}/locations/{location}/muteConfigs/{mute_config}`
     * + `projects/{project}/muteConfigs/{mute_config}`
     * + `projects/{project}/locations/{location}/muteConfigs/{mute_config}`
     * 
* * string name = 1 [(.google.api.field_behavior) = IDENTIFIER]; * * @param value The bytes for name to set. * @return This builder for chaining. */ public Builder setNameBytes(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } checkByteStringIsUtf8(value); name_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } private java.lang.Object description_ = ""; /** * * *
     * A description of the mute config.
     * 
* * string description = 2; * * @return The description. */ public java.lang.String getDescription() { java.lang.Object ref = description_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); description_ = s; return s; } else { return (java.lang.String) ref; } } /** * * *
     * A description of the mute config.
     * 
* * string description = 2; * * @return The bytes for description. */ public com.google.protobuf.ByteString getDescriptionBytes() { java.lang.Object ref = description_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); description_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** * * *
     * A description of the mute config.
     * 
* * string description = 2; * * @param value The description to set. * @return This builder for chaining. */ public Builder setDescription(java.lang.String value) { if (value == null) { throw new NullPointerException(); } description_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } /** * * *
     * A description of the mute config.
     * 
* * string description = 2; * * @return This builder for chaining. */ public Builder clearDescription() { description_ = getDefaultInstance().getDescription(); bitField0_ = (bitField0_ & ~0x00000002); onChanged(); return this; } /** * * *
     * A description of the mute config.
     * 
* * string description = 2; * * @param value The bytes for description to set. * @return This builder for chaining. */ public Builder setDescriptionBytes(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } checkByteStringIsUtf8(value); description_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } private java.lang.Object filter_ = ""; /** * * *
     * 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: `=`, `:`
     * 
* * string filter = 3 [(.google.api.field_behavior) = REQUIRED]; * * @return The filter. */ public java.lang.String getFilter() { java.lang.Object ref = filter_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); filter_ = s; return s; } else { return (java.lang.String) ref; } } /** * * *
     * 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: `=`, `:`
     * 
* * string filter = 3 [(.google.api.field_behavior) = REQUIRED]; * * @return The bytes for filter. */ public com.google.protobuf.ByteString getFilterBytes() { java.lang.Object ref = filter_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); filter_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** * * *
     * 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: `=`, `:`
     * 
* * string filter = 3 [(.google.api.field_behavior) = REQUIRED]; * * @param value The filter to set. * @return This builder for chaining. */ public Builder setFilter(java.lang.String value) { if (value == null) { throw new NullPointerException(); } filter_ = value; bitField0_ |= 0x00000004; onChanged(); return this; } /** * * *
     * 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: `=`, `:`
     * 
* * string filter = 3 [(.google.api.field_behavior) = REQUIRED]; * * @return This builder for chaining. */ public Builder clearFilter() { filter_ = getDefaultInstance().getFilter(); bitField0_ = (bitField0_ & ~0x00000004); onChanged(); return this; } /** * * *
     * 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: `=`, `:`
     * 
* * string filter = 3 [(.google.api.field_behavior) = REQUIRED]; * * @param value The bytes for filter to set. * @return This builder for chaining. */ public Builder setFilterBytes(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } checkByteStringIsUtf8(value); filter_ = value; bitField0_ |= 0x00000004; onChanged(); return this; } private com.google.protobuf.Timestamp createTime_; private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder> createTimeBuilder_; /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * * @return Whether the createTime field is set. */ public boolean hasCreateTime() { return ((bitField0_ & 0x00000008) != 0); } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * * @return The createTime. */ public com.google.protobuf.Timestamp getCreateTime() { if (createTimeBuilder_ == null) { return createTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : createTime_; } else { return createTimeBuilder_.getMessage(); } } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public Builder setCreateTime(com.google.protobuf.Timestamp value) { if (createTimeBuilder_ == null) { if (value == null) { throw new NullPointerException(); } createTime_ = value; } else { createTimeBuilder_.setMessage(value); } bitField0_ |= 0x00000008; onChanged(); return this; } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public Builder setCreateTime(com.google.protobuf.Timestamp.Builder builderForValue) { if (createTimeBuilder_ == null) { createTime_ = builderForValue.build(); } else { createTimeBuilder_.setMessage(builderForValue.build()); } bitField0_ |= 0x00000008; onChanged(); return this; } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public Builder mergeCreateTime(com.google.protobuf.Timestamp value) { if (createTimeBuilder_ == null) { if (((bitField0_ & 0x00000008) != 0) && createTime_ != null && createTime_ != com.google.protobuf.Timestamp.getDefaultInstance()) { getCreateTimeBuilder().mergeFrom(value); } else { createTime_ = value; } } else { createTimeBuilder_.mergeFrom(value); } if (createTime_ != null) { bitField0_ |= 0x00000008; onChanged(); } return this; } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public Builder clearCreateTime() { bitField0_ = (bitField0_ & ~0x00000008); createTime_ = null; if (createTimeBuilder_ != null) { createTimeBuilder_.dispose(); createTimeBuilder_ = null; } onChanged(); return this; } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public com.google.protobuf.Timestamp.Builder getCreateTimeBuilder() { bitField0_ |= 0x00000008; onChanged(); return getCreateTimeFieldBuilder().getBuilder(); } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public com.google.protobuf.TimestampOrBuilder getCreateTimeOrBuilder() { if (createTimeBuilder_ != null) { return createTimeBuilder_.getMessageOrBuilder(); } else { return createTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : createTime_; } } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp create_time = 4 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder> getCreateTimeFieldBuilder() { if (createTimeBuilder_ == null) { createTimeBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder>( getCreateTime(), getParentForChildren(), isClean()); createTime_ = null; } return createTimeBuilder_; } private com.google.protobuf.Timestamp updateTime_; private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder> updateTimeBuilder_; /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * * @return Whether the updateTime field is set. */ public boolean hasUpdateTime() { return ((bitField0_ & 0x00000010) != 0); } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * * @return The updateTime. */ public com.google.protobuf.Timestamp getUpdateTime() { if (updateTimeBuilder_ == null) { return updateTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : updateTime_; } else { return updateTimeBuilder_.getMessage(); } } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public Builder setUpdateTime(com.google.protobuf.Timestamp value) { if (updateTimeBuilder_ == null) { if (value == null) { throw new NullPointerException(); } updateTime_ = value; } else { updateTimeBuilder_.setMessage(value); } bitField0_ |= 0x00000010; onChanged(); return this; } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public Builder setUpdateTime(com.google.protobuf.Timestamp.Builder builderForValue) { if (updateTimeBuilder_ == null) { updateTime_ = builderForValue.build(); } else { updateTimeBuilder_.setMessage(builderForValue.build()); } bitField0_ |= 0x00000010; onChanged(); return this; } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public Builder mergeUpdateTime(com.google.protobuf.Timestamp value) { if (updateTimeBuilder_ == null) { if (((bitField0_ & 0x00000010) != 0) && updateTime_ != null && updateTime_ != com.google.protobuf.Timestamp.getDefaultInstance()) { getUpdateTimeBuilder().mergeFrom(value); } else { updateTime_ = value; } } else { updateTimeBuilder_.mergeFrom(value); } if (updateTime_ != null) { bitField0_ |= 0x00000010; onChanged(); } return this; } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public Builder clearUpdateTime() { bitField0_ = (bitField0_ & ~0x00000010); updateTime_ = null; if (updateTimeBuilder_ != null) { updateTimeBuilder_.dispose(); updateTimeBuilder_ = null; } onChanged(); return this; } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public com.google.protobuf.Timestamp.Builder getUpdateTimeBuilder() { bitField0_ |= 0x00000010; onChanged(); return getUpdateTimeFieldBuilder().getBuilder(); } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ public com.google.protobuf.TimestampOrBuilder getUpdateTimeOrBuilder() { if (updateTimeBuilder_ != null) { return updateTimeBuilder_.getMessageOrBuilder(); } else { return updateTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : updateTime_; } } /** * * *
     * 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.
     * 
* * * .google.protobuf.Timestamp update_time = 5 [(.google.api.field_behavior) = OUTPUT_ONLY]; * */ private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder> getUpdateTimeFieldBuilder() { if (updateTimeBuilder_ == null) { updateTimeBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder>( getUpdateTime(), getParentForChildren(), isClean()); updateTime_ = null; } return updateTimeBuilder_; } private java.lang.Object mostRecentEditor_ = ""; /** * * *
     * 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.
     * 
* * string most_recent_editor = 6 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * @return The mostRecentEditor. */ public java.lang.String getMostRecentEditor() { java.lang.Object ref = mostRecentEditor_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); mostRecentEditor_ = s; return s; } else { return (java.lang.String) ref; } } /** * * *
     * 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.
     * 
* * string most_recent_editor = 6 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * @return The bytes for mostRecentEditor. */ public com.google.protobuf.ByteString getMostRecentEditorBytes() { java.lang.Object ref = mostRecentEditor_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref); mostRecentEditor_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** * * *
     * 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.
     * 
* * string most_recent_editor = 6 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * @param value The mostRecentEditor to set. * @return This builder for chaining. */ public Builder setMostRecentEditor(java.lang.String value) { if (value == null) { throw new NullPointerException(); } mostRecentEditor_ = value; bitField0_ |= 0x00000020; onChanged(); return this; } /** * * *
     * 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.
     * 
* * string most_recent_editor = 6 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * @return This builder for chaining. */ public Builder clearMostRecentEditor() { mostRecentEditor_ = getDefaultInstance().getMostRecentEditor(); bitField0_ = (bitField0_ & ~0x00000020); onChanged(); return this; } /** * * *
     * 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.
     * 
* * string most_recent_editor = 6 [(.google.api.field_behavior) = OUTPUT_ONLY]; * * @param value The bytes for mostRecentEditor to set. * @return This builder for chaining. */ public Builder setMostRecentEditorBytes(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } checkByteStringIsUtf8(value); mostRecentEditor_ = value; bitField0_ |= 0x00000020; onChanged(); return this; } private int type_ = 0; /** * * *
     * Required. The type of the mute config, which determines what type of mute
     * state the config affects. Immutable after creation.
     * 
* * * .google.cloud.securitycenter.v2.MuteConfig.MuteConfigType type = 8 [(.google.api.field_behavior) = REQUIRED]; * * * @return The enum numeric value on the wire for type. */ @java.lang.Override public int getTypeValue() { return type_; } /** * * *
     * Required. The type of the mute config, which determines what type of mute
     * state the config affects. Immutable after creation.
     * 
* * * .google.cloud.securitycenter.v2.MuteConfig.MuteConfigType type = 8 [(.google.api.field_behavior) = REQUIRED]; * * * @param value The enum numeric value on the wire for type to set. * @return This builder for chaining. */ public Builder setTypeValue(int value) { type_ = value; bitField0_ |= 0x00000040; onChanged(); return this; } /** * * *
     * Required. The type of the mute config, which determines what type of mute
     * state the config affects. Immutable after creation.
     * 
* * * .google.cloud.securitycenter.v2.MuteConfig.MuteConfigType type = 8 [(.google.api.field_behavior) = REQUIRED]; * * * @return The type. */ @java.lang.Override public com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType getType() { com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType result = com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType.forNumber(type_); return result == null ? com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType.UNRECOGNIZED : result; } /** * * *
     * Required. The type of the mute config, which determines what type of mute
     * state the config affects. Immutable after creation.
     * 
* * * .google.cloud.securitycenter.v2.MuteConfig.MuteConfigType type = 8 [(.google.api.field_behavior) = REQUIRED]; * * * @param value The type to set. * @return This builder for chaining. */ public Builder setType(com.google.cloud.securitycenter.v2.MuteConfig.MuteConfigType value) { if (value == null) { throw new NullPointerException(); } bitField0_ |= 0x00000040; type_ = value.getNumber(); onChanged(); return this; } /** * * *
     * Required. The type of the mute config, which determines what type of mute
     * state the config affects. Immutable after creation.
     * 
* * * .google.cloud.securitycenter.v2.MuteConfig.MuteConfigType type = 8 [(.google.api.field_behavior) = REQUIRED]; * * * @return This builder for chaining. */ public Builder clearType() { bitField0_ = (bitField0_ & ~0x00000040); type_ = 0; onChanged(); return this; } private com.google.protobuf.Timestamp expiryTime_; private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder> expiryTimeBuilder_; /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * * * @return Whether the expiryTime field is set. */ public boolean hasExpiryTime() { return ((bitField0_ & 0x00000080) != 0); } /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * * * @return The expiryTime. */ public com.google.protobuf.Timestamp getExpiryTime() { if (expiryTimeBuilder_ == null) { return expiryTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : expiryTime_; } else { return expiryTimeBuilder_.getMessage(); } } /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * */ public Builder setExpiryTime(com.google.protobuf.Timestamp value) { if (expiryTimeBuilder_ == null) { if (value == null) { throw new NullPointerException(); } expiryTime_ = value; } else { expiryTimeBuilder_.setMessage(value); } bitField0_ |= 0x00000080; onChanged(); return this; } /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * */ public Builder setExpiryTime(com.google.protobuf.Timestamp.Builder builderForValue) { if (expiryTimeBuilder_ == null) { expiryTime_ = builderForValue.build(); } else { expiryTimeBuilder_.setMessage(builderForValue.build()); } bitField0_ |= 0x00000080; onChanged(); return this; } /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * */ public Builder mergeExpiryTime(com.google.protobuf.Timestamp value) { if (expiryTimeBuilder_ == null) { if (((bitField0_ & 0x00000080) != 0) && expiryTime_ != null && expiryTime_ != com.google.protobuf.Timestamp.getDefaultInstance()) { getExpiryTimeBuilder().mergeFrom(value); } else { expiryTime_ = value; } } else { expiryTimeBuilder_.mergeFrom(value); } if (expiryTime_ != null) { bitField0_ |= 0x00000080; onChanged(); } return this; } /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * */ public Builder clearExpiryTime() { bitField0_ = (bitField0_ & ~0x00000080); expiryTime_ = null; if (expiryTimeBuilder_ != null) { expiryTimeBuilder_.dispose(); expiryTimeBuilder_ = null; } onChanged(); return this; } /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * */ public com.google.protobuf.Timestamp.Builder getExpiryTimeBuilder() { bitField0_ |= 0x00000080; onChanged(); return getExpiryTimeFieldBuilder().getBuilder(); } /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * */ public com.google.protobuf.TimestampOrBuilder getExpiryTimeOrBuilder() { if (expiryTimeBuilder_ != null) { return expiryTimeBuilder_.getMessageOrBuilder(); } else { return expiryTime_ == null ? com.google.protobuf.Timestamp.getDefaultInstance() : expiryTime_; } } /** * * *
     * Optional. The expiry of the mute config. Only applicable for dynamic
     * configs. If the expiry is set, when the config expires, it is removed from
     * all findings.
     * 
* * .google.protobuf.Timestamp expiry_time = 9 [(.google.api.field_behavior) = OPTIONAL]; * */ private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder> getExpiryTimeFieldBuilder() { if (expiryTimeBuilder_ == null) { expiryTimeBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.Timestamp, com.google.protobuf.Timestamp.Builder, com.google.protobuf.TimestampOrBuilder>( getExpiryTime(), getParentForChildren(), isClean()); expiryTime_ = null; } return expiryTimeBuilder_; } @java.lang.Override public final Builder setUnknownFields(final com.google.protobuf.UnknownFieldSet unknownFields) { return super.setUnknownFields(unknownFields); } @java.lang.Override public final Builder mergeUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.mergeUnknownFields(unknownFields); } // @@protoc_insertion_point(builder_scope:google.cloud.securitycenter.v2.MuteConfig) } // @@protoc_insertion_point(class_scope:google.cloud.securitycenter.v2.MuteConfig) private static final com.google.cloud.securitycenter.v2.MuteConfig DEFAULT_INSTANCE; static { DEFAULT_INSTANCE = new com.google.cloud.securitycenter.v2.MuteConfig(); } public static com.google.cloud.securitycenter.v2.MuteConfig getDefaultInstance() { return DEFAULT_INSTANCE; } private static final com.google.protobuf.Parser PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override public MuteConfig parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { Builder builder = newBuilder(); try { builder.mergeFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.setUnfinishedMessage(builder.buildPartial()); } catch (com.google.protobuf.UninitializedMessageException e) { throw e.asInvalidProtocolBufferException().setUnfinishedMessage(builder.buildPartial()); } catch (java.io.IOException e) { throw new com.google.protobuf.InvalidProtocolBufferException(e) .setUnfinishedMessage(builder.buildPartial()); } return builder.buildPartial(); } }; public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override public com.google.cloud.securitycenter.v2.MuteConfig getDefaultInstanceForType() { return DEFAULT_INSTANCE; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy