Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
software.amazon.awssdk.services.ssm.model.ComplianceItem Maven / Gradle / Ivy
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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.
*/
package software.amazon.awssdk.services.ssm.model;
import java.io.Serializable;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.traits.MapTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructMap;
import software.amazon.awssdk.core.util.SdkAutoConstructMap;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*
* Information about the compliance as defined by the resource type. For example, for a patch resource type,
* Items
includes information about the PatchSeverity, Classification, and so on.
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class ComplianceItem implements SdkPojo, Serializable, ToCopyableBuilder {
private static final SdkField COMPLIANCE_TYPE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ComplianceType").getter(getter(ComplianceItem::complianceType)).setter(setter(Builder::complianceType))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ComplianceType").build()).build();
private static final SdkField RESOURCE_TYPE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ResourceType").getter(getter(ComplianceItem::resourceType)).setter(setter(Builder::resourceType))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ResourceType").build()).build();
private static final SdkField RESOURCE_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ResourceId").getter(getter(ComplianceItem::resourceId)).setter(setter(Builder::resourceId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ResourceId").build()).build();
private static final SdkField ID_FIELD = SdkField. builder(MarshallingType.STRING).memberName("Id")
.getter(getter(ComplianceItem::id)).setter(setter(Builder::id))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Id").build()).build();
private static final SdkField TITLE_FIELD = SdkField. builder(MarshallingType.STRING).memberName("Title")
.getter(getter(ComplianceItem::title)).setter(setter(Builder::title))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Title").build()).build();
private static final SdkField STATUS_FIELD = SdkField. builder(MarshallingType.STRING).memberName("Status")
.getter(getter(ComplianceItem::statusAsString)).setter(setter(Builder::status))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Status").build()).build();
private static final SdkField SEVERITY_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("Severity").getter(getter(ComplianceItem::severityAsString)).setter(setter(Builder::severity))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Severity").build()).build();
private static final SdkField EXECUTION_SUMMARY_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("ExecutionSummary")
.getter(getter(ComplianceItem::executionSummary)).setter(setter(Builder::executionSummary))
.constructor(ComplianceExecutionSummary::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ExecutionSummary").build()).build();
private static final SdkField> DETAILS_FIELD = SdkField
.> builder(MarshallingType.MAP)
.memberName("Details")
.getter(getter(ComplianceItem::details))
.setter(setter(Builder::details))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Details").build(),
MapTrait.builder()
.keyLocationName("key")
.valueLocationName("value")
.valueFieldInfo(
SdkField. builder(MarshallingType.STRING)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
.locationName("value").build()).build()).build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(COMPLIANCE_TYPE_FIELD,
RESOURCE_TYPE_FIELD, RESOURCE_ID_FIELD, ID_FIELD, TITLE_FIELD, STATUS_FIELD, SEVERITY_FIELD, EXECUTION_SUMMARY_FIELD,
DETAILS_FIELD));
private static final long serialVersionUID = 1L;
private final String complianceType;
private final String resourceType;
private final String resourceId;
private final String id;
private final String title;
private final String status;
private final String severity;
private final ComplianceExecutionSummary executionSummary;
private final Map details;
private ComplianceItem(BuilderImpl builder) {
this.complianceType = builder.complianceType;
this.resourceType = builder.resourceType;
this.resourceId = builder.resourceId;
this.id = builder.id;
this.title = builder.title;
this.status = builder.status;
this.severity = builder.severity;
this.executionSummary = builder.executionSummary;
this.details = builder.details;
}
/**
*
* The compliance type. For example, Association (for a State Manager association), Patch, or Custom:
* string
are all valid compliance types.
*
*
* @return The compliance type. For example, Association (for a State Manager association), Patch, or Custom:
* string
are all valid compliance types.
*/
public String complianceType() {
return complianceType;
}
/**
*
* The type of resource. ManagedInstance
is currently the only supported resource type.
*
*
* @return The type of resource. ManagedInstance
is currently the only supported resource type.
*/
public String resourceType() {
return resourceType;
}
/**
*
* An ID for the resource. For a managed instance, this is the instance ID.
*
*
* @return An ID for the resource. For a managed instance, this is the instance ID.
*/
public String resourceId() {
return resourceId;
}
/**
*
* An ID for the compliance item. For example, if the compliance item is a Windows patch, the ID could be the number
* of the KB article; for example: KB4010320.
*
*
* @return An ID for the compliance item. For example, if the compliance item is a Windows patch, the ID could be
* the number of the KB article; for example: KB4010320.
*/
public String id() {
return id;
}
/**
*
* A title for the compliance item. For example, if the compliance item is a Windows patch, the title could be the
* title of the KB article for the patch; for example: Security Update for Active Directory Federation Services.
*
*
* @return A title for the compliance item. For example, if the compliance item is a Windows patch, the title could
* be the title of the KB article for the patch; for example: Security Update for Active Directory
* Federation Services.
*/
public String title() {
return title;
}
/**
*
* The status of the compliance item. An item is either COMPLIANT, NON_COMPLIANT, or an empty string (for Windows
* patches that aren't applicable).
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #status} will
* return {@link ComplianceStatus#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #statusAsString}.
*
*
* @return The status of the compliance item. An item is either COMPLIANT, NON_COMPLIANT, or an empty string (for
* Windows patches that aren't applicable).
* @see ComplianceStatus
*/
public ComplianceStatus status() {
return ComplianceStatus.fromValue(status);
}
/**
*
* The status of the compliance item. An item is either COMPLIANT, NON_COMPLIANT, or an empty string (for Windows
* patches that aren't applicable).
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #status} will
* return {@link ComplianceStatus#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #statusAsString}.
*
*
* @return The status of the compliance item. An item is either COMPLIANT, NON_COMPLIANT, or an empty string (for
* Windows patches that aren't applicable).
* @see ComplianceStatus
*/
public String statusAsString() {
return status;
}
/**
*
* The severity of the compliance status. Severity can be one of the following: Critical, High, Medium, Low,
* Informational, Unspecified.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #severity} will
* return {@link ComplianceSeverity#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #severityAsString}.
*
*
* @return The severity of the compliance status. Severity can be one of the following: Critical, High, Medium, Low,
* Informational, Unspecified.
* @see ComplianceSeverity
*/
public ComplianceSeverity severity() {
return ComplianceSeverity.fromValue(severity);
}
/**
*
* The severity of the compliance status. Severity can be one of the following: Critical, High, Medium, Low,
* Informational, Unspecified.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #severity} will
* return {@link ComplianceSeverity#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #severityAsString}.
*
*
* @return The severity of the compliance status. Severity can be one of the following: Critical, High, Medium, Low,
* Informational, Unspecified.
* @see ComplianceSeverity
*/
public String severityAsString() {
return severity;
}
/**
*
* A summary for the compliance item. The summary includes an execution ID, the execution type (for example,
* command), and the execution time.
*
*
* @return A summary for the compliance item. The summary includes an execution ID, the execution type (for example,
* command), and the execution time.
*/
public ComplianceExecutionSummary executionSummary() {
return executionSummary;
}
/**
* Returns true if the Details property was specified by the sender (it may be empty), or false if the sender did
* not specify the value (it will be empty). For responses returned by the SDK, the sender is the AWS service.
*/
public boolean hasDetails() {
return details != null && !(details instanceof SdkAutoConstructMap);
}
/**
*
* A "Key": "Value" tag combination for the compliance item.
*
*
* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
*
*
* You can use {@link #hasDetails()} to see if a value was sent in this field.
*
*
* @return A "Key": "Value" tag combination for the compliance item.
*/
public Map details() {
return details;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + Objects.hashCode(complianceType());
hashCode = 31 * hashCode + Objects.hashCode(resourceType());
hashCode = 31 * hashCode + Objects.hashCode(resourceId());
hashCode = 31 * hashCode + Objects.hashCode(id());
hashCode = 31 * hashCode + Objects.hashCode(title());
hashCode = 31 * hashCode + Objects.hashCode(statusAsString());
hashCode = 31 * hashCode + Objects.hashCode(severityAsString());
hashCode = 31 * hashCode + Objects.hashCode(executionSummary());
hashCode = 31 * hashCode + Objects.hashCode(details());
return hashCode;
}
@Override
public boolean equals(Object obj) {
return equalsBySdkFields(obj);
}
@Override
public boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof ComplianceItem)) {
return false;
}
ComplianceItem other = (ComplianceItem) obj;
return Objects.equals(complianceType(), other.complianceType()) && Objects.equals(resourceType(), other.resourceType())
&& Objects.equals(resourceId(), other.resourceId()) && Objects.equals(id(), other.id())
&& Objects.equals(title(), other.title()) && Objects.equals(statusAsString(), other.statusAsString())
&& Objects.equals(severityAsString(), other.severityAsString())
&& Objects.equals(executionSummary(), other.executionSummary()) && Objects.equals(details(), other.details());
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*/
@Override
public String toString() {
return ToString.builder("ComplianceItem").add("ComplianceType", complianceType()).add("ResourceType", resourceType())
.add("ResourceId", resourceId()).add("Id", id()).add("Title", title()).add("Status", statusAsString())
.add("Severity", severityAsString()).add("ExecutionSummary", executionSummary()).add("Details", details())
.build();
}
public Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "ComplianceType":
return Optional.ofNullable(clazz.cast(complianceType()));
case "ResourceType":
return Optional.ofNullable(clazz.cast(resourceType()));
case "ResourceId":
return Optional.ofNullable(clazz.cast(resourceId()));
case "Id":
return Optional.ofNullable(clazz.cast(id()));
case "Title":
return Optional.ofNullable(clazz.cast(title()));
case "Status":
return Optional.ofNullable(clazz.cast(statusAsString()));
case "Severity":
return Optional.ofNullable(clazz.cast(severityAsString()));
case "ExecutionSummary":
return Optional.ofNullable(clazz.cast(executionSummary()));
case "Details":
return Optional.ofNullable(clazz.cast(details()));
default:
return Optional.empty();
}
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
private static Function getter(Function g) {
return obj -> g.apply((ComplianceItem) obj);
}
private static BiConsumer setter(BiConsumer s) {
return (obj, val) -> s.accept((Builder) obj, val);
}
public interface Builder extends SdkPojo, CopyableBuilder {
/**
*
* The compliance type. For example, Association (for a State Manager association), Patch, or Custom:
* string
are all valid compliance types.
*
*
* @param complianceType
* The compliance type. For example, Association (for a State Manager association), Patch, or Custom:
* string
are all valid compliance types.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder complianceType(String complianceType);
/**
*
* The type of resource. ManagedInstance
is currently the only supported resource type.
*
*
* @param resourceType
* The type of resource. ManagedInstance
is currently the only supported resource type.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder resourceType(String resourceType);
/**
*
* An ID for the resource. For a managed instance, this is the instance ID.
*
*
* @param resourceId
* An ID for the resource. For a managed instance, this is the instance ID.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder resourceId(String resourceId);
/**
*
* An ID for the compliance item. For example, if the compliance item is a Windows patch, the ID could be the
* number of the KB article; for example: KB4010320.
*
*
* @param id
* An ID for the compliance item. For example, if the compliance item is a Windows patch, the ID could be
* the number of the KB article; for example: KB4010320.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder id(String id);
/**
*
* A title for the compliance item. For example, if the compliance item is a Windows patch, the title could be
* the title of the KB article for the patch; for example: Security Update for Active Directory Federation
* Services.
*
*
* @param title
* A title for the compliance item. For example, if the compliance item is a Windows patch, the title
* could be the title of the KB article for the patch; for example: Security Update for Active Directory
* Federation Services.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder title(String title);
/**
*
* The status of the compliance item. An item is either COMPLIANT, NON_COMPLIANT, or an empty string (for
* Windows patches that aren't applicable).
*
*
* @param status
* The status of the compliance item. An item is either COMPLIANT, NON_COMPLIANT, or an empty string (for
* Windows patches that aren't applicable).
* @see ComplianceStatus
* @return Returns a reference to this object so that method calls can be chained together.
* @see ComplianceStatus
*/
Builder status(String status);
/**
*
* The status of the compliance item. An item is either COMPLIANT, NON_COMPLIANT, or an empty string (for
* Windows patches that aren't applicable).
*
*
* @param status
* The status of the compliance item. An item is either COMPLIANT, NON_COMPLIANT, or an empty string (for
* Windows patches that aren't applicable).
* @see ComplianceStatus
* @return Returns a reference to this object so that method calls can be chained together.
* @see ComplianceStatus
*/
Builder status(ComplianceStatus status);
/**
*
* The severity of the compliance status. Severity can be one of the following: Critical, High, Medium, Low,
* Informational, Unspecified.
*
*
* @param severity
* The severity of the compliance status. Severity can be one of the following: Critical, High, Medium,
* Low, Informational, Unspecified.
* @see ComplianceSeverity
* @return Returns a reference to this object so that method calls can be chained together.
* @see ComplianceSeverity
*/
Builder severity(String severity);
/**
*
* The severity of the compliance status. Severity can be one of the following: Critical, High, Medium, Low,
* Informational, Unspecified.
*
*
* @param severity
* The severity of the compliance status. Severity can be one of the following: Critical, High, Medium,
* Low, Informational, Unspecified.
* @see ComplianceSeverity
* @return Returns a reference to this object so that method calls can be chained together.
* @see ComplianceSeverity
*/
Builder severity(ComplianceSeverity severity);
/**
*
* A summary for the compliance item. The summary includes an execution ID, the execution type (for example,
* command), and the execution time.
*
*
* @param executionSummary
* A summary for the compliance item. The summary includes an execution ID, the execution type (for
* example, command), and the execution time.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder executionSummary(ComplianceExecutionSummary executionSummary);
/**
*
* A summary for the compliance item. The summary includes an execution ID, the execution type (for example,
* command), and the execution time.
*
* This is a convenience that creates an instance of the {@link ComplianceExecutionSummary.Builder} avoiding the
* need to create one manually via {@link ComplianceExecutionSummary#builder()}.
*
* When the {@link Consumer} completes, {@link ComplianceExecutionSummary.Builder#build()} is called immediately
* and its result is passed to {@link #executionSummary(ComplianceExecutionSummary)}.
*
* @param executionSummary
* a consumer that will call methods on {@link ComplianceExecutionSummary.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #executionSummary(ComplianceExecutionSummary)
*/
default Builder executionSummary(Consumer executionSummary) {
return executionSummary(ComplianceExecutionSummary.builder().applyMutation(executionSummary).build());
}
/**
*
* A "Key": "Value" tag combination for the compliance item.
*
*
* @param details
* A "Key": "Value" tag combination for the compliance item.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder details(Map details);
}
static final class BuilderImpl implements Builder {
private String complianceType;
private String resourceType;
private String resourceId;
private String id;
private String title;
private String status;
private String severity;
private ComplianceExecutionSummary executionSummary;
private Map details = DefaultSdkAutoConstructMap.getInstance();
private BuilderImpl() {
}
private BuilderImpl(ComplianceItem model) {
complianceType(model.complianceType);
resourceType(model.resourceType);
resourceId(model.resourceId);
id(model.id);
title(model.title);
status(model.status);
severity(model.severity);
executionSummary(model.executionSummary);
details(model.details);
}
public final String getComplianceType() {
return complianceType;
}
@Override
public final Builder complianceType(String complianceType) {
this.complianceType = complianceType;
return this;
}
public final void setComplianceType(String complianceType) {
this.complianceType = complianceType;
}
public final String getResourceType() {
return resourceType;
}
@Override
public final Builder resourceType(String resourceType) {
this.resourceType = resourceType;
return this;
}
public final void setResourceType(String resourceType) {
this.resourceType = resourceType;
}
public final String getResourceId() {
return resourceId;
}
@Override
public final Builder resourceId(String resourceId) {
this.resourceId = resourceId;
return this;
}
public final void setResourceId(String resourceId) {
this.resourceId = resourceId;
}
public final String getId() {
return id;
}
@Override
public final Builder id(String id) {
this.id = id;
return this;
}
public final void setId(String id) {
this.id = id;
}
public final String getTitle() {
return title;
}
@Override
public final Builder title(String title) {
this.title = title;
return this;
}
public final void setTitle(String title) {
this.title = title;
}
public final String getStatus() {
return status;
}
@Override
public final Builder status(String status) {
this.status = status;
return this;
}
@Override
public final Builder status(ComplianceStatus status) {
this.status(status == null ? null : status.toString());
return this;
}
public final void setStatus(String status) {
this.status = status;
}
public final String getSeverity() {
return severity;
}
@Override
public final Builder severity(String severity) {
this.severity = severity;
return this;
}
@Override
public final Builder severity(ComplianceSeverity severity) {
this.severity(severity == null ? null : severity.toString());
return this;
}
public final void setSeverity(String severity) {
this.severity = severity;
}
public final ComplianceExecutionSummary.Builder getExecutionSummary() {
return executionSummary != null ? executionSummary.toBuilder() : null;
}
@Override
public final Builder executionSummary(ComplianceExecutionSummary executionSummary) {
this.executionSummary = executionSummary;
return this;
}
public final void setExecutionSummary(ComplianceExecutionSummary.BuilderImpl executionSummary) {
this.executionSummary = executionSummary != null ? executionSummary.build() : null;
}
public final Map getDetails() {
return details;
}
@Override
public final Builder details(Map details) {
this.details = ComplianceItemDetailsCopier.copy(details);
return this;
}
public final void setDetails(Map details) {
this.details = ComplianceItemDetailsCopier.copy(details);
}
@Override
public ComplianceItem build() {
return new ComplianceItem(this);
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
}
}