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

120 lines
4.9 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
3 years ago
#### Using [Cargo](https://crates.io/crates/monolith)
$ cargo install monolith
3 years ago
#### Via [Homebrew](https://formulae.brew.sh/formula/monolith) (macOS and GNU/Linux)
4 years ago
$ brew install monolith
3 years ago
#### Using [Snapcraft](https://snapcraft.io/monolith) (GNU/Linux)
4 years ago
$ snap install monolith
3 years ago
#### Using [FreeBSD packages](https://svnweb.freebsd.org/ports/head/www/monolith/) (FreeBSD)
3 years ago
$ pkg install monolith
3 years ago
#### Using [FreeBSD ports](https://www.freshports.org/www/monolith/) (FreeBSD)
4 years ago
$ cd /usr/ports/www/monolith/
$ make install clean
#### Using [pkgsrc](https://pkgsrc.se/www/monolith) (NetBSD, OpenBSD, Haiku, etc)
$ 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/)
3 years ago
$ docker build -t Y2Z/monolith .
$ sudo install -b utils/run-in-container.sh /usr/local/bin/monolith
#### From source
4 years ago
Dependency: `libssl-dev`
$ git clone https://github.com/Y2Z/monolith.git
$ cd monolith
$ make install
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
3 years ago
$ 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>