You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
monolith/README.md

109 lines
4.1 KiB
Markdown

[![Monolith Build Status for GNU/Linux](https://github.com/Y2Z/monolith/workflows/GNU%2FLinux/badge.svg)](https://github.com/Y2Z/monolith/actions?query=workflow%3AGNU%2FLinux)
[![Monolith Build Status for macOS](https://github.com/Y2Z/monolith/workflows/macOS/badge.svg)](https://github.com/Y2Z/monolith/actions?query=workflow%3AmacOS)
[![Monolith Build Status for Windows](https://github.com/Y2Z/monolith/workflows/Windows/badge.svg)](https://github.com/Y2Z/monolith/actions?query=workflow%3AWindows)
5 years ago
```
4 years ago
_____ ______________ __________ ___________________ ___
| \ / \ | | | | | |
| \_/ __ \_| __ | | ___ ___ |__| |
| | | | | | | | | | | |
| |\ /| |__| _ |__| |____| | | | | __ |
| | \___/ | | \ | | | | | | |
|___| |__________| \_____________________| |___| |___| |___|
5 years ago
```
5 years ago
A data hoarders dream come true: bundle any web page into a single HTML file. You can finally replace that gazillion of open tabs with a gazillion of .html files stored somewhere on your precious little drive.
7 years ago
Unlike the conventional “Save page as”, `monolith` not only saves the target document, it embeds CSS, image, and JavaScript assets **all at once**, producing a single HTML5 document that is a joy to store and share.
7 years ago
5 years ago
If compared to saving websites with `wget -mpk`, this tool embeds all assets as data URLs and therefore lets browsers render the saved page exactly the way it was on the Internet, even when no network connection is available.
7 years ago
4 years ago
---------------------------------------------------
4 years ago
4 years ago
## Installation
7 years ago
### Using Cargo
$ cargo install monolith
#### Via Homebrew (on macOS and GNU/Linux)
4 years ago
$ brew install monolith
4 years ago
#### Using Snapcraft (on GNU/Linux)
4 years ago
$ snap install monolith
4 years ago
#### Using Ports collection (on FreeBSD and TrueOS)
$ cd /usr/ports/www/monolith/
$ make install clean
4 years ago
#### Using pre-built binaries (Windows, ARM-based devices, etc)
Every [release](https://github.com/Y2Z/monolith/releases) contains pre-built binaries for Windows, GNU/Linux, as well as platforms with non-standart CPU architecture.
#### From source
4 years ago
Dependency: `libssl-dev`
$ git clone https://github.com/Y2Z/monolith.git
$ cd monolith
$ make install
4 years ago
#### Using Containers
$ docker build -t Y2Z/monolith .
$ sudo install -b utils/run-in-container.sh /usr/local/bin/monolith
4 years ago
---------------------------------------------------
4 years ago
4 years ago
## Usage
4 years ago
$ monolith https://lyrics.github.io/db/P/Portishead/Dummy/Roads/ -o portishead-roads-lyrics.html
3 years ago
or
$ cat index.html | monolith -aIiFfcMv - > index-processed.html
7 years ago
4 years ago
---------------------------------------------------
4 years ago
4 years ago
## Options
- `-a`: Exclude audio sources
3 years ago
- `-b`: Use custom `base URL`
- `-c`: Exclude CSS
- `-e`: Ignore network errors
- `-f`: Omit frames
- `-F`: Exclude web fonts
5 years ago
- `-i`: Remove images
- `-I`: Isolate the document
5 years ago
- `-j`: Exclude JavaScript
- `-k`: Accept invalid X.509 (TLS) certificates
3 years ago
- `-M`: Don't add timestamp and URL information
3 years ago
- `-o`: Write output to `file`
4 years ago
- `-s`: Be quiet
3 years ago
- `-t`: Adjust `network request timeout`
- `-u`: Provide `custom User-Agent`
- `-v`: Exclude videos
7 years ago
4 years ago
---------------------------------------------------
4 years ago
3 years ago
## Proxies
Please set `https_proxy`, `http_proxy`, and `no_proxy` environment variables.
4 years ago
---------------------------------------------------
4 years ago
4 years ago
## Contributing
Please open an issue if something is wrong, that helps make this project better.
4 years ago
---------------------------------------------------
4 years ago
4 years ago
## Related projects
4 years ago
- `Monolith Chrome Extension`: https://github.com/rhysd/monolith-of-web
- `Pagesaver`: https://github.com/distributed-mind/pagesaver
4 years ago
- `Personal WayBack Machine`: https://github.com/popey/pwbm
- `Hako`: https://github.com/dmpop/hako
4 years ago
---------------------------------------------------
4 years ago
4 years ago
## License
The Unlicense
4 years ago
---------------------------------------------------
4 years ago
<!-- Microtext -->
<sub>Keep in mind that `monolith` is not aware of your browsers session</sub>