Skip to content

puemos/hls-downloader

HLS Downloader

Capture and download HTTP Live Streams (HLS) straight from your browser.
FreeΒ β€’Β OpenΒ SourceΒ β€’Β MIT Licensed

Test Coverage

Extension promo tile

Popup screenshot


πŸ“– Table of Contents

✨ Features

  • Automatic stream discovery Detects HLS playlists on the page the moment you open it. No DevTools sniffing required.
  • Fine-grained quality control Pick any combination of video resolution (240p β†’ 4K) and audio language/bit-rate before you download, so you never waste bandwidth on the wrong track.
  • 100% local merge with ffmpeg.wasm A WebAssembly build of FFmpeg runs right inside your tab, muxing the chosen audio + video into a single MP4. * Nothing is uploaded, keeping your files private.
  • Works everywhere you browse
    Verified on Firefox, Edge, Chrome, Brave, Arc, and other Chromium-based browsers, on Windows, macOS, and Linux.

πŸ“¦ Get It

Browser Download / availability
Google Chrome logoΒ Β Google Chrome Experimental MV3 build available from source (see Development section).
Firefox logoΒ Β Firefox Get it on Firefox Add-ons or use manual installation
Microsoft Edge logoΒ Β Microsoft Edge Get it from Edge Add-ons
Brave logoΒ Β Brave Use manual installation
Arc logoΒ Β Arc Use manual installation
Opera logoΒ Β Opera Use manual installation

*For Brave/Arc/etc. download the ZIP from the latest release and follow the manual-install steps below.


πŸ› οΈ Installation

Newer versions (β‰₯ 4.1.2) ship only a ZIP archive.
Older versions can still be installed from the CRX (see the collapsible notes).

Manual install for versions < 4.1.2 (CRX)
  1. Grab hls-downloader.crx from the corresponding legacy release.
  2. Open chrome://extensions/, enable Developer mode.
  3. Drag and drop the CRX onto the extensions page.
  4. Confirm any prompts.

Google Chrome logo Chrome

  1. Download extension-mv3-chrome.zip from the latest release.
  2. Extract the ZIP to a convenient folder.
  3. Open chrome://extensions/ and enable Developer mode.
  4. Click Load unpacked and select the extracted folder (the one that contains manifest.json).
  5. Enjoy πŸŽ‰

Brave logo Brave

  1. Download extension-mv3-chrome.zip from the latest release.
  2. Extract the ZIP to a convenient folder.
  3. Open brave://extensions/ and enable Developer mode.
  4. Click Load unpacked and select the extracted folder (the one that contains manifest.json).
  5. Enjoy πŸŽ‰

Arc logo Arc

  1. Download extension-mv3-chrome.zip from the latest release.
  2. Extract the ZIP to a convenient folder.
  3. Open Arc Menu β†’ Extensions β†’ Manage Extensions (or press Command+T or Ctrl+T and type Manage Extensions), then enable Developer mode.
  4. Click Load unpacked and select the extracted folder (the one that contains manifest.json).
  5. Enjoy πŸŽ‰

Opera logo Opera

  1. Download extension-mv3-chrome.zip from the latest release.
  2. Extract the ZIP to a convenient folder.
  3. Open opera://extensions/ and enable Developer mode.
  4. Click Load unpacked and select the extracted folder (the one that contains manifest.json).
  5. Enjoy πŸŽ‰

Firefox logo Firefox

  1. Opem about:debugging#/runtime/this-firefox.
  2. Click Load Temporary Add-on... and pick the XPI.

For Dear Testers – concise build/install steps for Firefox & Chromium reviewers.


🎬 Usage

  1. Browse to a page that plays an HLS video and start playback.
  2. Click the HLS Downloader icon – detected playlists appear in the Sniffer tab.
  3. Choose Select next to a playlist.
  4. Pick your video & audio streams, then press Download.
  5. Grab a coffee β˜• – ffmpeg.wasm merges everything and your browser prompts you to save the MP4 when done.

πŸ§‘β€πŸ’» Development

Clone & Build

Requires Node.js 20+ (includes Corepack) and the zip command.

