amazonka-kinesis-video-archived-media-2.0: Amazon Kinesis Video Streams Archived Media SDK.
Copyright(c) 2013-2023 Brendan Hay
LicenseMozilla Public License, v. 2.0.
MaintainerBrendan Hay
Stabilityauto-generated
Portabilitynon-portable (GHC extensions)
Safe HaskellSafe-Inferred
LanguageHaskell2010

Amazonka.KinesisVideoArchivedMedia.GetClip

Description

Downloads an MP4 file (clip) containing the archived, on-demand media from the specified video stream over the specified time range.

Both the StreamName and the StreamARN parameters are optional, but you must specify either the StreamName or the StreamARN when invoking this API operation.

As a prerequisite to using GetCLip API, you must obtain an endpoint using GetDataEndpoint, specifying GET_CLIP for the APIName parameter.

An Amazon Kinesis video stream has the following requirements for providing data through MP4:

  • The media must contain h.264 or h.265 encoded video and, optionally, AAC or G.711 encoded audio. Specifically, the codec ID of track 1 should be V_MPEG/ISO/AVC (for h.264) or V_MPEGH/ISO/HEVC (for H.265). Optionally, the codec ID of track 2 should be A_AAC (for AAC) or A_MS/ACM (for G.711).
  • Data retention must be greater than 0.
  • The video track of each fragment must contain codec private data in the Advanced Video Coding (AVC) for H.264 format and HEVC for H.265 format. For more information, see MPEG-4 specification ISO/IEC 14496-15. For information about adapting stream data to a given format, see NAL Adaptation Flags.
  • The audio track (if present) of each fragment must contain codec private data in the AAC format (AAC specification ISO/IEC 13818-7) or the MS Wave format.

You can monitor the amount of outgoing data by monitoring the GetClip.OutgoingBytes Amazon CloudWatch metric. For information about using CloudWatch to monitor Kinesis Video Streams, see Monitoring Kinesis Video Streams. For pricing information, see Amazon Kinesis Video Streams Pricing and AWS Pricing. Charges for outgoing AWS data apply.

Synopsis

Creating a Request

data GetClip Source #

See: newGetClip smart constructor.

Constructors

GetClip' 

Fields

  • streamARN :: Maybe Text

    The Amazon Resource Name (ARN) of the stream for which to retrieve the media clip.

    You must specify either the StreamName or the StreamARN.

  • streamName :: Maybe Text

    The name of the stream for which to retrieve the media clip.

    You must specify either the StreamName or the StreamARN.

  • clipFragmentSelector :: ClipFragmentSelector

    The time range of the requested clip and the source of the timestamps.

Instances

Instances details
ToJSON GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

ToHeaders GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Methods

toHeaders :: GetClip -> [Header] #

ToPath GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Methods

toPath :: GetClip -> ByteString #

ToQuery GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

AWSRequest GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Associated Types

type AWSResponse GetClip #

Generic GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Associated Types

type Rep GetClip :: Type -> Type #

Methods

from :: GetClip -> Rep GetClip x #

to :: Rep GetClip x -> GetClip #

Read GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Show GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

NFData GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Methods

rnf :: GetClip -> () #

Eq GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Methods

(==) :: GetClip -> GetClip -> Bool #

(/=) :: GetClip -> GetClip -> Bool #

Hashable GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Methods

hashWithSalt :: Int -> GetClip -> Int #

hash :: GetClip -> Int #

type AWSResponse GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

type Rep GetClip Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

type Rep GetClip = D1 ('MetaData "GetClip" "Amazonka.KinesisVideoArchivedMedia.GetClip" "amazonka-kinesis-video-archived-media-2.0-ByMPs2ZAQOi357CZJGqXlN" 'False) (C1 ('MetaCons "GetClip'" 'PrefixI 'True) (S1 ('MetaSel ('Just "streamARN") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedStrict) (Rec0 (Maybe Text)) :*: (S1 ('MetaSel ('Just "streamName") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedStrict) (Rec0 (Maybe Text)) :*: S1 ('MetaSel ('Just "clipFragmentSelector") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedStrict) (Rec0 ClipFragmentSelector))))

newGetClip Source #

Create a value of GetClip with all optional fields omitted.

Use generic-lens or optics to modify other optional fields.

The following record fields are available, with the corresponding lenses provided for backwards compatibility:

$sel:streamARN:GetClip', getClip_streamARN - The Amazon Resource Name (ARN) of the stream for which to retrieve the media clip.

You must specify either the StreamName or the StreamARN.

$sel:streamName:GetClip', getClip_streamName - The name of the stream for which to retrieve the media clip.

You must specify either the StreamName or the StreamARN.

$sel:clipFragmentSelector:GetClip', getClip_clipFragmentSelector - The time range of the requested clip and the source of the timestamps.

Request Lenses

getClip_streamARN :: Lens' GetClip (Maybe Text) Source #

The Amazon Resource Name (ARN) of the stream for which to retrieve the media clip.

You must specify either the StreamName or the StreamARN.

getClip_streamName :: Lens' GetClip (Maybe Text) Source #

The name of the stream for which to retrieve the media clip.

You must specify either the StreamName or the StreamARN.

getClip_clipFragmentSelector :: Lens' GetClip ClipFragmentSelector Source #

The time range of the requested clip and the source of the timestamps.

Destructuring the Response

data GetClipResponse Source #

See: newGetClipResponse smart constructor.

Constructors

GetClipResponse' 

Fields

Instances

Instances details
Generic GetClipResponse Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

Associated Types

type Rep GetClipResponse :: Type -> Type #

Show GetClipResponse Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

type Rep GetClipResponse Source # 
Instance details

Defined in Amazonka.KinesisVideoArchivedMedia.GetClip

type Rep GetClipResponse = D1 ('MetaData "GetClipResponse" "Amazonka.KinesisVideoArchivedMedia.GetClip" "amazonka-kinesis-video-archived-media-2.0-ByMPs2ZAQOi357CZJGqXlN" 'False) (C1 ('MetaCons "GetClipResponse'" 'PrefixI 'True) (S1 ('MetaSel ('Just "contentType") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedStrict) (Rec0 (Maybe Text)) :*: (S1 ('MetaSel ('Just "httpStatus") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedStrict) (Rec0 Int) :*: S1 ('MetaSel ('Just "payload") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedStrict) (Rec0 ResponseBody))))

newGetClipResponse Source #

Create a value of GetClipResponse with all optional fields omitted.

Use generic-lens or optics to modify other optional fields.

The following record fields are available, with the corresponding lenses provided for backwards compatibility:

$sel:contentType:GetClipResponse', getClipResponse_contentType - The content type of the media in the requested clip.

$sel:httpStatus:GetClipResponse', getClipResponse_httpStatus - The response's http status code.

$sel:payload:GetClipResponse', getClipResponse_payload - Traditional MP4 file that contains the media clip from the specified video stream. The output will contain the first 100 MB or the first 200 fragments from the specified start timestamp. For more information, see Kinesis Video Streams Limits.

Response Lenses

getClipResponse_contentType :: Lens' GetClipResponse (Maybe Text) Source #

The content type of the media in the requested clip.

getClipResponse_httpStatus :: Lens' GetClipResponse Int Source #

The response's http status code.

getClipResponse_payload :: Lens' GetClipResponse ResponseBody Source #

Traditional MP4 file that contains the media clip from the specified video stream. The output will contain the first 100 MB or the first 200 fragments from the specified start timestamp. For more information, see Kinesis Video Streams Limits.