Hoardy-Web
?Hoardy-Web
is a suite of tools that helps you to passively capture, archive, and hoard your web browsing history.
Not just the URLs, but also the contents and the requisite resources (images, media, CSS
, fonts, etc) of the pages you visit.
Not just the last 3 months, but from the beginning of time you start using it.
Practically speaking, you install the Hoardy-Web
browser extension/add-on into your web browser and just browse the web normally while Hoardy-Web
passively, in background, captures and archives web pages you visit for later offline viewing, mirroring, and/or indexing.
Hoardy-Web
has a lot of configuration options to help you tweak what should or should not be archived and a very low memory footprint, keeping you browsing experience snappy even on ancient hardware (unless explicitly configured otherwise to, e.g., minimize writes to disk instead).
If you just want to start saving your browsing history, you can start using the Hoardy-Web
extension independently of other tools that are being developed in this repository.
But to display, search, extract useful values from, organize, manipulate, and run scripts over your archived data, you will eventually need to install and use at least the accompanying hoardy-web
CLI tool.
To learn more:
Hoardy-Web
does and does not do.Help
page answer questions about most common issues you can encounter while using Hoardy-Web
extension/add-on.Hoardy-Web
was previously known as "Personal Private Passive Web Archive" aka "pwebarc".
If you are reading this on GitHub, be aware that this repository is a mirror of a repository on the author's web site.
In author's humble opinion, the rendering of the documentation pages there is superior to what can be seen on GitHub (its implemented via pandoc
there).
See there for more screenshots.
Hoardy-Web
exists?So, you wake up remembering something interesting you saw a long time ago. Knowing you won't find it in your normal browsing history, which only contains the URLs and the titles of the pages you visited in the last 3 months, you try looking it up on Google. You fail. Eventually, you remember the website you seen it at, or maybe you re-discovered the link in question in an old message to/from a friend, or maybe a tool like recoll or Promnesia helped you. You open the link… and discover it offline/gone/a parked domain. Not a problem! Have no fear! You go to Wayback Machine and look it up there… and discover they only archived an ancient version of it and the thing you wanted is missing there.
Or, say, you read a cool fanfiction on AO3 years ago, you even wrote down the URL, you go back to it wanting to experience it again… and discover the author made it private... and Wayback Machine saved only the very first chapter.
"If it is on the Internet, it is on Internet forever!" they said. They lied!
Things vanish from the Internet all the time, Wayback Machine is awesome, but
Meanwhile, Hoardy-Web
solves all of the above out-of-the-box (though, the full-text search is currently being done by other tools running on top of it).
Say, there is a web page that can not be easily reached via curl
/wget
(because it is behind a paywall or complex authentication method that is hard to reproduce outside of a browser) but for accessibility or just simple reading comfort reasons each time you visit that page you want to automatically feed its source to a script that strips and/or modifies its HTML
markup in a website-specific way and feeds it into a TTS engine, a Braille display, or a book reader app.
With most modern web browsers you can do TTS either out-of-the-box or by installing an add-on (though, be aware of privacy issues when using most of these), but tools that can do website-specific accessibility without also being website-specific UI apps are very few.
Meanwhile, Hoardy-Web
with some scripts can do it.
Say, there's a web page/app you use (like a banking app), but it lacks some features you want, and in your browser's Network Monitor you can see it uses JSON RPC
or some such to fetch its data, and you want those JSON
s for yourself (e.g., to compute statistics and supplement the app output with them), but the app in question has no public API and scraping it with a script is non-trivial (e.g., the site does complicated JavaScript
+multifactor-based auth, tries to detect you are actually using a browser, and bans you immediately if not).
Or, maybe, you want to parse those behind-auth pages with a script, save the results to a database, and then do interesting things with them (e.g., track price changes, manually classify, annotate, and merge pages representing the same product by different sellers, do complex queries, like sorting by price/unit or price/weight, limit results by geographical locations extracted from text labels, etc).
Or, say, you want to fetch a bunch of pages belonging to two recommendation lists on AO3 or GoodReads, get all outgoing links for each fetched page, union sets for the pages belonging to the same recommendation list, and then intersect the results of the two lists to get a shorter list of things you might want to read with higher probability.
Or, more generally, say, you want to tag web pages referenced from a certain set of other web pages with some tag in your indexing software, and update it automatically each time you visit any of the source pages.
Or, say, you want to combine a full-text indexing engine, your browsing and derived web link graph data, your states/ratings/notes from org-mode, messages from your friends, and other archives, so that you could do arbitrarily complex queries over it all, like "show me all GoodReads pages for all books not marked as DONE
or CANCELED
in my org-mode
files, ever mentioned by any of my friends, ordered by undirected-graph Pagerank algorithm biased with my own book ratings (so that books sharing GoodReads lists with the books I finished and liked will get higher scores)".
So, basically, you want a private personalized Bayesian recommendation system.
"Everything will have a RESTful API!" they said.
They lied!
A lot of useful stuff never got RESTful APIs, those RESTful APIs that exists are frequently buggy, you'll probably have to scrape data from HTML
s anyway.
"Semantic Web will allow arbitrarily complex queries spanning multiple data sources!" they said. Well, 25 years later ("RDF Model and Syntax Specification" was published in 1999), almost no progress there, the most commonly used subset of RDF does what indexing systems in 1970s did, but less efficiently and with a worse UI.
Meanwhile, Hoardy-Web
provides some of the tools to help you build your own little local data paradise.
The Hoardy-Web
browser extension runs under desktop versions of both Firefox- and Chromium-based browsers as well as under Firefox-for-Android-based browsers.
Hoardy-Web
's main workflow is to passively collect and archive HTTP
requests and responses (and, if you ask, also DOM
snapshots, i.e. the contents of the page after all JavaScript
was run) directly from your browser as you browse the web.
Therefore, Hoardy-Web
allows you to
trivially archive web pages hidden behind CAPTCHAs, requiring special cookies, multi-factor logins, paywalls, anti-scraping/curl
/wget
measures, and etc (after all, the website in question only interacts with your normal web browser, not with a custom web crawler);
archive most HTTP
-level data, not just web pages, and not just things available via HTTP GET
requests (e.g., it can archive answer pages of web search engines fetched via HTTP POST
, AJAX
data, JSON RPC
calls, etc; though, at the moment, it can not archive WebSockets
data);
all the while
Hoardy-Web
can archive collected data
WRR
-formatted dumps),hoardy-web-sas
), orIn other words, Hoardy-Web
is your own personal private Wayback Machine which passively archives everything you see and, unlike the original Wayback Machine, also archives HTTP POST
requests and responses, and most other HTTP
-level data.
Also, unless configured otherwise, Hoardy-Web
will dump and archive collected data immediately, to both prevent data loss and to free the used RAM as soon as possible, keeping your browsing experience snappy even on ancient hardware.
Compared to most of its alternatives, Hoardy-Web
DOES NOT:
force you to use a Chromium-based browser (you can use Hoardy-Web
with Firefox, Tor Browser, LibreWolf, Fenix aka Firefox for Android, Fennec, Mull, etc, which is not a small thing, since if you tried using any of the close alternatives running under Chromium-based browsers, you might have noticed that the experience there is pretty awful: the browser becomes even slower than usual, large files don't get captured, random stuff fails to be captured at random times because Chromium randomly detaches its debugger from its tabs... none of these problems exist on Firefox-based browsers because Firefox does not fight ad-blocking and hardcore ad-blocking extensions and Hoardy-Web
use the same browser APIs);
require you to capture, collect, and archive recorded data one page/browsing session at a time (the default behaviour is to archive everything completely automatically, though it implements optional limbo mode which delays archival of collected data and provides optional manual/semi-automatic control if you want it);
require you to download the data you want to archive twice or more (you'd be surprised how commonly other tools will either ask you to do that explicitly, or just do that silently when you ask them to save something);
send any of your data anywhere (unless you explicitly configure it to do so);
send any telemetry anywhere;
require you to store all the things in browser's local storage where they can vanish at any moment (though, saving to local storage is the default because it simplifies on-boarding, but switching to another archival method takes a couple of clicks and re-archival of old data from browser's local storage to elsewhere is easy);
require you to run a database server;
require you to run a web browser to view the data you've already archived (in fact, the hoardy-web
tool comes with a bunch of scripts which allow you to use other tools for that; e.g., a script to view HTML
documents via pandoc
piped into less
in your favorite tty emulator).
Technically, Hoardy-Web
is most similar to
Or, to summarize it another way, you can view Hoardy-Web
as an alternative for mitmproxy which leaves SSL/TLS layer alone and hooks into target application's runtime instead.
In fact, an unpublished and now irrelevant ancestor project of Hoardy-Web
was a tool to generate website mirrors from mitmproxy
stream captures.
(By the way, if you want that, hoardy-web
CLI tool can do that for you. It can take mitmproxy
dumps as inputs.)
But then I got annoyed by all the sites that don't work under mitmproxy
, did some research into the alternatives, decided there were none I wanted to use, and so I made my own.
The Hoardy-Web
browser extension that captures all HTTP
requests and responses (and DOM
snapshots) your browser fetches, dumps them into WRR
format, and then exports them by generating fake-Downloads containing bundles of those dumps, submits them to the specified archiving server (by POST
ing them to the specified URL), or saves the to browser's local storage.
The extension is
stable while running under desktop versions of both Firefox- and Chromium-based browsers;
beta while running under Fenix-based (Firefox-for-Android-based) browsers.
See the "Quirks and Bugs" section of extension's Help
page for known issues.
Also, Hoardy-Web
is tested much less on Chromium than on Firefox.
The hoardy-web-sas
simple archiving server that simply dumps everything the Hoardy-Web
extension submits to it to disk, one file per HTTP
request+response.
The simple archiving server is stable (it's so simple there hardly could be any bugs there).
The hoardy-web
CLI tool that allows you to display, search, programmatically extract values from, organize, manipulate, import, and export web archives stored in WRR
and mitmproxy
formats.
hoardy-web
tool is deep in its beta stage.
At the moment, it does about 70% of the stuff I want it to do, and the things it does it does not do as well as I'd like.
See the TODO list for more info.
A patch for Firefox to allow Hoardy-Web
extension to collect request POST
data as-is. This is not required and even without that patch Hoardy-Web
will collect everything in most cases, but it could be useful if you want to correctly capture POST
requests that upload files.
See the "Quirks and Bugs" section of extension's Help
page for more info.
Hoardy-Web
is designed to
To conform to the above design principles
the Hoardy-Web
Web Extension browser add-on does almost no actual work, simply generating HTTP
request+response dumps, archiving them, and then freeing the memory as soon as possible (unless you enable limbo mode, but then you asked for it), thus keeping your browsing experience snappy even on ancient hardware;
also the Hoardy-Web
extension collects data as browser gives it, without any data normalization and conversion, when possible;
the dumps are generated using the simplest, trivially parsable with many third-party libraries, yet most space-efficient on-disk file format representing separate HTTP
requests+responses there currently is (aka Web Request+Response
, WRR
), which is a file format that is both more general and more simple than WARC
, much simpler than that mitmproxy
uses, and much more efficient than HAR
;
the Hoardy-Web
extension can write the dumps it produces to disk by itself by generating fake-Dowloads containing bundles of WRR
dumps, but because of limitations of browser APIs, Hoardy-Web
can't tell if a file generated this way succeeds at being written to disk;
which is why, for users who want write guarantees and error reporting, the extension has other archival methods, which includes archival by submission via HTTP
;
server-side part of submission via HTTP
uses the hoardy-web-sas
simple archiving server, which is tiny (less than 250 lines of code) pure-Python script that provides an HTTP
interface for archival of dumps given via HTTP POST
requests;
both the Hoardy-Web
extension and the hoardy-web-sas
simple archiving server write those dumps to disk as-is, with optional compression for data storage efficiency;
meanwhile, viewing of, generation of website mirrors from, organization and management, data normalization (massaging), post-processing, other ways of extraction of useful values from archived WRR
files --- i.e. basically everything that is computationally expensive --- is delegated to the hoardy-web
CLI tool;
the hoardy-web
CLI tool is very easy to use in your own scripts;
by default, none these tools ever overwrite any files on disk (to prevent accidental data loss).
Hoardy-Web
expects you to treat your older pre-WRR
archives you want to convert to WRR
similarly:
hoardy-web import
them into a separate directory, butmitmproxy
(or whatever) dumps alone (on an external backup drive, if you lack disk space on your machine).This way, if hoardy-web
has some unexpected bug, or hoardy-web import
adds some new feature, you could always re-import them later without losing anything.
Currently, Hoardy-Web
has two main use cases for regular users, in both of which you first capture some data using the add-on and then you either
feed a subset of your archives to the hoardy-web
CLI tool to generate a static offline website mirror a-la wget -mpk
, which you can then view with your favorite web-browser as normal;
except, unlike with wget
, you can discover you dislike the result, change some options, and re-generate the mirror without re-downloading anything;
you use hoardy-web
to simply maintain a tree of symlinks pointing to latest WRR
file for each URL and then read them --- by using w3m
, pandoc
, any other HTML
reader you want, or feed them to TTS engine, or a Braille display --- via some scripts;
personally, I prefer this one, because I hate web browsers and prefer to read most things from a TTY;
(TODO: eventually, when that gets implemented, a Wayback Machine-like Web UI for replay).
Alternatively, you can programmatically access that data by asking the hoardy-web
CLI tool to dump WRR
files into JSONs or verbose CBORs for you, or you can just parse WRR
files yourself with readily-available libraries.
Since the whole of hoardy-web
(the project) adheres to the philosophy described above, the simultaneous use of Hoardy-Web
(the extension) and hoardy-web
(the tool) helps immensely when developing scrapers for uncooperative websites: you just visit them via your web browser as normal, then, possibly years later, use the hoardy-web
tool to organize your archives and conveniently programmatically feed the archived data into your scraper without the need to re-fetch anything.
Given how simple the WRR
file format is, you can modify any HTTP
library to generate WRR
files, thus allowing you to use the hoardy-web
tool with data captured by other software, and use data produced by the Hoardy-Web
extension as inputs to your own tools.
Which is why, personally, I patch some of the commonly available FLOSS website scrapers to dump the data they fetch as WRR
files so that in the future I could write my own better scrapers and indexers and test them on a huge collected database of already collected inputs immediately.
Also, as far as I'm aware, hoardy-web
is a tool that can do more useful stuff to your WRR
archives than any other tool can do to any other file format for HTTP
dumps with the sole exception of WARC
.
See extension's Help
page (or the Help
button in the extension's UI, which will make it interactive) for a long detailed description of what the extension does step-by-step.
It is a must-read, though instead of reading that file raw I highly recommend you read it via the Help
button of the extension's UI, since doing that will make the whole thing pretty interactive.
See the "Frequently Asked Questions" section of extension's Help
page for the answers to the frequently asked questions, including those about common quirks you can encounter while using it.
See the "Quirks and Bugs" section of extension's Help
page for more info on quirks and limitations of Hoardy-Web
when used on different browsers.
See below for a long list of comparisons to its alternatives.
Then notice that Hoardy-Web
is the best among them, and go follow "Quickstart" section for setup instructions. ( •̀ ω •́ )✧
To follow the development:
See CHANGELOG.md for the progress log and human-readable description of recent changes (which is much shorter and more comprehensible than the commit log).
See the TODO list for the list of things that are not implemented/ready yet.
If you want to learn to use the hoardy-web
tool, see its README, which has a bunch of extended and explained usage examples.
Also, a lot of info from that page can be seen by running hoardy-web --help
.
See example scripts to learn how to do various interesting things with your archived data.
In the unlikely case you have problems with the hoardy-web-sas
simple archiving server, see its README.
Or you can read hoardy-web-sas --help
instead.
If you want to build the extension from source, see its README.
If you are a developer, see all the hoardy-web
-related links above, and also see the description of the on-disk file format used by all these tools.
If your questions are not unanswered by these, then open an issue on GitHub or get in touch otherwise.
Yes, as of October 2024, I archive all of my web traffic using Hoardy-Web
, without any interruptions, since October 2023.
Before that my preferred tool was mitmproxy.
After adding each new feature to the hoardy-web
tool, as a rule, I feed at least the last 5 years of my web browsing into it (at the moment, most of it converted from other formats to .wrr
, obviously) to see if everything works as expected.
Hoardy-Web
browser extension/add-onOn Firefox, Tor Browser, LibreWolf, Fenix aka Firefox for Android, Fennec, Mull, etc: Install the extension from addons.mozilla.org.
On Chromium, Google Chrome, Ungoogled Chromium, Brave, etc: see Installing on Chromium-based browser.
Unfortunately, this requires a bit more work than clicking Install
button on Chrome Web Store, yes.
"Why isn't Hoardy-Web
on Chrome Web Store?"
I'm not a lawyer, but to me it looks like Hoardy-Web
violates Chrome Web Store's "Terms of Use".
Specifically, the "enables the unauthorized download of streaming content or media" clause.
In my personal opinion, any content you web browser fetches while you are browsing the web normally you are "authorized" to download.
This is especially true for Hoardy-Web
since, unlike most of its alternatives, it does not generate any requests itself, it only captures the data that a web page generates while you browse it.
But given the context of that clause in that document, I feel like Google would disagree with my the interpretation above.
Even though, technically speaking, separation between "streamed" and "downloaded" content or media is a complete delusion.
Meanwhile, Hoardy-Web
tries its best to collect all web traffic you browser generates, which, obviously, includes streaming content.
On Chromium (but not on Firefox), technically, at the moment, Hoardy-Web
does fail to collect streaming media properly because Chromium has a bug that prevents collection of the first few KiB of all audio and video files, and its API design prevents collection of large files in general, but if we are talking about YouTube, then most of the data of those streaming media files Chromium will fetch while you watch a video there will, in fact, get collected even on Chromium.
So, in principle, to conform to those terms, Hoardy-Web
would need to either disallow archival of all embedded media (which would defeat the point of it existing), or come bundled with a blacklist of URLs Google would claim you would be "unauthorized" to save to disk, and forcefully disallow archival for those.
Even if such a blacklist could be made somehow (How do you expect somebody make such a thing, Google-san?), it would be very annoying and time-consuming to maintain.
(Meanwhile, on Firefox, Hoardy-Web
will just silently collect everything you browser fetches.
And addons.mozilla.org's policies do not restrict this.)
(Also, Chrome Web Store actually requires developers to pay Google to host their add-ons there while Mozilla's service is free. Meaning, you should go and donate to any free add-ons that do not violate your privacy and sell your data you installed from there. Their authors paid Google so that you could conveniently install their add-ons with a single click. Who else will pay the authors? Also, consider donating to Mozilla, things would be much, much worse without them.)
Alternatively, build it from source.
Now load any web page in your browser. The extension will report if everything works okay, or tell you where the problem is if something is broken.
Assuming the extension reported success: Congratulations! You are now collecting and archiving all your web browsing traffic originating from that browser. Repeat extension installation for all browsers/browser profiles as needed.
Technically speaking, if you just want to collect everything and don't have time to figure out how to use the rest of this suite of tools right this moment, you can stop here and figure out how to use the rest of this suite later.
It took me about 6 months before I had to refer back to previously archived data for the first time when I started using mitmproxy to sporadically collect my HTTP
traffic in 2017.
So, I recommend you start collecting immediately and be lazy about the rest.
Also, I learned a lot about nefarious things some of the websites I visit do in the background while doing that, now you are going to learn the same.
In practice, though, your will probably want to install at least the hoardy-web-sas
simple archiving server (see below for instructions) and switch Hoardy-Web
to Submit dumps via 'HTTP'
mode pretty soon because it is very easy to accidentally loose data using other archival methods and, assuming you have Python installed on your computer, it is also the most convenient archival method there is.
Or, alternatively, you can use the combination of archiving by saving of data to browser's local storage (the default) followed by manual export into WRR
bundles as described below in the section on using Hoardy-Web
together with Tor Browser.
Or, alternatively, you can switch to Export dumps via 'saveAs'
mode by default and simply accept the resulting slightly more annoying UI (on Firefox, it can be fixed with a small about:config
change) and the facts that you can now lose some data if your disk ever gets out of space or if you accidentally mis-click a button in your browser's Downloads
UI.
Next, you should read extension's Help
page.
It has lots of useful details about how it works and quirks of different browsers.
If you open it by clicking the Help
button in the extension's UI, then hovering over or clicking on links in there will highlight relevant settings.
See "Setup recommendations" section for best practices for configuring your system and browsers to be used with Hoardy-Web
.
Install Python 3
:
python3
via your package manager. Realistically, it probably is installed already.Install the Pythonic parts:
Test the results actually work:
PATH
environment variable:python3 -m hoardy_web_sas --help
python3 -m hoardy_web --help
hoardy-web-sas --help
hoardy-web --help
Install everything by running
nix-env -i -f ./default.nix
Test the results work:
hoardy-web-sas --help
hoardy-web --help
Also, instead of installing the add-on from addons.mozilla.org
or from Releases on GitHub you can take freshly built XPI and Chromium ZIPs from
ls ~/.nix-profile/Hoardy-Web*
instead. See the extension's README for more info on how to install them manually.
You can add hoardy_web_sas.py
to Autorun or start it from your ~/.xsession
, systemd --user
, etc.
You can also make a new browser profile specifically for archived browsing, run Firefox as firefox -ProfileManager
to get to the appropriate UI. On Windows you can just edit your desktop or toolbar shortcut to target
"C:\Program Files\Mozilla Firefox\firefox.exe" -ProfileManager
or similar by default to switch between profiles on browser startup.
It is highly recommended you make separate browser profiles for anonymous and logged-in browsing with separate extension instances pointing to separate archiving server instances dumping data to different directories on disk.
Set the "anonymous" browser profile to always run in Private Browsing
mode to prevent login persistence there.
If you do accidentally login in "anonymous" profile, move those dumps out of the "anonymous" directory immediately.
This way you can easily share dumps from the "anonymous" instance without worrying about leaking your private data or login credentials.
Hoardy-Web
with Tor BrowserWhen using Hoardy-Web
with Tor Browser, you probably want to configure it all in such a way so that all of the machinery of Hoardy-Web
is completely invisible to web pages running under your Tor Browser, to prevent fingerprinting.
So, in the mostly convenient yet sufficiently paranoid setup, you would only ever use Hoardy-Web
extension configured to archive captured data to browser's local storage (which is the default) and then export your dumps manually at the end of a browsing session, see re-archival intructions.
Yes, this is slightly annoying, but this is the only absolutely safe way to export data out of Hoardy-Web
without using submission via HTTP
, and you don't need to do this at the end of each and every browsing session.
You can also simply switch to using Export dumps via 'saveAs'
by default instead.
I expect this to work fine for 99.99% of the users 99.99% of the time, but, technically speaking, this is unsafe.
Also, by default, browser's UI will be slightly annoying, since Hoardy-Web
will be generating new "Downloads" all the time, but that issue can be fixed with a small about:config
change.
In theory, running ./hoardy_web_sas.py
listening on a loopback IP address should prevent any web pages from accessing it, since the browsers disallow such cross-origin requests, thus making the normal Submit dumps via 'HTTP'
mode setup quite viable.
However, Tor Browser is configured to proxy everything via the TOR network by default, so you need to configure it to exclude the requests to ./hoardy_web_sas.py
from being proxied.
A slightly more paranoid than normal way to do this is:
./hoardy_web_sas.py --host 127.0.99.1
or similar.about:config
in your Tor Browser and add 127.0.99.1
to network.proxy.no_proxies_on
.Server URL
setting in the extension to http://127.0.99.1:3210/pwebarc/dump
.Why?
When using Tor Browser, you probably don't want to use 127.0.0.1
and 127.0.1.1
as those are normal loopback IP addresses used by most things, and you probably don't want to allow any JavaScript
code running in Tor Browser to (potentially, if there are any bugs) access to those.
Yes, if there are any bugs in the cross-domain check code, with this setup JavaScript
could discover you are using Hoardy-Web
(and then, in the worst case, DOS your system by flooding your disk with garbage dumps), but it won't be able to touch the rest of your stuff listening on your other loopback addresses.
So, while this setup is not super-secure if your Tor Browser allows web pages to run arbitrary JavaScript
(in which case, let's be honest, no setup is secure), with JavaScript
always disabled, to me, it looks like a completely reasonable thing to do.
In theory, you can have the benefits of both invisibility of archival to local storage and convenience, guarantees, and error reporting of archival to an archiving server at the same time:
./hoardy_web_sas.py --host 127.0.99.1
or similar.network.proxy.no_proxies_on
, enable submission via HTTP
while disabling saving to local storage, re-archive, your local storage should now be empty, unset network.proxy.no_proxies_on
again.In practice, doing this manually all the time is prone to errors. Automating this away is on the TODO list.
Then, you can improve on this setup even more by running both the Tor Browser and ./hoardy_web_sas.py
in separate containers/VMs.
"Cons" and "Pros" are in comparison to the main workflow of Hoardy-Web
.
Most similar and easier to use projects first, harder to use and less similar projects later.
Tools most similar to Hoardy-Web
in their implementation, though not in their philosophy and intended use.
Pros:
Hoardy-Web
currently has.Cons:
Hoardy-Web
does:
archiveweb.page
for each browser tab; and thenarchiveweb.page
also requires constant manual effort to export the data out.Differences in design:
archiveweb.page
captures whole browsing sessions, while Hoardy-Web
captures separate HTTP
requests and responses;archiveweb.page
implements "Autopilot", which Hoardy-Web
will never get (if you want that, Hoardy-Web
expects you to use UserScripts instead).Same issues:
Both Hoardy-Web
and archiveweb.page
store captured data internally in the browser's local storage/IndexedDB by default.
This is both convenient for on-boarding new users and helps in preserving the captured data when your computer looses power unexpectedly, your browser crashes, you quit from it before everything gets archived, or the extension crashes or gets reloaded unexpectedly.
On the other hand, this is both inefficient and dangerous for long-term preservation of said data, since it is very easy to accidentally loose data archived to browser's local storage (e.g., by uninstalling the extension).
Which is why Hoardy-Web
has Submit dumps via 'HTTP'
mode which will automatically submit your dumps to the hoardy-web-sas
simple archiving server instead.
When running under Chromium, a bunch of Chromium's bugs make many things pretty annoying.
Both Hoardy-Web
and archiveweb.page
suffer from exactly the same issues, which --- if you know what to look for --- you can notice straight in the advertisement animation on their "Usage" page.
Those issues have no workarounds known to me (except for "switch to Firefox-based browser").
But because they exists, I made Hoardy-Web
instead of forking archiveweb.page
, trying to port it to Firefox, and making the fork follow my preferred workflow.
A self-hosted web app and web crawler written in Node.js
most similar to Hoardy-Web
in its intended use.
DownloadNet
does its web crawling by spawning a Chromium browser instance and attaching to it via its debug protocol, which is a bit weird, but it does work, and with exception of Hoardy-Web
it is the only other tool I know of that can archive everything passively as you browse, since you can just browse in that debugged Chromium window and it will archive the data it fetches.
Pros:
Hoardy-Web
aims to do, exceptCons:
Same issues:
Browser add-ons that capture whole web pages by taking their DOM
snapshots and saving all requisite resources the captured page references.
Pros:
Hoardy-Web
currently does not.Cons:
Hoardy-Web
does, you will have to manually capture each page you want to save;POST
request data or JSONs fetched by web apps;HTTP
requests and responses, capturing a page will make the browser re-download non-cached page resources a second time;CSS
, fonts, etc) for each web page to make each saved page self-contained.Differences in design:
DOM
snapshots, while Hoardy-Web
captures HTTP
requests and responses (though, it can capture DOM
snapshots too).A browser extension that implements an alternative mechanism to browser bookmarks.
Saving a web page into Memex saves a DOM
snapshot of the tab in question into an in-browser database.
Memex then implements full-text search engine for saved snapshots and PDFs.
Pros:
Hoardy-Web
currently does not;Cons:
Hoardy-Web
does, you will have to manually save each page you visit;POST
request data or JSONs fetched by web apps;Hoardy-Web
, it is very fat --- it's .xpi
is more than 40 times larger;about:performance
);HTTP
requests to third-party services in background (Hoardy-Web
does none of that);Differences in design:
DOM
snapshots and PDFs, while Hoardy-Web
captures HTTP
requests and responses (though, it can capture DOM
snapshots too);Hoardy-Web
expects you to do that with third-party tools;Hoardy-Web
expects you to use normal file backup tools for that.HAR
archives from time to time.Cons:
Hoardy-Web
does, you will have to manually enable it for each browser tab;HAR
s are JSON
, meaning all that binary data gets encoded indirectly, thus making resulting HAR
archives very inefficient for long-term storage, as they take a lot of disk space, even when compressed.And then you still need something like this suite to look into the generated archives.
A Man-in-the-middle SSL proxy.
Pros:
Hoardy-Web
add-on currently does not capture.Cons:
mitmproxy
dump files are flat streams of HTTP
requests and responses that use custom frequently changing between versions data format, so you'll have to re-parse them repeatedly using mitmproxy
's own parsers to get to the requests you want;HTTP
request+response streams as website mirrors or some such.Though, the latter issue can be solved via this project's hoardy-web
tool as it can take mitmproxy
dumps as inputs.
Pros:
Hoardy-Web
add-on currently does not.Cons:
HTTP
data from the PCAP
dumps; andPCAP
dumps are IP packet-level, thus also inefficient for this use case; andPCAP
dumps of SSL traffic can not be compressed much, thus storing the raw captures will take a lot of disk space.And then you still need something like this suite to look into the generated archives.
A web crawler and self-hosted web app into which you can feed the URLs for them to be archived.
Pros:
WARC
format, which is a de-facto standard;git
repos, etc;Cons:
Hoardy-Web
does,
mitmproxy
with archivebox-proxy plugin;HTTP POST
requests with it.Still, probably the best of the self-hosted web-app-server kind of tools for this ATM.
A system similar to ArchiveBox
, but has a bulit-in tagging system and archives pages as raw HTML
+ whole-page PNG
rendering/screenshot --- which is a bit weird, but it has the advantage of not needing any replay machinery at all for re-viewing simple web pages, you only need a plain simple image viewer, though it will take a lot of disk space to store those huge whole-page "screenshot" images.
Pros and Cons are almost identical to those of ArchiveBox
above, except it has less third-party tools around it so less stuff can be automated easily.
wget -mpk
and curl
Pros:
Cons:
Hoardy-Web
does, you will have to manually capture each page you want to save;wget
and making wget
play pretend at being a normal web browser is basically impossible;curl
, curl
also doesn't have the equivalent to wget
's -mpk
options;wget -mpk
done right.
Pros:
WARC
format, which is a de-facto standard and has a lot of tooling around it;Cons:
Hoardy-Web
does, you will have to manually capture each page you want to save;HTTP POST
requests with it;WARC
files.A simple web crawler built on top of wpull
, presented to you by the ArchiveTeam, a group associated with the Internet Archive which appears to be the source of archives for the most of the interesting pages I find there.
Pros:
WARC
format, which is a de-facto standard and has a lot of tooling around it;Cons:
Hoardy-Web
does, you will have to manually capture each page you want to save;HTTP POST
requests with it;WARC
files.Stand-alone tools doing the same thing SingleFile add-on does: generate single-file HTML
s with bundled resources viewable directly in the browser.
Pros:
Cons:
Hoardy-Web
does, you will have to manually capture each page you want to save;HTTP POST
requests using them;Stand-alone tool based on SingleFile
, using a headless browser to capture pages.
A more robust solution to do what monolith
and obelisk
do, if you don't mind nodejs
and the need to run a headless browser.
The crawler behind the Internet Archive.
It's a self-hosted web app into which you can feed the URLs for them to be archived, so to make it archive all of your web browsing:
Pros:
WARC
format, which is a de-facto standard and has a lot of tooling around it;Cons:
/save/
REST API URLs (which is not hard, but I'm unaware if any such add-on exists);HTTP POST
requests with it.A self-hosted wiki that archives pages you link to in background.
ArchiveBox wiki has a long list or related things.
It's an awesome personal private archival system adhering to the same philosophy as Hoardy-Web
, but it's basically an abstraction replacing your file system with a content-addressed store that can be rendered into different "views", including a POSIXy file system.
It can do very little in helping you actually archive a web page, but you can start dumping new Hoardy-Web
.wrr
files with compression disabled, decompress you existing .wrr
files, and then feed them all into Perkeep to be stored and automatically replicated to your backup copies forever.
(Perkeep already has a better compression than what Hoardy-Web
currently does and provides a FUSE FS interface for transparent operation, so compressing things twice would be rather counterproductive.)
See CHANGELOG.md
.
See the bottom of CHANGELOG.md
.
GPLv3+, some small library parts are MIT.
Contributions are accepted both via GitHub issues and PRs, and via pure email.
In the latter case I expect to see patches formatted with git-format-patch
.
If you want to perform a major change and you want it to be accepted upstream here, you should probably write me an email or open an issue on GitHub first. In the cover letter, describe what you want to change and why. I might also have a bunch of code doing most of what you want in my stash of unpublished patches already.