# Using streams Streams can sometimes be quite picky on how they can be used. So here is a guide on how to use them. ## Essentials All streams have the same common parameters: - `Stream.type`: The type of stream. Either `hls` or `file` - `Stream.id`: The id of this stream, unique per scraper output. - `Stream.flags`: A list of flags that apply to this stream. Most people won't need to use it. - `Stream.captions`: A list of captions/subtitles for this stream. - `Stream.headers`: Either undefined or a key value object of headers you must set to use the stream. - `Stream.preferredHeaders`: Either undefined or a key value object of headers you may want to set if you want optimal playback - but not required. Now let's delve deeper into how to actually watch these streams! ## Streams with type `hls` HLS streams can be tough to watch, it's not a normal file you can just use. These streams have an extra property `Stream.playlist` which contains the m3u8 playlist. Here is a code sample of how to use HLS streams in web context using hls.js ```html ``` ## Streams with type `file` File streams are quite easy to use, it just returns a new property: `Stream.qualities`. This property is a map of quality and a stream file. So if you want to get 1080p quality you do `stream["1080"]` to get your stream file. It will return undefined if there is no quality like that. The possibly qualities are: `unknown`, `360`, `480`, `720`, `1080`, `4k`. File based streams are garuanteed to always have one quality. Once you get a streamfile, you have the following parameters: - `StreamFile.type`: Right now it can only be `mp4`. - `StreamFile.url`: The URL linking to the video file. Here is a code sample of how to watch a file based stream the video in a browser: ```html ``` ## Streams with headers Streams have both a `Stream.headers` and a `Stream.preferredHeaders`. The difference between the two is that `Stream.headers` **must** be set in other for the stream to work. While the other one is optional, and can only enhance the quality or performance. If your target is set to `BROWSER`. There will never be required headers, as it's not possible to do. ## Using captions/subtitles All streams have a list of captions at `Stream.captions`. The structure looks like this: ```ts type Caption = { type: CaptionType; // language type, either 'srt' or 'vtt' id: string; // only unique per stream url: string; // the url pointing to the subtitle file hasCorsRestrictions: boolean; // If true, you will need to proxy it if you're running in a browser language: string; // language code of the caption }; ```