{-# 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.IVS.Types.Channel -- 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.IVS.Types.Channel where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IVS.Types.ChannelLatencyMode import Amazonka.IVS.Types.ChannelType import qualified Amazonka.Prelude as Prelude -- | Object specifying a channel. -- -- /See:/ 'newChannel' smart constructor. data Channel = Channel' { -- | Channel ARN. arn :: Prelude.Maybe Prelude.Text, -- | Whether the channel is private (enabled for playback authorization). -- Default: @false@. authorized :: Prelude.Maybe Prelude.Bool, -- | Channel ingest endpoint, part of the definition of an ingest server, -- used when you set up streaming software. ingestEndpoint :: Prelude.Maybe Prelude.Text, -- | Channel latency mode. Use @NORMAL@ to broadcast and deliver live video -- up to Full HD. Use @LOW@ for near-real-time interaction with viewers. -- Default: @LOW@. (Note: In the Amazon IVS console, @LOW@ and @NORMAL@ -- correspond to Ultra-low and Standard, respectively.) latencyMode :: Prelude.Maybe ChannelLatencyMode, -- | Channel name. name :: Prelude.Maybe Prelude.Text, -- | Channel playback URL. playbackUrl :: Prelude.Maybe Prelude.Text, -- | Recording-configuration ARN. A value other than an empty string -- indicates that recording is enabled. Default: \"\" (empty string, -- recording is disabled). recordingConfigurationArn :: Prelude.Maybe Prelude.Text, -- | Array of 1-50 maps, each of the form @string:string (key:value)@. See -- -- for more information, including restrictions that apply to tags and -- \"Tag naming limits and requirements\"; Amazon IVS has no -- service-specific constraints beyond what is documented there. tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | Channel type, which determines the allowable resolution and bitrate. /If -- you exceed the allowable resolution or bitrate, the stream probably will -- disconnect immediately./ Default: @STANDARD@. Valid values: -- -- - @STANDARD@: Video is transcoded: multiple qualities are generated -- from the original input, to automatically give viewers the best -- experience for their devices and network conditions. Transcoding -- allows higher playback quality across a range of download speeds. -- Resolution can be up to 1080p and bitrate can be up to 8.5 Mbps. -- Audio is transcoded only for renditions 360p and below; above that, -- audio is passed through. This is the default. -- -- - @BASIC@: Video is transmuxed: Amazon IVS delivers the original input -- to viewers. The viewer’s video-quality choice is limited to the -- original input. Resolution can be up to 1080p and bitrate can be up -- to 1.5 Mbps for 480p and up to 3.5 Mbps for resolutions between 480p -- and 1080p. type' :: Prelude.Maybe ChannelType } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'Channel' 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: -- -- 'arn', 'channel_arn' - Channel ARN. -- -- 'authorized', 'channel_authorized' - Whether the channel is private (enabled for playback authorization). -- Default: @false@. -- -- 'ingestEndpoint', 'channel_ingestEndpoint' - Channel ingest endpoint, part of the definition of an ingest server, -- used when you set up streaming software. -- -- 'latencyMode', 'channel_latencyMode' - Channel latency mode. Use @NORMAL@ to broadcast and deliver live video -- up to Full HD. Use @LOW@ for near-real-time interaction with viewers. -- Default: @LOW@. (Note: In the Amazon IVS console, @LOW@ and @NORMAL@ -- correspond to Ultra-low and Standard, respectively.) -- -- 'name', 'channel_name' - Channel name. -- -- 'playbackUrl', 'channel_playbackUrl' - Channel playback URL. -- -- 'recordingConfigurationArn', 'channel_recordingConfigurationArn' - Recording-configuration ARN. A value other than an empty string -- indicates that recording is enabled. Default: \"\" (empty string, -- recording is disabled). -- -- 'tags', 'channel_tags' - Array of 1-50 maps, each of the form @string:string (key:value)@. See -- -- for more information, including restrictions that apply to tags and -- \"Tag naming limits and requirements\"; Amazon IVS has no -- service-specific constraints beyond what is documented there. -- -- 'type'', 'channel_type' - Channel type, which determines the allowable resolution and bitrate. /If -- you exceed the allowable resolution or bitrate, the stream probably will -- disconnect immediately./ Default: @STANDARD@. Valid values: -- -- - @STANDARD@: Video is transcoded: multiple qualities are generated -- from the original input, to automatically give viewers the best -- experience for their devices and network conditions. Transcoding -- allows higher playback quality across a range of download speeds. -- Resolution can be up to 1080p and bitrate can be up to 8.5 Mbps. -- Audio is transcoded only for renditions 360p and below; above that, -- audio is passed through. This is the default. -- -- - @BASIC@: Video is transmuxed: Amazon IVS delivers the original input -- to viewers. The viewer’s video-quality choice is limited to the -- original input. Resolution can be up to 1080p and bitrate can be up -- to 1.5 Mbps for 480p and up to 3.5 Mbps for resolutions between 480p -- and 1080p. newChannel :: Channel newChannel = Channel' { arn = Prelude.Nothing, authorized = Prelude.Nothing, ingestEndpoint = Prelude.Nothing, latencyMode = Prelude.Nothing, name = Prelude.Nothing, playbackUrl = Prelude.Nothing, recordingConfigurationArn = Prelude.Nothing, tags = Prelude.Nothing, type' = Prelude.Nothing } -- | Channel ARN. channel_arn :: Lens.Lens' Channel (Prelude.Maybe Prelude.Text) channel_arn = Lens.lens (\Channel' {arn} -> arn) (\s@Channel' {} a -> s {arn = a} :: Channel) -- | Whether the channel is private (enabled for playback authorization). -- Default: @false@. channel_authorized :: Lens.Lens' Channel (Prelude.Maybe Prelude.Bool) channel_authorized = Lens.lens (\Channel' {authorized} -> authorized) (\s@Channel' {} a -> s {authorized = a} :: Channel) -- | Channel ingest endpoint, part of the definition of an ingest server, -- used when you set up streaming software. channel_ingestEndpoint :: Lens.Lens' Channel (Prelude.Maybe Prelude.Text) channel_ingestEndpoint = Lens.lens (\Channel' {ingestEndpoint} -> ingestEndpoint) (\s@Channel' {} a -> s {ingestEndpoint = a} :: Channel) -- | Channel latency mode. Use @NORMAL@ to broadcast and deliver live video -- up to Full HD. Use @LOW@ for near-real-time interaction with viewers. -- Default: @LOW@. (Note: In the Amazon IVS console, @LOW@ and @NORMAL@ -- correspond to Ultra-low and Standard, respectively.) channel_latencyMode :: Lens.Lens' Channel (Prelude.Maybe ChannelLatencyMode) channel_latencyMode = Lens.lens (\Channel' {latencyMode} -> latencyMode) (\s@Channel' {} a -> s {latencyMode = a} :: Channel) -- | Channel name. channel_name :: Lens.Lens' Channel (Prelude.Maybe Prelude.Text) channel_name = Lens.lens (\Channel' {name} -> name) (\s@Channel' {} a -> s {name = a} :: Channel) -- | Channel playback URL. channel_playbackUrl :: Lens.Lens' Channel (Prelude.Maybe Prelude.Text) channel_playbackUrl = Lens.lens (\Channel' {playbackUrl} -> playbackUrl) (\s@Channel' {} a -> s {playbackUrl = a} :: Channel) -- | Recording-configuration ARN. A value other than an empty string -- indicates that recording is enabled. Default: \"\" (empty string, -- recording is disabled). channel_recordingConfigurationArn :: Lens.Lens' Channel (Prelude.Maybe Prelude.Text) channel_recordingConfigurationArn = Lens.lens (\Channel' {recordingConfigurationArn} -> recordingConfigurationArn) (\s@Channel' {} a -> s {recordingConfigurationArn = a} :: Channel) -- | Array of 1-50 maps, each of the form @string:string (key:value)@. See -- -- for more information, including restrictions that apply to tags and -- \"Tag naming limits and requirements\"; Amazon IVS has no -- service-specific constraints beyond what is documented there. channel_tags :: Lens.Lens' Channel (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) channel_tags = Lens.lens (\Channel' {tags} -> tags) (\s@Channel' {} a -> s {tags = a} :: Channel) Prelude.. Lens.mapping Lens.coerced -- | Channel type, which determines the allowable resolution and bitrate. /If -- you exceed the allowable resolution or bitrate, the stream probably will -- disconnect immediately./ Default: @STANDARD@. Valid values: -- -- - @STANDARD@: Video is transcoded: multiple qualities are generated -- from the original input, to automatically give viewers the best -- experience for their devices and network conditions. Transcoding -- allows higher playback quality across a range of download speeds. -- Resolution can be up to 1080p and bitrate can be up to 8.5 Mbps. -- Audio is transcoded only for renditions 360p and below; above that, -- audio is passed through. This is the default. -- -- - @BASIC@: Video is transmuxed: Amazon IVS delivers the original input -- to viewers. The viewer’s video-quality choice is limited to the -- original input. Resolution can be up to 1080p and bitrate can be up -- to 1.5 Mbps for 480p and up to 3.5 Mbps for resolutions between 480p -- and 1080p. channel_type :: Lens.Lens' Channel (Prelude.Maybe ChannelType) channel_type = Lens.lens (\Channel' {type'} -> type') (\s@Channel' {} a -> s {type' = a} :: Channel) instance Data.FromJSON Channel where parseJSON = Data.withObject "Channel" ( \x -> Channel' Prelude.<$> (x Data..:? "arn") Prelude.<*> (x Data..:? "authorized") Prelude.<*> (x Data..:? "ingestEndpoint") Prelude.<*> (x Data..:? "latencyMode") Prelude.<*> (x Data..:? "name") Prelude.<*> (x Data..:? "playbackUrl") Prelude.<*> (x Data..:? "recordingConfigurationArn") Prelude.<*> (x Data..:? "tags" Data..!= Prelude.mempty) Prelude.<*> (x Data..:? "type") ) instance Prelude.Hashable Channel where hashWithSalt _salt Channel' {..} = _salt `Prelude.hashWithSalt` arn `Prelude.hashWithSalt` authorized `Prelude.hashWithSalt` ingestEndpoint `Prelude.hashWithSalt` latencyMode `Prelude.hashWithSalt` name `Prelude.hashWithSalt` playbackUrl `Prelude.hashWithSalt` recordingConfigurationArn `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` type' instance Prelude.NFData Channel where rnf Channel' {..} = Prelude.rnf arn `Prelude.seq` Prelude.rnf authorized `Prelude.seq` Prelude.rnf ingestEndpoint `Prelude.seq` Prelude.rnf latencyMode `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf playbackUrl `Prelude.seq` Prelude.rnf recordingConfigurationArn `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf type'