git clone https://github.com/puemos/hls-downloader.git
cd hls-downloader

# install the pinned pnpm version
corepack enable
corepack prepare [email protected] --activate

pnpm install --frozen-lockfile
pnpm run build    # outputs β†’ ./dist/, extension-chrome.zip, extension-firefox.xpi

# verify build artifacts then clean up
pnpm run clean

MV2 vs MV3 builds

The default build targets Manifest V2 (Firefox and legacy Chromium workflows). To produce a Manifest V3 bundle for Chromium-based browsers (Firefox does not fully support MV3 background service workers yet):

MV_TARGET=mv3 pnpm run build   # writes manifest v3 + offscreen page to dist/
pnpm run clean                 # optional: remove artifacts after testing

You can generate both flavors at once with pre-named artifacts:

pnpm run build:all          # outputs dist/mv2 + dist/mv3
# zips: extension-mv2-chrome.zip / extension-mv2-firefox.xpi  (MV2 contents at archive root)
#       extension-mv3-chrome.zip                            (MV3 contents at archive root; Chromium only)

Tip: If pnpm is missing, run corepack enable && corepack prepare [email protected] --activate to match the locked toolchain.

Run tests & generate coverage badge:

pnpm test          # unit tests
pnpm test:coverage # combined coverage + badge

Live Development

pnpm dev        # watches & rebuilds into dist/
pnpm storybook  # preview popup & design-system components

Project Structure

src/
β”œβ”€ assets/          # extension manifest & icons
β”œβ”€ background/      # background scripts
β”œβ”€ core/            # shared logic & Redux store
β”œβ”€ design-system/   # UI component library
└─ popup/           # React popup UI

🀝 Contributing

We β™₯ PRs! See the contributing guide and automation guide.

git checkout -b feature/my-awesome-idea
# ...code...
git commit -am "feat: add awesome idea"
git push origin feature/my-awesome-idea
# open PR πŸŽ‰

πŸ“œ Code of Conduct

TLDR: Be kind This project follows the Contributor Covenant.


🚧 Build Variants

HLS Downloader is available in multiple build variants to accommodate different distribution requirements:

Store Builds (Firefox Add-ons / Edge Add-ons)

Official store releases include a blocklist that respects copyright holder opt-out requests. This version complies with distribution platform policies and content owner preferences.

Independent Builds

Alternative builds are available for advanced users who prefer complete local control. These "experimental" variants contain no blocklist and allow unrestricted operation:

# MV2 without blocklist (Firefox/Edge manual install)
pnpm run build:mv2:no-blocklist

# MV3 without blocklist (Chrome/Brave/Arc manual install)
pnpm run build:mv3:no-blocklist

# Build all variants at once
pnpm run build:all-variants

Non-blocklist builds are named "experimental unstable nightly beta alpha hls-downloader" and are intended for personal use onlyβ€”not for redistribution on official stores.


🀚 Disclaimer

This extension is designed for downloading video content that you own or have authorization to access. It is prohibited to use this tool for downloading copyrighted content without permission. Users are solely responsible for their actions, and the developer assumes no liability for user behavior. This tool is provided "as-is" without warranty of any kind.


🚫 Copyright Protection and Opt-Out Policy

We respect the intellectual property rights and legitimate interests of all websites and content operators.

If you do not wish this tool to operate on your website, you may submit an opt-out request. We will add verified domains to the project's blocklist in subsequent releases.

How to Submit an Opt-Out Request

  1. Create a new Issue using the "Opt-Out Request" template
  2. Use the title format: [Opt-Out Request] YourDomain.com
  3. Provide the following information for verification:
    • Website Domain (e.g., example.com)
    • Contact Email (for identity verification if necessary)

We commit to honoring legitimate requests and will include verified domains in the blocklist for store-distributed versions. Please note that as an open-source project, update cycles may vary. Thank you for your understanding and cooperation.


πŸ“ License

MIT License – click to expand
The MIT License (MIT)

Copyright (c) 2025 Shy Alter

More: https://github.com/puemos/hls-downloader/blob/master/LICENSE

Made with β™₯ by puemos