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

165 lines
5.2 KiB
Markdown

[![monolith build status on 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 on macOS](https://github.com/Y2Z/monolith/workflows/macOS/badge.svg)](https://github.com/Y2Z/monolith/actions?query=workflow%3AmacOS)
[![monolith build status on Windows](https://github.com/Y2Z/monolith/workflows/Windows/badge.svg)](https://github.com/Y2Z/monolith/actions?query=workflow%3AWindows)
```
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
3 years ago
#### Using [Cargo](https://crates.io/crates/monolith)
```console
cargo install monolith
```
3 years ago
#### Via [Homebrew](https://formulae.brew.sh/formula/monolith) (macOS and GNU/Linux)
```console
brew install monolith
```
#### Via [MacPorts](https://ports.macports.org/port/monolith/summary) (macOS)
```console
sudo port install monolith
```
4 years ago
#### Via [MacPorts](https://ports.macports.org/port/monolith/summary) (macOS)
3 years ago
```console
sudo port install monolith
```
3 years ago
#### Using [Snapcraft](https://snapcraft.io/monolith) (GNU/Linux)
```console
snap install monolith
```
4 years ago
3 years ago
#### Using [FreeBSD packages](https://svnweb.freebsd.org/ports/head/www/monolith/) (FreeBSD)
```console
pkg install monolith
```
3 years ago
3 years ago
#### Using [FreeBSD ports](https://www.freshports.org/www/monolith/) (FreeBSD)
```console
cd /usr/ports/www/monolith/
make install clean
```
4 years ago
#### Using [pkgsrc](https://pkgsrc.se/www/monolith) (NetBSD, OpenBSD, Haiku, etc)
```console
cd /usr/pkgsrc/www/monolith
make install clean
```
3 years ago
#### Using [pre-built binaries](https://github.com/Y2Z/monolith/releases) (Windows, ARM-based devices, etc)
Every release contains pre-built binaries for Windows, GNU/Linux, as well as platforms with non-standart CPU architecture.
4 years ago
3 years ago
#### Using [containers](https://www.docker.com/)
```console
docker build -t Y2Z/monolith .
sudo install -b utils/run-in-container.sh /usr/local/bin/monolith
```
3 years ago
#### From source
4 years ago
Dependency: `libssl-dev`
```console
git clone https://github.com/Y2Z/monolith.git
cd monolith
make install
```
4 years ago
---------------------------------------------------
4 years ago
4 years ago
## Usage
```console
monolith https://lyrics.github.io/db/P/Portishead/Dummy/Roads/ -o portishead-roads-lyrics.html
```
3 years ago
or
```console
cat index.html | monolith -aIiFfcMv -b https://original.site/ - > result.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
- `-C`: Save document using custom `charset`
- `-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
- `-n`: Extract contents of NOSCRIPT elements
- `-o`: Write output to `file` (use “-” for STDOUT)
4 years ago
- `-s`: Be quiet
3 years ago
- `-t`: Adjust `network request timeout`
3 years ago
- `-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
3 years ago
- Monolith Chrome Extension: https://github.com/rhysd/monolith-of-web
- Pagesaver: https://github.com/distributed-mind/pagesaver
- Personal WayBack Machine: https://github.com/popey/pwbm
- Hako: https://github.com/dmpop/hako
- Monk: https://gitlab.com/fisherdarling/monk
4 years ago
---------------------------------------------------
4 years ago
4 years ago
## License
To the extent possible under law, the author(s) have dedicated all copyright related and neighboring rights to this software to the public domain worldwide.
This software is distributed without any warranty.
4 years ago
---------------------------------------------------
4 years ago
<!-- Microtext -->
<sub>Keep in mind that `monolith` is not aware of your browsers session</sub>