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

com.amazonaws.services.mediaconvert.model.CaptionSourceSettings Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Elemental MediaConvert module holds the client classes that are used for communicating with AWS Elemental MediaConvert Service

The newest version!
/*
 * Copyright 2019-2024 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;

/**
 * If your input captions are SCC, TTML, STL, SMI, SRT, or IMSC in an xml file, specify the URI of the input captions
 * source file. If your input captions are IMSC in an IMF package, use TrackSourceSettings instead of FileSoureSettings.
 * 
 * @see AWS
 *      API Documentation
 */
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class CaptionSourceSettings implements Serializable, Cloneable, StructuredPojo {

    /** Settings for ancillary captions source. */
    private AncillarySourceSettings ancillarySourceSettings;
    /** DVB Sub Source Settings */
    private DvbSubSourceSettings dvbSubSourceSettings;
    /** Settings for embedded captions Source */
    private EmbeddedSourceSettings embeddedSourceSettings;
    /**
     * If your input captions are SCC, SMI, SRT, STL, TTML, WebVTT, or IMSC 1.1 in an xml file, specify the URI of the
     * input caption source file. If your caption source is IMSC in an IMF package, use TrackSourceSettings instead of
     * FileSoureSettings.
     */
    private FileSourceSettings fileSourceSettings;
    /** Use Source to identify the format of your input captions. The service cannot auto-detect caption format. */
    private String sourceType;
    /** Settings specific to Teletext caption sources, including Page number. */
    private TeletextSourceSettings teletextSourceSettings;
    /**
     * Settings specific to caption sources that are specified by track number. Currently, this is only IMSC captions in
     * an IMF package. If your caption source is IMSC 1.1 in a separate xml file, use FileSourceSettings instead of
     * TrackSourceSettings.
     */
    private TrackSourceSettings trackSourceSettings;
    /**
     * Settings specific to WebVTT sources in HLS alternative rendition group. Specify the properties (renditionGroupId,
     * renditionName or renditionLanguageCode) to identify the unique subtitle track among the alternative rendition
     * groups present in the HLS manifest. If no unique track is found, or multiple tracks match the specified
     * properties, the job fails. If there is only one subtitle track in the rendition group, the settings can be left
     * empty and the default subtitle track will be chosen. If your caption source is a sidecar file, use
     * FileSourceSettings instead of WebvttHlsSourceSettings.
     */
    private WebvttHlsSourceSettings webvttHlsSourceSettings;

    /**
     * Settings for ancillary captions source.
     * 
     * @param ancillarySourceSettings
     *        Settings for ancillary captions source.
     */

    public void setAncillarySourceSettings(AncillarySourceSettings ancillarySourceSettings) {
        this.ancillarySourceSettings = ancillarySourceSettings;
    }

    /**
     * Settings for ancillary captions source.
     * 
     * @return Settings for ancillary captions source.
     */

    public AncillarySourceSettings getAncillarySourceSettings() {
        return this.ancillarySourceSettings;
    }

    /**
     * Settings for ancillary captions source.
     * 
     * @param ancillarySourceSettings
     *        Settings for ancillary captions source.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public CaptionSourceSettings withAncillarySourceSettings(AncillarySourceSettings ancillarySourceSettings) {
        setAncillarySourceSettings(ancillarySourceSettings);
        return this;
    }

    /**
     * DVB Sub Source Settings
     * 
     * @param dvbSubSourceSettings
     *        DVB Sub Source Settings
     */

    public void setDvbSubSourceSettings(DvbSubSourceSettings dvbSubSourceSettings) {
        this.dvbSubSourceSettings = dvbSubSourceSettings;
    }

    /**
     * DVB Sub Source Settings
     * 
     * @return DVB Sub Source Settings
     */

    public DvbSubSourceSettings getDvbSubSourceSettings() {
        return this.dvbSubSourceSettings;
    }

    /**
     * DVB Sub Source Settings
     * 
     * @param dvbSubSourceSettings
     *        DVB Sub Source Settings
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public CaptionSourceSettings withDvbSubSourceSettings(DvbSubSourceSettings dvbSubSourceSettings) {
        setDvbSubSourceSettings(dvbSubSourceSettings);
        return this;
    }

    /**
     * Settings for embedded captions Source
     * 
     * @param embeddedSourceSettings
     *        Settings for embedded captions Source
     */

    public void setEmbeddedSourceSettings(EmbeddedSourceSettings embeddedSourceSettings) {
        this.embeddedSourceSettings = embeddedSourceSettings;
    }

    /**
     * Settings for embedded captions Source
     * 
     * @return Settings for embedded captions Source
     */

    public EmbeddedSourceSettings getEmbeddedSourceSettings() {
        return this.embeddedSourceSettings;
    }

    /**
     * Settings for embedded captions Source
     * 
     * @param embeddedSourceSettings
     *        Settings for embedded captions Source
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public CaptionSourceSettings withEmbeddedSourceSettings(EmbeddedSourceSettings embeddedSourceSettings) {
        setEmbeddedSourceSettings(embeddedSourceSettings);
        return this;
    }

    /**
     * If your input captions are SCC, SMI, SRT, STL, TTML, WebVTT, or IMSC 1.1 in an xml file, specify the URI of the
     * input caption source file. If your caption source is IMSC in an IMF package, use TrackSourceSettings instead of
     * FileSoureSettings.
     * 
     * @param fileSourceSettings
     *        If your input captions are SCC, SMI, SRT, STL, TTML, WebVTT, or IMSC 1.1 in an xml file, specify the URI
     *        of the input caption source file. If your caption source is IMSC in an IMF package, use
     *        TrackSourceSettings instead of FileSoureSettings.
     */

    public void setFileSourceSettings(FileSourceSettings fileSourceSettings) {
        this.fileSourceSettings = fileSourceSettings;
    }

    /**
     * If your input captions are SCC, SMI, SRT, STL, TTML, WebVTT, or IMSC 1.1 in an xml file, specify the URI of the
     * input caption source file. If your caption source is IMSC in an IMF package, use TrackSourceSettings instead of
     * FileSoureSettings.
     * 
     * @return If your input captions are SCC, SMI, SRT, STL, TTML, WebVTT, or IMSC 1.1 in an xml file, specify the URI
     *         of the input caption source file. If your caption source is IMSC in an IMF package, use
     *         TrackSourceSettings instead of FileSoureSettings.
     */

    public FileSourceSettings getFileSourceSettings() {
        return this.fileSourceSettings;
    }

    /**
     * If your input captions are SCC, SMI, SRT, STL, TTML, WebVTT, or IMSC 1.1 in an xml file, specify the URI of the
     * input caption source file. If your caption source is IMSC in an IMF package, use TrackSourceSettings instead of
     * FileSoureSettings.
     * 
     * @param fileSourceSettings
     *        If your input captions are SCC, SMI, SRT, STL, TTML, WebVTT, or IMSC 1.1 in an xml file, specify the URI
     *        of the input caption source file. If your caption source is IMSC in an IMF package, use
     *        TrackSourceSettings instead of FileSoureSettings.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public CaptionSourceSettings withFileSourceSettings(FileSourceSettings fileSourceSettings) {
        setFileSourceSettings(fileSourceSettings);
        return this;
    }

    /**
     * Use Source to identify the format of your input captions. The service cannot auto-detect caption format.
     * 
     * @param sourceType
     *        Use Source to identify the format of your input captions. The service cannot auto-detect caption format.
     * @see CaptionSourceType
     */

    public void setSourceType(String sourceType) {
        this.sourceType = sourceType;
    }

    /**
     * Use Source to identify the format of your input captions. The service cannot auto-detect caption format.
     * 
     * @return Use Source to identify the format of your input captions. The service cannot auto-detect caption format.
     * @see CaptionSourceType
     */

    public String getSourceType() {
        return this.sourceType;
    }

    /**
     * Use Source to identify the format of your input captions. The service cannot auto-detect caption format.
     * 
     * @param sourceType
     *        Use Source to identify the format of your input captions. The service cannot auto-detect caption format.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see CaptionSourceType
     */

    public CaptionSourceSettings withSourceType(String sourceType) {
        setSourceType(sourceType);
        return this;
    }

    /**
     * Use Source to identify the format of your input captions. The service cannot auto-detect caption format.
     * 
     * @param sourceType
     *        Use Source to identify the format of your input captions. The service cannot auto-detect caption format.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see CaptionSourceType
     */

    public CaptionSourceSettings withSourceType(CaptionSourceType sourceType) {
        this.sourceType = sourceType.toString();
        return this;
    }

    /**
     * Settings specific to Teletext caption sources, including Page number.
     * 
     * @param teletextSourceSettings
     *        Settings specific to Teletext caption sources, including Page number.
     */

    public void setTeletextSourceSettings(TeletextSourceSettings teletextSourceSettings) {
        this.teletextSourceSettings = teletextSourceSettings;
    }

    /**
     * Settings specific to Teletext caption sources, including Page number.
     * 
     * @return Settings specific to Teletext caption sources, including Page number.
     */

    public TeletextSourceSettings getTeletextSourceSettings() {
        return this.teletextSourceSettings;
    }

    /**
     * Settings specific to Teletext caption sources, including Page number.
     * 
     * @param teletextSourceSettings
     *        Settings specific to Teletext caption sources, including Page number.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public CaptionSourceSettings withTeletextSourceSettings(TeletextSourceSettings teletextSourceSettings) {
        setTeletextSourceSettings(teletextSourceSettings);
        return this;
    }

    /**
     * Settings specific to caption sources that are specified by track number. Currently, this is only IMSC captions in
     * an IMF package. If your caption source is IMSC 1.1 in a separate xml file, use FileSourceSettings instead of
     * TrackSourceSettings.
     * 
     * @param trackSourceSettings
     *        Settings specific to caption sources that are specified by track number. Currently, this is only IMSC
     *        captions in an IMF package. If your caption source is IMSC 1.1 in a separate xml file, use
     *        FileSourceSettings instead of TrackSourceSettings.
     */

    public void setTrackSourceSettings(TrackSourceSettings trackSourceSettings) {
        this.trackSourceSettings = trackSourceSettings;
    }

    /**
     * Settings specific to caption sources that are specified by track number. Currently, this is only IMSC captions in
     * an IMF package. If your caption source is IMSC 1.1 in a separate xml file, use FileSourceSettings instead of
     * TrackSourceSettings.
     * 
     * @return Settings specific to caption sources that are specified by track number. Currently, this is only IMSC
     *         captions in an IMF package. If your caption source is IMSC 1.1 in a separate xml file, use
     *         FileSourceSettings instead of TrackSourceSettings.
     */

    public TrackSourceSettings getTrackSourceSettings() {
        return this.trackSourceSettings;
    }

    /**
     * Settings specific to caption sources that are specified by track number. Currently, this is only IMSC captions in
     * an IMF package. If your caption source is IMSC 1.1 in a separate xml file, use FileSourceSettings instead of
     * TrackSourceSettings.
     * 
     * @param trackSourceSettings
     *        Settings specific to caption sources that are specified by track number. Currently, this is only IMSC
     *        captions in an IMF package. If your caption source is IMSC 1.1 in a separate xml file, use
     *        FileSourceSettings instead of TrackSourceSettings.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public CaptionSourceSettings withTrackSourceSettings(TrackSourceSettings trackSourceSettings) {
        setTrackSourceSettings(trackSourceSettings);
        return this;
    }

    /**
     * Settings specific to WebVTT sources in HLS alternative rendition group. Specify the properties (renditionGroupId,
     * renditionName or renditionLanguageCode) to identify the unique subtitle track among the alternative rendition
     * groups present in the HLS manifest. If no unique track is found, or multiple tracks match the specified
     * properties, the job fails. If there is only one subtitle track in the rendition group, the settings can be left
     * empty and the default subtitle track will be chosen. If your caption source is a sidecar file, use
     * FileSourceSettings instead of WebvttHlsSourceSettings.
     * 
     * @param webvttHlsSourceSettings
     *        Settings specific to WebVTT sources in HLS alternative rendition group. Specify the properties
     *        (renditionGroupId, renditionName or renditionLanguageCode) to identify the unique subtitle track among the
     *        alternative rendition groups present in the HLS manifest. If no unique track is found, or multiple tracks
     *        match the specified properties, the job fails. If there is only one subtitle track in the rendition group,
     *        the settings can be left empty and the default subtitle track will be chosen. If your caption source is a
     *        sidecar file, use FileSourceSettings instead of WebvttHlsSourceSettings.
     */

    public void setWebvttHlsSourceSettings(WebvttHlsSourceSettings webvttHlsSourceSettings) {
        this.webvttHlsSourceSettings = webvttHlsSourceSettings;
    }

    /**
     * Settings specific to WebVTT sources in HLS alternative rendition group. Specify the properties (renditionGroupId,
     * renditionName or renditionLanguageCode) to identify the unique subtitle track among the alternative rendition
     * groups present in the HLS manifest. If no unique track is found, or multiple tracks match the specified
     * properties, the job fails. If there is only one subtitle track in the rendition group, the settings can be left
     * empty and the default subtitle track will be chosen. If your caption source is a sidecar file, use
     * FileSourceSettings instead of WebvttHlsSourceSettings.
     * 
     * @return Settings specific to WebVTT sources in HLS alternative rendition group. Specify the properties
     *         (renditionGroupId, renditionName or renditionLanguageCode) to identify the unique subtitle track among
     *         the alternative rendition groups present in the HLS manifest. If no unique track is found, or multiple
     *         tracks match the specified properties, the job fails. If there is only one subtitle track in the
     *         rendition group, the settings can be left empty and the default subtitle track will be chosen. If your
     *         caption source is a sidecar file, use FileSourceSettings instead of WebvttHlsSourceSettings.
     */

    public WebvttHlsSourceSettings getWebvttHlsSourceSettings() {
        return this.webvttHlsSourceSettings;
    }

    /**
     * Settings specific to WebVTT sources in HLS alternative rendition group. Specify the properties (renditionGroupId,
     * renditionName or renditionLanguageCode) to identify the unique subtitle track among the alternative rendition
     * groups present in the HLS manifest. If no unique track is found, or multiple tracks match the specified
     * properties, the job fails. If there is only one subtitle track in the rendition group, the settings can be left
     * empty and the default subtitle track will be chosen. If your caption source is a sidecar file, use
     * FileSourceSettings instead of WebvttHlsSourceSettings.
     * 
     * @param webvttHlsSourceSettings
     *        Settings specific to WebVTT sources in HLS alternative rendition group. Specify the properties
     *        (renditionGroupId, renditionName or renditionLanguageCode) to identify the unique subtitle track among the
     *        alternative rendition groups present in the HLS manifest. If no unique track is found, or multiple tracks
     *        match the specified properties, the job fails. If there is only one subtitle track in the rendition group,
     *        the settings can be left empty and the default subtitle track will be chosen. If your caption source is a
     *        sidecar file, use FileSourceSettings instead of WebvttHlsSourceSettings.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public CaptionSourceSettings withWebvttHlsSourceSettings(WebvttHlsSourceSettings webvttHlsSourceSettings) {
        setWebvttHlsSourceSettings(webvttHlsSourceSettings);
        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 (getAncillarySourceSettings() != null)
            sb.append("AncillarySourceSettings: ").append(getAncillarySourceSettings()).append(",");
        if (getDvbSubSourceSettings() != null)
            sb.append("DvbSubSourceSettings: ").append(getDvbSubSourceSettings()).append(",");
        if (getEmbeddedSourceSettings() != null)
            sb.append("EmbeddedSourceSettings: ").append(getEmbeddedSourceSettings()).append(",");
        if (getFileSourceSettings() != null)
            sb.append("FileSourceSettings: ").append(getFileSourceSettings()).append(",");
        if (getSourceType() != null)
            sb.append("SourceType: ").append(getSourceType()).append(",");
        if (getTeletextSourceSettings() != null)
            sb.append("TeletextSourceSettings: ").append(getTeletextSourceSettings()).append(",");
        if (getTrackSourceSettings() != null)
            sb.append("TrackSourceSettings: ").append(getTrackSourceSettings()).append(",");
        if (getWebvttHlsSourceSettings() != null)
            sb.append("WebvttHlsSourceSettings: ").append(getWebvttHlsSourceSettings());
        sb.append("}");
        return sb.toString();
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;

        if (obj instanceof CaptionSourceSettings == false)
            return false;
        CaptionSourceSettings other = (CaptionSourceSettings) obj;
        if (other.getAncillarySourceSettings() == null ^ this.getAncillarySourceSettings() == null)
            return false;
        if (other.getAncillarySourceSettings() != null && other.getAncillarySourceSettings().equals(this.getAncillarySourceSettings()) == false)
            return false;
        if (other.getDvbSubSourceSettings() == null ^ this.getDvbSubSourceSettings() == null)
            return false;
        if (other.getDvbSubSourceSettings() != null && other.getDvbSubSourceSettings().equals(this.getDvbSubSourceSettings()) == false)
            return false;
        if (other.getEmbeddedSourceSettings() == null ^ this.getEmbeddedSourceSettings() == null)
            return false;
        if (other.getEmbeddedSourceSettings() != null && other.getEmbeddedSourceSettings().equals(this.getEmbeddedSourceSettings()) == false)
            return false;
        if (other.getFileSourceSettings() == null ^ this.getFileSourceSettings() == null)
            return false;
        if (other.getFileSourceSettings() != null && other.getFileSourceSettings().equals(this.getFileSourceSettings()) == false)
            return false;
        if (other.getSourceType() == null ^ this.getSourceType() == null)
            return false;
        if (other.getSourceType() != null && other.getSourceType().equals(this.getSourceType()) == false)
            return false;
        if (other.getTeletextSourceSettings() == null ^ this.getTeletextSourceSettings() == null)
            return false;
        if (other.getTeletextSourceSettings() != null && other.getTeletextSourceSettings().equals(this.getTeletextSourceSettings()) == false)
            return false;
        if (other.getTrackSourceSettings() == null ^ this.getTrackSourceSettings() == null)
            return false;
        if (other.getTrackSourceSettings() != null && other.getTrackSourceSettings().equals(this.getTrackSourceSettings()) == false)
            return false;
        if (other.getWebvttHlsSourceSettings() == null ^ this.getWebvttHlsSourceSettings() == null)
            return false;
        if (other.getWebvttHlsSourceSettings() != null && other.getWebvttHlsSourceSettings().equals(this.getWebvttHlsSourceSettings()) == false)
            return false;
        return true;
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int hashCode = 1;

        hashCode = prime * hashCode + ((getAncillarySourceSettings() == null) ? 0 : getAncillarySourceSettings().hashCode());
        hashCode = prime * hashCode + ((getDvbSubSourceSettings() == null) ? 0 : getDvbSubSourceSettings().hashCode());
        hashCode = prime * hashCode + ((getEmbeddedSourceSettings() == null) ? 0 : getEmbeddedSourceSettings().hashCode());
        hashCode = prime * hashCode + ((getFileSourceSettings() == null) ? 0 : getFileSourceSettings().hashCode());
        hashCode = prime * hashCode + ((getSourceType() == null) ? 0 : getSourceType().hashCode());
        hashCode = prime * hashCode + ((getTeletextSourceSettings() == null) ? 0 : getTeletextSourceSettings().hashCode());
        hashCode = prime * hashCode + ((getTrackSourceSettings() == null) ? 0 : getTrackSourceSettings().hashCode());
        hashCode = prime * hashCode + ((getWebvttHlsSourceSettings() == null) ? 0 : getWebvttHlsSourceSettings().hashCode());
        return hashCode;
    }

    @Override
    public CaptionSourceSettings clone() {
        try {
            return (CaptionSourceSettings) 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.CaptionSourceSettingsMarshaller.getInstance().marshall(this, protocolMarshaller);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy