/* * Copyright 2018-2023 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 com.amazonaws.services.mediaconvert.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** * Use these settings to insert a DVB Service Description Table (SDT) in the transport stream of this output. * * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class DvbSdtSettings implements Serializable, Cloneable, StructuredPojo { /** * Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information from * input stream to output stream. "Follow input SDT if present" copies SDT information from input stream to output * stream if SDT information is present in the input, otherwise it will fall back on the user-defined values. Enter * "SDT Manually" means user will enter the SDT information. "No SDT" means output stream will not contain SDT * information. */ private String outputSdt; /** The number of milliseconds between instances of this table in the output transport stream. */ private Integer sdtInterval; /** * The service name placed in the service_descriptor in the Service Description Table. Maximum length is 256 * characters. */ private String serviceName; /** * The service provider name placed in the service_descriptor in the Service Description Table. Maximum length is * 256 characters. */ private String serviceProviderName; /** * Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information from * input stream to output stream. "Follow input SDT if present" copies SDT information from input stream to output * stream if SDT information is present in the input, otherwise it will fall back on the user-defined values. Enter * "SDT Manually" means user will enter the SDT information. "No SDT" means output stream will not contain SDT * information. * * @param outputSdt * Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information * from input stream to output stream. "Follow input SDT if present" copies SDT information from input stream * to output stream if SDT information is present in the input, otherwise it will fall back on the * user-defined values. Enter "SDT Manually" means user will enter the SDT information. "No SDT" means output * stream will not contain SDT information. * @see OutputSdt */ public void setOutputSdt(String outputSdt) { this.outputSdt = outputSdt; } /** * Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information from * input stream to output stream. "Follow input SDT if present" copies SDT information from input stream to output * stream if SDT information is present in the input, otherwise it will fall back on the user-defined values. Enter * "SDT Manually" means user will enter the SDT information. "No SDT" means output stream will not contain SDT * information. * * @return Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information * from input stream to output stream. "Follow input SDT if present" copies SDT information from input * stream to output stream if SDT information is present in the input, otherwise it will fall back on the * user-defined values. Enter "SDT Manually" means user will enter the SDT information. "No SDT" means * output stream will not contain SDT information. * @see OutputSdt */ public String getOutputSdt() { return this.outputSdt; } /** * Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information from * input stream to output stream. "Follow input SDT if present" copies SDT information from input stream to output * stream if SDT information is present in the input, otherwise it will fall back on the user-defined values. Enter * "SDT Manually" means user will enter the SDT information. "No SDT" means output stream will not contain SDT * information. * * @param outputSdt * Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information * from input stream to output stream. "Follow input SDT if present" copies SDT information from input stream * to output stream if SDT information is present in the input, otherwise it will fall back on the * user-defined values. Enter "SDT Manually" means user will enter the SDT information. "No SDT" means output * stream will not contain SDT information. * @return Returns a reference to this object so that method calls can be chained together. * @see OutputSdt */ public DvbSdtSettings withOutputSdt(String outputSdt) { setOutputSdt(outputSdt); return this; } /** * Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information from * input stream to output stream. "Follow input SDT if present" copies SDT information from input stream to output * stream if SDT information is present in the input, otherwise it will fall back on the user-defined values. Enter * "SDT Manually" means user will enter the SDT information. "No SDT" means output stream will not contain SDT * information. * * @param outputSdt * Selects method of inserting SDT information into output stream. "Follow input SDT" copies SDT information * from input stream to output stream. "Follow input SDT if present" copies SDT information from input stream * to output stream if SDT information is present in the input, otherwise it will fall back on the * user-defined values. Enter "SDT Manually" means user will enter the SDT information. "No SDT" means output * stream will not contain SDT information. * @return Returns a reference to this object so that method calls can be chained together. * @see OutputSdt */ public DvbSdtSettings withOutputSdt(OutputSdt outputSdt) { this.outputSdt = outputSdt.toString(); return this; } /** * The number of milliseconds between instances of this table in the output transport stream. * * @param sdtInterval * The number of milliseconds between instances of this table in the output transport stream. */ public void setSdtInterval(Integer sdtInterval) { this.sdtInterval = sdtInterval; } /** * The number of milliseconds between instances of this table in the output transport stream. * * @return The number of milliseconds between instances of this table in the output transport stream. */ public Integer getSdtInterval() { return this.sdtInterval; } /** * The number of milliseconds between instances of this table in the output transport stream. * * @param sdtInterval * The number of milliseconds between instances of this table in the output transport stream. * @return Returns a reference to this object so that method calls can be chained together. */ public DvbSdtSettings withSdtInterval(Integer sdtInterval) { setSdtInterval(sdtInterval); return this; } /** * The service name placed in the service_descriptor in the Service Description Table. Maximum length is 256 * characters. * * @param serviceName * The service name placed in the service_descriptor in the Service Description Table. Maximum length is 256 * characters. */ public void setServiceName(String serviceName) { this.serviceName = serviceName; } /** * The service name placed in the service_descriptor in the Service Description Table. Maximum length is 256 * characters. * * @return The service name placed in the service_descriptor in the Service Description Table. Maximum length is 256 * characters. */ public String getServiceName() { return this.serviceName; } /** * The service name placed in the service_descriptor in the Service Description Table. Maximum length is 256 * characters. * * @param serviceName * The service name placed in the service_descriptor in the Service Description Table. Maximum length is 256 * characters. * @return Returns a reference to this object so that method calls can be chained together. */ public DvbSdtSettings withServiceName(String serviceName) { setServiceName(serviceName); return this; } /** * The service provider name placed in the service_descriptor in the Service Description Table. Maximum length is * 256 characters. * * @param serviceProviderName * The service provider name placed in the service_descriptor in the Service Description Table. Maximum * length is 256 characters. */ public void setServiceProviderName(String serviceProviderName) { this.serviceProviderName = serviceProviderName; } /** * The service provider name placed in the service_descriptor in the Service Description Table. Maximum length is * 256 characters. * * @return The service provider name placed in the service_descriptor in the Service Description Table. Maximum * length is 256 characters. */ public String getServiceProviderName() { return this.serviceProviderName; } /** * The service provider name placed in the service_descriptor in the Service Description Table. Maximum length is * 256 characters. * * @param serviceProviderName * The service provider name placed in the service_descriptor in the Service Description Table. Maximum * length is 256 characters. * @return Returns a reference to this object so that method calls can be chained together. */ public DvbSdtSettings withServiceProviderName(String serviceProviderName) { setServiceProviderName(serviceProviderName); return this; } /** * 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. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getOutputSdt() != null) sb.append("OutputSdt: ").append(getOutputSdt()).append(","); if (getSdtInterval() != null) sb.append("SdtInterval: ").append(getSdtInterval()).append(","); if (getServiceName() != null) sb.append("ServiceName: ").append(getServiceName()).append(","); if (getServiceProviderName() != null) sb.append("ServiceProviderName: ").append(getServiceProviderName()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof DvbSdtSettings == false) return false; DvbSdtSettings other = (DvbSdtSettings) obj; if (other.getOutputSdt() == null ^ this.getOutputSdt() == null) return false; if (other.getOutputSdt() != null && other.getOutputSdt().equals(this.getOutputSdt()) == false) return false; if (other.getSdtInterval() == null ^ this.getSdtInterval() == null) return false; if (other.getSdtInterval() != null && other.getSdtInterval().equals(this.getSdtInterval()) == false) return false; if (other.getServiceName() == null ^ this.getServiceName() == null) return false; if (other.getServiceName() != null && other.getServiceName().equals(this.getServiceName()) == false) return false; if (other.getServiceProviderName() == null ^ this.getServiceProviderName() == null) return false; if (other.getServiceProviderName() != null && other.getServiceProviderName().equals(this.getServiceProviderName()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getOutputSdt() == null) ? 0 : getOutputSdt().hashCode()); hashCode = prime * hashCode + ((getSdtInterval() == null) ? 0 : getSdtInterval().hashCode()); hashCode = prime * hashCode + ((getServiceName() == null) ? 0 : getServiceName().hashCode()); hashCode = prime * hashCode + ((getServiceProviderName() == null) ? 0 : getServiceProviderName().hashCode()); return hashCode; } @Override public DvbSdtSettings clone() { try { return (DvbSdtSettings) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.mediaconvert.model.transform.DvbSdtSettingsMarshaller.getInstance().marshall(this, protocolMarshaller); } }