Gildas 271b1ee5e8 added default value for the option 'filename-template' (cf #338) 6 anni fa
..
back-ends 49e6d1a17d updated copyright date 6 anni fa
README.MD b207befb0f fixed formatting 6 anni fa
dockerfile 95e4bd057f added '--depth 1' option when calling 'git clone' (cf. #338) 6 anni fa
package.json b207befb0f fixed formatting 6 anni fa
single-file 271b1ee5e8 added default value for the option 'filename-template' (cf #338) 6 anni fa
single-file.bat 57fd19e2ba prepend with path to the batch directory 7 anni fa

README.MD

SingleFile (Command Line Interface)

Introduction

SingleFile can be launched from the command line by running it into a (headless) browser. It runs through Node.js as a standalone script injected into the web page instead of being embedded into a WebExtension. To connect to the browser, it can use Puppeteer or Selenium WebDriver. Alternatively, it can also emulate a browser with JavaScript disabled by using jsdom.

Install

  • Make sure Chrome or Firefox is installed and the executable can be found through the PATH environment variable. Otherwise you will need to set the --browser-executable-path option to help SingleFile locating it. As an alternative to Chrome and Firefox, you can use jsdom by setting the --back-end option to jsdom.

  • Install Node.js

  • Unzip the master archive somewhere on your disk in an empty folder and go into the SingleFile-master/cli directory.

unzip master.zip .

cd SingleFile-master

cd cli

  • As an alternative to decompressing the master archive, you can clone the repository if git is installed on your machine and go into the SingleFile/cli directory.

git clone https://github.com/gildas-lormeau/SingleFile.git

cd SingleFile

cd cli

  • Install dependencies with npm (installed with Node.js).

npm install

  • Make single-file executable (Linux/Unix/BSD etc.).

chmod +x single-file

  • To use Firefox instead of Chrome, you must download the Selenium WebDriver component (i.e. geckodriver for Firefox). Make sure it can be found through the PATH environment variable or the cli folder. Otherwise you will need to set the --web-driver-executable-path option to help WebDriver locating the executable.

  • To use Puppeteer with Firefox, you must install the package puppeteer-firefox manually by running npm install puppeteer-firefox and set the --back-end option to puppeteer-firefox.

Run

  • Syntax

single-file <url> [output] [options ...]

  • Display help

single-file --help

single-file https://www.wikipedia.org

single-file https://www.wikipedia.org wikipedia.html

single-file https://www.wikipedia.org wikipedia.html --back-end=webdriver-gecko

Docker

  • Build

docker build -t singlefile .

  • Run

docker run singlefile "https://www.wikipedia.org"

  • Run and pipe the result into a file

docker run singlefile "https://www.wikipedia.org" > wikipedia.html

License

SingleFile is licensed under AGPL. Code derived from third-party projects is licensed under MIT. Please contact me at gildas.lormeau <at> gmail.com if you are interested in licensing the SingleFile code for a commercial service or product.