com.amazonaws.services.mediaconvert.model.JobSettings Maven / Gradle / Ivy
/*
* Copyright 2013-2018 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;
/**
* JobSettings contains all the transcode settings for a job.
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class JobSettings implements Serializable, Cloneable, StructuredPojo {
/** When specified, this offset (in milliseconds) is added to the input Ad Avail PTS time. */
private Integer adAvailOffset;
/**
* Settings for ad avail blanking. Video can be blanked or overlaid with an image, and audio muted during SCTE-35
* triggered ad avails.
*/
private AvailBlanking availBlanking;
/**
* Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in a job.
* These inputs will be concantenated together to create the output.
*/
private java.util.List inputs;
private NielsenConfiguration nielsenConfiguration;
/**
* (OutputGroups) contains one group of settings for each set of outputs that share a common package type. All
* unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output group as
* well. Required in (OutputGroups) is a group of settings that apply to the whole group. This required object
* depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type, settings object pairs
* are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS, HlsGroupSettings *
* DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS, MsSmoothGroupSettings *
* CMAF_GROUP_SETTINGS, CmafGroupSettings
*/
private java.util.List outputGroups;
/** Contains settings used to acquire and adjust timecode information from inputs. */
private TimecodeConfig timecodeConfig;
private TimedMetadataInsertion timedMetadataInsertion;
/**
* When specified, this offset (in milliseconds) is added to the input Ad Avail PTS time.
*
* @param adAvailOffset
* When specified, this offset (in milliseconds) is added to the input Ad Avail PTS time.
*/
public void setAdAvailOffset(Integer adAvailOffset) {
this.adAvailOffset = adAvailOffset;
}
/**
* When specified, this offset (in milliseconds) is added to the input Ad Avail PTS time.
*
* @return When specified, this offset (in milliseconds) is added to the input Ad Avail PTS time.
*/
public Integer getAdAvailOffset() {
return this.adAvailOffset;
}
/**
* When specified, this offset (in milliseconds) is added to the input Ad Avail PTS time.
*
* @param adAvailOffset
* When specified, this offset (in milliseconds) is added to the input Ad Avail PTS time.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withAdAvailOffset(Integer adAvailOffset) {
setAdAvailOffset(adAvailOffset);
return this;
}
/**
* Settings for ad avail blanking. Video can be blanked or overlaid with an image, and audio muted during SCTE-35
* triggered ad avails.
*
* @param availBlanking
* Settings for ad avail blanking. Video can be blanked or overlaid with an image, and audio muted during
* SCTE-35 triggered ad avails.
*/
public void setAvailBlanking(AvailBlanking availBlanking) {
this.availBlanking = availBlanking;
}
/**
* Settings for ad avail blanking. Video can be blanked or overlaid with an image, and audio muted during SCTE-35
* triggered ad avails.
*
* @return Settings for ad avail blanking. Video can be blanked or overlaid with an image, and audio muted during
* SCTE-35 triggered ad avails.
*/
public AvailBlanking getAvailBlanking() {
return this.availBlanking;
}
/**
* Settings for ad avail blanking. Video can be blanked or overlaid with an image, and audio muted during SCTE-35
* triggered ad avails.
*
* @param availBlanking
* Settings for ad avail blanking. Video can be blanked or overlaid with an image, and audio muted during
* SCTE-35 triggered ad avails.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withAvailBlanking(AvailBlanking availBlanking) {
setAvailBlanking(availBlanking);
return this;
}
/**
* Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in a job.
* These inputs will be concantenated together to create the output.
*
* @return Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in
* a job. These inputs will be concantenated together to create the output.
*/
public java.util.List getInputs() {
return inputs;
}
/**
* Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in a job.
* These inputs will be concantenated together to create the output.
*
* @param inputs
* Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in a
* job. These inputs will be concantenated together to create the output.
*/
public void setInputs(java.util.Collection inputs) {
if (inputs == null) {
this.inputs = null;
return;
}
this.inputs = new java.util.ArrayList(inputs);
}
/**
* Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in a job.
* These inputs will be concantenated together to create the output.
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setInputs(java.util.Collection)} or {@link #withInputs(java.util.Collection)} if you want to override the
* existing values.
*
*
* @param inputs
* Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in a
* job. These inputs will be concantenated together to create the output.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withInputs(Input... inputs) {
if (this.inputs == null) {
setInputs(new java.util.ArrayList(inputs.length));
}
for (Input ele : inputs) {
this.inputs.add(ele);
}
return this;
}
/**
* Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in a job.
* These inputs will be concantenated together to create the output.
*
* @param inputs
* Use Inputs (inputs) to define source file used in the transcode job. There can be multiple inputs add in a
* job. These inputs will be concantenated together to create the output.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withInputs(java.util.Collection inputs) {
setInputs(inputs);
return this;
}
/**
* @param nielsenConfiguration
*/
public void setNielsenConfiguration(NielsenConfiguration nielsenConfiguration) {
this.nielsenConfiguration = nielsenConfiguration;
}
/**
* @return
*/
public NielsenConfiguration getNielsenConfiguration() {
return this.nielsenConfiguration;
}
/**
* @param nielsenConfiguration
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withNielsenConfiguration(NielsenConfiguration nielsenConfiguration) {
setNielsenConfiguration(nielsenConfiguration);
return this;
}
/**
* (OutputGroups) contains one group of settings for each set of outputs that share a common package type. All
* unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output group as
* well. Required in (OutputGroups) is a group of settings that apply to the whole group. This required object
* depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type, settings object pairs
* are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS, HlsGroupSettings *
* DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS, MsSmoothGroupSettings *
* CMAF_GROUP_SETTINGS, CmafGroupSettings
*
* @return (OutputGroups) contains one group of settings for each set of outputs that share a common package type.
* All unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output
* group as well. Required in (OutputGroups) is a group of settings that apply to the whole group. This
* required object depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type,
* settings object pairs are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS,
* HlsGroupSettings * DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS,
* MsSmoothGroupSettings * CMAF_GROUP_SETTINGS, CmafGroupSettings
*/
public java.util.List getOutputGroups() {
return outputGroups;
}
/**
* (OutputGroups) contains one group of settings for each set of outputs that share a common package type. All
* unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output group as
* well. Required in (OutputGroups) is a group of settings that apply to the whole group. This required object
* depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type, settings object pairs
* are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS, HlsGroupSettings *
* DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS, MsSmoothGroupSettings *
* CMAF_GROUP_SETTINGS, CmafGroupSettings
*
* @param outputGroups
* (OutputGroups) contains one group of settings for each set of outputs that share a common package type.
* All unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output
* group as well. Required in (OutputGroups) is a group of settings that apply to the whole group. This
* required object depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type,
* settings object pairs are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS,
* HlsGroupSettings * DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS,
* MsSmoothGroupSettings * CMAF_GROUP_SETTINGS, CmafGroupSettings
*/
public void setOutputGroups(java.util.Collection outputGroups) {
if (outputGroups == null) {
this.outputGroups = null;
return;
}
this.outputGroups = new java.util.ArrayList(outputGroups);
}
/**
* (OutputGroups) contains one group of settings for each set of outputs that share a common package type. All
* unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output group as
* well. Required in (OutputGroups) is a group of settings that apply to the whole group. This required object
* depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type, settings object pairs
* are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS, HlsGroupSettings *
* DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS, MsSmoothGroupSettings *
* CMAF_GROUP_SETTINGS, CmafGroupSettings
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setOutputGroups(java.util.Collection)} or {@link #withOutputGroups(java.util.Collection)} if you want to
* override the existing values.
*
*
* @param outputGroups
* (OutputGroups) contains one group of settings for each set of outputs that share a common package type.
* All unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output
* group as well. Required in (OutputGroups) is a group of settings that apply to the whole group. This
* required object depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type,
* settings object pairs are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS,
* HlsGroupSettings * DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS,
* MsSmoothGroupSettings * CMAF_GROUP_SETTINGS, CmafGroupSettings
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withOutputGroups(OutputGroup... outputGroups) {
if (this.outputGroups == null) {
setOutputGroups(new java.util.ArrayList(outputGroups.length));
}
for (OutputGroup ele : outputGroups) {
this.outputGroups.add(ele);
}
return this;
}
/**
* (OutputGroups) contains one group of settings for each set of outputs that share a common package type. All
* unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output group as
* well. Required in (OutputGroups) is a group of settings that apply to the whole group. This required object
* depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type, settings object pairs
* are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS, HlsGroupSettings *
* DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS, MsSmoothGroupSettings *
* CMAF_GROUP_SETTINGS, CmafGroupSettings
*
* @param outputGroups
* (OutputGroups) contains one group of settings for each set of outputs that share a common package type.
* All unpackaged files (MPEG-4, MPEG-2 TS, Quicktime, MXF, and no container) are grouped in a single output
* group as well. Required in (OutputGroups) is a group of settings that apply to the whole group. This
* required object depends on the value you set for (Type) under (OutputGroups)>(OutputGroupSettings). Type,
* settings object pairs are as follows. * FILE_GROUP_SETTINGS, FileGroupSettings * HLS_GROUP_SETTINGS,
* HlsGroupSettings * DASH_ISO_GROUP_SETTINGS, DashIsoGroupSettings * MS_SMOOTH_GROUP_SETTINGS,
* MsSmoothGroupSettings * CMAF_GROUP_SETTINGS, CmafGroupSettings
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withOutputGroups(java.util.Collection outputGroups) {
setOutputGroups(outputGroups);
return this;
}
/**
* Contains settings used to acquire and adjust timecode information from inputs.
*
* @param timecodeConfig
* Contains settings used to acquire and adjust timecode information from inputs.
*/
public void setTimecodeConfig(TimecodeConfig timecodeConfig) {
this.timecodeConfig = timecodeConfig;
}
/**
* Contains settings used to acquire and adjust timecode information from inputs.
*
* @return Contains settings used to acquire and adjust timecode information from inputs.
*/
public TimecodeConfig getTimecodeConfig() {
return this.timecodeConfig;
}
/**
* Contains settings used to acquire and adjust timecode information from inputs.
*
* @param timecodeConfig
* Contains settings used to acquire and adjust timecode information from inputs.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withTimecodeConfig(TimecodeConfig timecodeConfig) {
setTimecodeConfig(timecodeConfig);
return this;
}
/**
* @param timedMetadataInsertion
*/
public void setTimedMetadataInsertion(TimedMetadataInsertion timedMetadataInsertion) {
this.timedMetadataInsertion = timedMetadataInsertion;
}
/**
* @return
*/
public TimedMetadataInsertion getTimedMetadataInsertion() {
return this.timedMetadataInsertion;
}
/**
* @param timedMetadataInsertion
* @return Returns a reference to this object so that method calls can be chained together.
*/
public JobSettings withTimedMetadataInsertion(TimedMetadataInsertion timedMetadataInsertion) {
setTimedMetadataInsertion(timedMetadataInsertion);
return this;
}
/**
* Returns a string representation of this object; useful for testing and debugging.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getAdAvailOffset() != null)
sb.append("AdAvailOffset: ").append(getAdAvailOffset()).append(",");
if (getAvailBlanking() != null)
sb.append("AvailBlanking: ").append(getAvailBlanking()).append(",");
if (getInputs() != null)
sb.append("Inputs: ").append(getInputs()).append(",");
if (getNielsenConfiguration() != null)
sb.append("NielsenConfiguration: ").append(getNielsenConfiguration()).append(",");
if (getOutputGroups() != null)
sb.append("OutputGroups: ").append(getOutputGroups()).append(",");
if (getTimecodeConfig() != null)
sb.append("TimecodeConfig: ").append(getTimecodeConfig()).append(",");
if (getTimedMetadataInsertion() != null)
sb.append("TimedMetadataInsertion: ").append(getTimedMetadataInsertion());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof JobSettings == false)
return false;
JobSettings other = (JobSettings) obj;
if (other.getAdAvailOffset() == null ^ this.getAdAvailOffset() == null)
return false;
if (other.getAdAvailOffset() != null && other.getAdAvailOffset().equals(this.getAdAvailOffset()) == false)
return false;
if (other.getAvailBlanking() == null ^ this.getAvailBlanking() == null)
return false;
if (other.getAvailBlanking() != null && other.getAvailBlanking().equals(this.getAvailBlanking()) == false)
return false;
if (other.getInputs() == null ^ this.getInputs() == null)
return false;
if (other.getInputs() != null && other.getInputs().equals(this.getInputs()) == false)
return false;
if (other.getNielsenConfiguration() == null ^ this.getNielsenConfiguration() == null)
return false;
if (other.getNielsenConfiguration() != null && other.getNielsenConfiguration().equals(this.getNielsenConfiguration()) == false)
return false;
if (other.getOutputGroups() == null ^ this.getOutputGroups() == null)
return false;
if (other.getOutputGroups() != null && other.getOutputGroups().equals(this.getOutputGroups()) == false)
return false;
if (other.getTimecodeConfig() == null ^ this.getTimecodeConfig() == null)
return false;
if (other.getTimecodeConfig() != null && other.getTimecodeConfig().equals(this.getTimecodeConfig()) == false)
return false;
if (other.getTimedMetadataInsertion() == null ^ this.getTimedMetadataInsertion() == null)
return false;
if (other.getTimedMetadataInsertion() != null && other.getTimedMetadataInsertion().equals(this.getTimedMetadataInsertion()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getAdAvailOffset() == null) ? 0 : getAdAvailOffset().hashCode());
hashCode = prime * hashCode + ((getAvailBlanking() == null) ? 0 : getAvailBlanking().hashCode());
hashCode = prime * hashCode + ((getInputs() == null) ? 0 : getInputs().hashCode());
hashCode = prime * hashCode + ((getNielsenConfiguration() == null) ? 0 : getNielsenConfiguration().hashCode());
hashCode = prime * hashCode + ((getOutputGroups() == null) ? 0 : getOutputGroups().hashCode());
hashCode = prime * hashCode + ((getTimecodeConfig() == null) ? 0 : getTimecodeConfig().hashCode());
hashCode = prime * hashCode + ((getTimedMetadataInsertion() == null) ? 0 : getTimedMetadataInsertion().hashCode());
return hashCode;
}
@Override
public JobSettings clone() {
try {
return (JobSettings) 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.JobSettingsMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy