rx-player
Version:
Canal+ HTML5 Video Player
85 lines (58 loc) • 3.91 kB
Markdown
# The `fetchers`
| Consideration | Status |
| ----------------------- | --------------------------------- |
| Preferred import style | Directory-only _[1]_ |
| Multithread environment | Should be runnable in a WebWorker |
_[1]_ Only the `fetchers` directory itself should be imported and relied on by the rest of
the code, not its inner files (thus `./index.ts` should export everything that may be
imported by outside code).
## Overview
The fetchers is the part of the code interacting with `transports` files, which allows, to
download and parse the Manifest and the media segments.
This directory actually exports two completely isolated type of fetchers:
- The **Manifest fetcher** is used to download and parse the manifest file.
- The **SegmentQueueCreator** is used to create `SegmentQueue` objects, allowing to
download and parse media segments.
## The Manifest fetcher
The Manifest fetcher allows to download and parse the Manifest/Playlist of the current
transport protocol to then return a `Manifest` object, which is protocol-agnostic.
This is the part of the code that interacts with `transports` to perform the request and
parsing of the Manifest file.
It also regularly refreshes the Manifest, based on its attributes and other criteria, like
performances when doing that.
## The SegmentQueueCreator
The SegmentQueueCreator allows to easily perform segment downloads for the rest of the
code. This is the part of the code that interacts with the transport protocols - defined
in `src/transports` - to load and parse media segments.
To do so, the SegmentQueueCreator creates `SegmentQueue` classes of different types
(example: a video or audio `SegmentQueue`) when you ask for it. Through those
`SegmentQueue`, you can then schedule various a FIFO queue of segment requests each with a
given priority.
The priority of this request is then corroborated with the priority of all requests
currently pending in the SegmentQueueCreator (and not only with those on the current
`SegmentQueue`) to know when the request should effectively be done - more prioritary
requests will be done first.
During the lifecycle of the request, the `SegmentQueue` will communicate about data and
metrics through several means - documented in the code.
### Priorization
Each Segment request can be linked to a priorization number. Such number will indicate
which segment is needed more immediately than other (the lower it is, the higher the
priority of the segment is).
This is for example used to indicate that a very close video segment has a higher priority
than some distant audio segment (both might be scheduled at the same time depending on the
situation).
If the request has no priorization number, the lowest priorization number (the highest
priority) will be set on it: `0`
Basically, any new request will have their priorization number compared to the one of the
current request(s) done by the SegmentQueueCreator:
- if no request is already pending, we perform the request immediately
- if (and only if) this priorization number is higher (so lower priority) than all current
requests, this new request will be postponed to let the higher-priority ones finish.
- If a new request has a priorization number lower or equal than all current downloads, we
perform the request immediately without interrupting the current, lower-priority ones.
- If a new request has a very low priorization number (so a very high priority, the number
is defined in `src/config.ts`), all current downloads with a very high priorization
number (also defined in the config) will be interrupted.
The priority of a download can be updated at any time, until this request either has
finished, was canceled or failed. The same rules apply when the priorization number is
updated (if this request is already pending, we keep it going in any case).