software.amazon.awssdk.services.mediaconvert.model.AllowedRenditionSize Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mediaconvert Show documentation
Show all versions of mediaconvert Show documentation
The AWS Java SDK for AWS Elemental MediaConvert module holds the client classes that are used for
communicating
with AWS Elemental MediaConvert Service
/*
* 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.mediaconvert.model;
import java.io.Serializable;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
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.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
* Use Allowed renditions to specify a list of possible resolutions in your ABR stack. * MediaConvert will create an ABR
* stack exclusively from the list of resolutions that you specify. * Some resolutions in the Allowed renditions list
* may not be included, however you can force a resolution to be included by setting Required to ENABLED. * You must
* specify at least one resolution that is greater than or equal to any resolutions that you specify in Min top
* rendition size or Min bottom rendition size. * If you specify Allowed renditions, you must not specify a separate
* rule for Force include renditions.
*/
@Generated("software.amazon.awssdk:codegen")
public final class AllowedRenditionSize implements SdkPojo, Serializable,
ToCopyableBuilder {
private static final SdkField HEIGHT_FIELD = SdkField. builder(MarshallingType.INTEGER)
.memberName("Height").getter(getter(AllowedRenditionSize::height)).setter(setter(Builder::height))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("height").build()).build();
private static final SdkField REQUIRED_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("Required").getter(getter(AllowedRenditionSize::requiredAsString)).setter(setter(Builder::required))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("required").build()).build();
private static final SdkField WIDTH_FIELD = SdkField. builder(MarshallingType.INTEGER).memberName("Width")
.getter(getter(AllowedRenditionSize::width)).setter(setter(Builder::width))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("width").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(HEIGHT_FIELD, REQUIRED_FIELD,
WIDTH_FIELD));
private static final long serialVersionUID = 1L;
private final Integer height;
private final String required;
private final Integer width;
private AllowedRenditionSize(BuilderImpl builder) {
this.height = builder.height;
this.required = builder.required;
this.width = builder.width;
}
/**
* Use Height to define the video resolution height, in pixels, for this rule.
*
* @return Use Height to define the video resolution height, in pixels, for this rule.
*/
public final Integer height() {
return height;
}
/**
* Set to ENABLED to force a rendition to be included.
*
* If the service returns an enum value that is not available in the current SDK version, {@link #required} will
* return {@link RequiredFlag#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #requiredAsString}.
*
*
* @return Set to ENABLED to force a rendition to be included.
* @see RequiredFlag
*/
public final RequiredFlag required() {
return RequiredFlag.fromValue(required);
}
/**
* Set to ENABLED to force a rendition to be included.
*
* If the service returns an enum value that is not available in the current SDK version, {@link #required} will
* return {@link RequiredFlag#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from
* {@link #requiredAsString}.
*
*
* @return Set to ENABLED to force a rendition to be included.
* @see RequiredFlag
*/
public final String requiredAsString() {
return required;
}
/**
* Use Width to define the video resolution width, in pixels, for this rule.
*
* @return Use Width to define the video resolution width, in pixels, for this rule.
*/
public final Integer width() {
return width;
}
@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 final int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + Objects.hashCode(height());
hashCode = 31 * hashCode + Objects.hashCode(requiredAsString());
hashCode = 31 * hashCode + Objects.hashCode(width());
return hashCode;
}
@Override
public final boolean equals(Object obj) {
return equalsBySdkFields(obj);
}
@Override
public final boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof AllowedRenditionSize)) {
return false;
}
AllowedRenditionSize other = (AllowedRenditionSize) obj;
return Objects.equals(height(), other.height()) && Objects.equals(requiredAsString(), other.requiredAsString())
&& Objects.equals(width(), other.width());
}
/**
* 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 final String toString() {
return ToString.builder("AllowedRenditionSize").add("Height", height()).add("Required", requiredAsString())
.add("Width", width()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "Height":
return Optional.ofNullable(clazz.cast(height()));
case "Required":
return Optional.ofNullable(clazz.cast(requiredAsString()));
case "Width":
return Optional.ofNullable(clazz.cast(width()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function