{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.MediaPackageVOD.Types.HlsPackage -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.MediaPackageVOD.Types.HlsPackage where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.MediaPackageVOD.Types.HlsEncryption import Amazonka.MediaPackageVOD.Types.HlsManifest import qualified Amazonka.Prelude as Prelude -- | An HTTP Live Streaming (HLS) packaging configuration. -- -- /See:/ 'newHlsPackage' smart constructor. data HlsPackage = HlsPackage' { encryption :: Prelude.Maybe HlsEncryption, -- | When enabled, MediaPackage passes through digital video broadcasting -- (DVB) subtitles into the output. includeDvbSubtitles :: Prelude.Maybe Prelude.Bool, -- | Duration (in seconds) of each fragment. Actual fragments will be rounded -- to the nearest multiple of the source fragment duration. segmentDurationSeconds :: Prelude.Maybe Prelude.Int, -- | When enabled, audio streams will be placed in rendition groups in the -- output. useAudioRenditionGroup :: Prelude.Maybe Prelude.Bool, -- | A list of HLS manifest configurations. hlsManifests :: [HlsManifest] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'HlsPackage' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'encryption', 'hlsPackage_encryption' - Undocumented member. -- -- 'includeDvbSubtitles', 'hlsPackage_includeDvbSubtitles' - When enabled, MediaPackage passes through digital video broadcasting -- (DVB) subtitles into the output. -- -- 'segmentDurationSeconds', 'hlsPackage_segmentDurationSeconds' - Duration (in seconds) of each fragment. Actual fragments will be rounded -- to the nearest multiple of the source fragment duration. -- -- 'useAudioRenditionGroup', 'hlsPackage_useAudioRenditionGroup' - When enabled, audio streams will be placed in rendition groups in the -- output. -- -- 'hlsManifests', 'hlsPackage_hlsManifests' - A list of HLS manifest configurations. newHlsPackage :: HlsPackage newHlsPackage = HlsPackage' { encryption = Prelude.Nothing, includeDvbSubtitles = Prelude.Nothing, segmentDurationSeconds = Prelude.Nothing, useAudioRenditionGroup = Prelude.Nothing, hlsManifests = Prelude.mempty } -- | Undocumented member. hlsPackage_encryption :: Lens.Lens' HlsPackage (Prelude.Maybe HlsEncryption) hlsPackage_encryption = Lens.lens (\HlsPackage' {encryption} -> encryption) (\s@HlsPackage' {} a -> s {encryption = a} :: HlsPackage) -- | When enabled, MediaPackage passes through digital video broadcasting -- (DVB) subtitles into the output. hlsPackage_includeDvbSubtitles :: Lens.Lens' HlsPackage (Prelude.Maybe Prelude.Bool) hlsPackage_includeDvbSubtitles = Lens.lens (\HlsPackage' {includeDvbSubtitles} -> includeDvbSubtitles) (\s@HlsPackage' {} a -> s {includeDvbSubtitles = a} :: HlsPackage) -- | Duration (in seconds) of each fragment. Actual fragments will be rounded -- to the nearest multiple of the source fragment duration. hlsPackage_segmentDurationSeconds :: Lens.Lens' HlsPackage (Prelude.Maybe Prelude.Int) hlsPackage_segmentDurationSeconds = Lens.lens (\HlsPackage' {segmentDurationSeconds} -> segmentDurationSeconds) (\s@HlsPackage' {} a -> s {segmentDurationSeconds = a} :: HlsPackage) -- | When enabled, audio streams will be placed in rendition groups in the -- output. hlsPackage_useAudioRenditionGroup :: Lens.Lens' HlsPackage (Prelude.Maybe Prelude.Bool) hlsPackage_useAudioRenditionGroup = Lens.lens (\HlsPackage' {useAudioRenditionGroup} -> useAudioRenditionGroup) (\s@HlsPackage' {} a -> s {useAudioRenditionGroup = a} :: HlsPackage) -- | A list of HLS manifest configurations. hlsPackage_hlsManifests :: Lens.Lens' HlsPackage [HlsManifest] hlsPackage_hlsManifests = Lens.lens (\HlsPackage' {hlsManifests} -> hlsManifests) (\s@HlsPackage' {} a -> s {hlsManifests = a} :: HlsPackage) Prelude.. Lens.coerced instance Data.FromJSON HlsPackage where parseJSON = Data.withObject "HlsPackage" ( \x -> HlsPackage' Prelude.<$> (x Data..:? "encryption") Prelude.<*> (x Data..:? "includeDvbSubtitles") Prelude.<*> (x Data..:? "segmentDurationSeconds") Prelude.<*> (x Data..:? "useAudioRenditionGroup") Prelude.<*> (x Data..:? "hlsManifests" Data..!= Prelude.mempty) ) instance Prelude.Hashable HlsPackage where hashWithSalt _salt HlsPackage' {..} = _salt `Prelude.hashWithSalt` encryption `Prelude.hashWithSalt` includeDvbSubtitles `Prelude.hashWithSalt` segmentDurationSeconds `Prelude.hashWithSalt` useAudioRenditionGroup `Prelude.hashWithSalt` hlsManifests instance Prelude.NFData HlsPackage where rnf HlsPackage' {..} = Prelude.rnf encryption `Prelude.seq` Prelude.rnf includeDvbSubtitles `Prelude.seq` Prelude.rnf segmentDurationSeconds `Prelude.seq` Prelude.rnf useAudioRenditionGroup `Prelude.seq` Prelude.rnf hlsManifests instance Data.ToJSON HlsPackage where toJSON HlsPackage' {..} = Data.object ( Prelude.catMaybes [ ("encryption" Data..=) Prelude.<$> encryption, ("includeDvbSubtitles" Data..=) Prelude.<$> includeDvbSubtitles, ("segmentDurationSeconds" Data..=) Prelude.<$> segmentDurationSeconds, ("useAudioRenditionGroup" Data..=) Prelude.<$> useAudioRenditionGroup, Prelude.Just ("hlsManifests" Data..= hlsManifests) ] )