Bonum Certa Men Certa

Help Make Techrights (and Other Technology-Centric Sites) More Robust to Censorship by Setting Up More IPFS Nodes

IPFS large logo



Summary: We're trying to improve the site's availability (ensuring it can never be offline) and make it more censorship-resistant; people who adopt IPFS can make that happen while tackling the "bloated Web" and "centralised Internet" issues -- all at the same time

JUST over a month ago we hooked up with data-centric security folks who had offered help with Techrights. Having faced legal threats over the years (for exposing corruption), we're always looking for ways to avert or discourage such attempts (ideally, even if we're forced to go offline or remove something, we want that to be outside our control, i.e. inability to comply, even if there's a will to comply). We don't typically just repeat what other sites say, we have many exclusive stories and we publish leaks (unseen beforehand).



Now, less than a month later, we have a pipeline for publishing the site both as text and over distributed protocols. The Techrights IPFS node over here (at home) now exceeds 50GB in traffic, just 3 weeks down the line (after introducing people to it, i.e. 'going public'). Not bad considering how young it is. It's always active, offering full site access. There's no single point of failure, no HTTP, no WWW, no HTML. It's very text-centric and thus compact, portable and so on. No bloat associated with exporting/importing images, fonts, JavaScript and so on.

Earlier today we published many pages of internal EPO material; we need to get those sorts of things backed up, as EPO management can be litigious and threatening (they tried it on us several times). Techrights is home to many other important bits of material; months ago we published old debian-private archives (1990s only); those were accessed nearly 30,000 times in this past week alone. Giving Debian better transparency 2.5 decades later can't be a bad thing. In fact, nobody contacted us regarding removal or redaction. Those mailing lists are pretty harmless and barely even embarrassing. Due to their age, they don't present/pose a threat to anybody's career.

"In other words, the more people participate in this network, the more robust and censorship-resistant it'll become. This, in turn, can attract more high-profile whistleblowers with high-profile leaks."Now, on to the 'beef' of this post...

This past autumn we spent time coding and testing a bunch of stuff (at the back end for the most part). First we made everything in the site accessible in/as text. Plain text. Nice and simple. Then, we explored a number of distribution systems. At the end we went ahead of IPFS, seeing that it is decentralised and Web-agnostic (its protocols aren't connected to the Web, unless a gateway is set up). We already have a number of devices pinning and serving the site's pages (or objects) upon request by CID.

Share large logoHow can readers help? They can become nodes. The material itself isn't sensitive (everything in it is public anyway), but it's precarious in the sense that takedown requests can be attempted against our main servers; we want to make it very clear upfront that it's an exercise in futility because many copies of the articles are already 'out there', being distributed by peer, not from a single point (of potential failure).

In other words, the more people participate in this network, the more robust and censorship-resistant it'll become. This, in turn, can attract more high-profile whistleblowers with high-profile leaks.

An informal manual was typed up by one of us as a sort of primer for those wishing to set up their own node. It ought not be hard to achieve (by just following the series of steps). Those instructions were written for a Raspberry Pi with Debian, but the hardware and the distro ought not matter much because we use the binaries rather than repos.

"I'm going to outline a pragmatic setup that you can use to get going with IPFS on any host," said the manual's author. Here's the recipe:




SUMMARY



Make user + group for IPFS. All further steps are to be performed under IPFS user's "~/" (home directory).

Download and extract latest Go binaries available from official tarball.

Symbolic link Go binary executables, from tarball, into "~/bin".

Download and extract latest IPFS binary available from official tarball.

Symbolic link IPFS binary executable, from tarball, into "~/bin".

BEGIN IPFS BASIC USE GUIDE SUMMARY



What's covered:

IPFS conceptual overview.

Help from the `ipfs` command itself.

Initialise ipfs for your IPFS user.

List pinned IPFS objects.

Add/pin IPFS objects.

Remove pinned IPFS objects.

Run garbage collector for IPFS objects.

Check IPFS stats.

Check a file's CID without adding/pinning to IPFS.

SETUP DETAILS



Make a dedicated user and group for IPFS on your machine. This will keep things manageable, down the line. Everything should be done under the IPFS user's home directory "~/".

Grab the latest Go binary you can find. Set it up in the home directory of your IPFS user. You can find the latest Go binary here. There are builds for a wide array of operating systems and CPU architectures.

Extract the tarball; look in "/bin" in the tarball for the binary executables. Right now there are two binaries, "go" and "gofmt".

Create a symbolic link in "~/bin" for the binary executables you find in the Go tarball. You should be able to run `$ source ~/.profile` to make sure "~/bin" is in PATH, for the IPFS user.

This completes the Go setup.

Next, we tackle the IPFS setup.

Download the latest binary you can get for go-ipfs from here. This binary should be packed in a tarball.

Extract the tarball.

"go-ipfs" is the name of the binary executable. Create a symbolic link for this binary in "~/bin". You don't need to use the setup script provided. It'll just mess with things that don't need messing.

IPFS BASIC USE GUIDE



Think of IPFS as a filesystem that lives on the Internet. Each file is an IPFS object denoted by a hash called the CID (content identifier).

`ipfs --help` includes help for commands and subcommands. Always double-check with this to make sure that anything you read on the Internet about IPFS matches up to the binary you actually are using on your system.

Before you do anything with ipfs, make sure to run `ipfs init`. This will populate "~/.ipfs" for you. That's all you need to do for initial setup.

You can "deploy" ipfs locally with `ipfs daemon`; this process will be running in the foreground and print to the terminal (probably stdout). You can just put it in the background and redirect stdout and stderr to a log file to manually monitor what it's doing. Killing this daemon will mean your IPFS node is no longer online. Feel free to control this daemon in whichever method you choose. This guide is kept as abstract as possible to enable deployment in maximum number of environments.

Files from your host can be added to IPFS as something called IPFS objects. The ipfs command for this is, unsurprisingly, called `ipfs add`. `ipfs add path` will add the specified file or directory to IPFS.

By default, `ipfs add` "pins" objects in your local IPFS datastore. What is a "pinned object"? A pinned object is an IPFS object in your local IPFS datastore that doesn't get garbage-collected.

`ipfs pin ls` is a good way to view your pins. `ipfs pin rm` can be used to remove pins; if you try to remove the wrong type of pin, IPFS will get mad and yell at you because it's probably a recursive pin (you'll see what kind of pin an IPFS object is in the output for `ipfs pin ls`); a top-level pin will probably be of type "recursive" (so you'll need to remove that to get rid of all the pinned objects that are associated).

You can check bandwidth status with `ipfs stats bw`. Good way to keep track of your precious bandwidth. ipfs comes with some default pins. You might want to get rid of those with `ipfs pin rm` to save on bandwidth. Those pins are documentation, however, so it's up to you if you want to keep them around or not.

Just removing a pin is not enough to ensure pin(s) are no longer is eating up your local IPFS datastore space. `ipfs repo gc` will run the garbage collector to get rid of all the unpinned IPFS objects.

The default IPFS configuration is pretty sane. You can find the default config file for IPFS in "~/.ipfs/config"; the config file is formatted in JSON. See `ipfs config --help` for further details.

Remember: always check `ipfs <command> <subcommand> --help` for definitive guidance on your binary's implementation. `ipfs --help` should be skimmed, in full, before you do anything with IPFS; you will likely find commands to help you with what you want to do. Don't forget that `ipfs <command> --help` and `ipfs <command> <subcommand> --help` are always available for you as well.

Consuming IPFS objects is straightforward. Just look at `ipfs get --help` and `ipfs cat --help` for instructions.

To check what a file's CID is, without adding/pinning to ipfs, just run `ipfs add -n /path/to/file`; see `ipfs add --help` for details. This is going to be a very important operation if you want to do any automation. It helps knowing what a file's CID will be before doing any operations live IPFS operations on it.

You should now be able to independently navigate the Internet for further information on IPFS. Official, online, documentation available here. Remember to always cross-check `ipfs version` and `ipfs <command> <subcommand> --help` to ensure what you read on the Internet is applicable to the IPFS binary executable on your system.

Image attributions: Font Awesome (Creative Commons Attribution 4.0 International) and IPFS project (Creative Commons Attribution-Share Alike 3.0 Unported)

Recent Techrights' Posts

The Importance of a Resilient Partner
Rianne's mental strength is something I both admire and sometimes envy
Dakota Chambers says “the year of Linux on the desktop” is next year (6 weeks from now)
Six weeks from now it is 2026 already
 
Links 20/11/2025: Esperanto Music History and "Hacking the URL Schema"
Links for the day
Links 20/11/2025: Phone Distraction Causes Ferry's Crash, Lots of Negative Press for Slop (Consensus Shifting)
Links for the day
Links 20/11/2025: Python Risk From Rust Activists, "Climate Change is Biggest Security Threat"
Links for the day
Links 20/11/2025: Cloudflare Outage Post Mortem and Tesla Robotaxi "Safety"
Links for the day
More Layoffs, Shutdowns Connected to Microsoft's XBox and Gaming Failure
sales flounder
Geminispace/Gopher Links 20/11/2025: Nagless, VPS, and Java
Links for the day
Over at Tux Machines...
GNU/Linux news for the past day
IRC Proceedings: Wednesday, November 19, 2025
IRC logs for Wednesday, November 19, 2025
Some People Still Being RAd at IBM This Week, According to Unverified Claims Online
IBM is misleading shareholders
Gemini Links 19/11/2025: FlatCube, uBlock Origin, and More
Links for the day
Luis Berenguer Giménez Claims to Still be at the EPO (European Patent Office), Even After His Replacement Following Cocaine Bust
Look what sort of culture Campinos imported from the EU (EUIPO) to Bavaria
Censorship Doesn't Always Work
Somehow we've managed to attract the wrath of some large corporations and organisations
The Media Explains to Us Why It's Dangerous to Cover EPO's "Cocainegate"
Does the EPO command the European media?
Fake News Sites Made by LLMs Are Lying With Confidence (IBM and Red Hat Layoffs)
Slop just doesn't work
Microsoft Lunduke Publicly Attacking Linus Torvalds Says a Lot About 4Chan Cult(ure)
find some issues that sites like ours habitually explore/investigate/revisit, then add some lunatic spin on top of them
Europe Talks About "Digital Sovereignty" and Free Software in Europe is Where Things Should Start
Time will tell if anything concrete can emerge from the above, as media reports certainly have not, at least not in English
Links 19/11/2025: Lawfare Against Greenpeace, Major British Newspaper Caught Using LLM Slop
Links for the day
Links 19/11/2025: "Corporate-Government Censorship" by App Stores (Says ACLU) and Invalidation of Patent Trolls' Patents Sought
Links for the day
Links 19/11/2025: Several Sites Admit Slop Bubble "About to Burst", US Government Tacitly Endorses Assassination of Journalists
Links for the day
GNU/Linux Up to 5% in analytics.usa.gov, Apple and Microsoft Only Sell Fantasies
As for Microsoft, it tries to rebrand Windows as "AI" something or "agentic" (AI) something because it's not selling well and Microsoft needs to engage in "creative" storytelling with shareholders
They Want to Take Humour Away
If society starts gravitating towards jokes being taboo and abuse/violence/online trolling being "jokes" (they're not), we're worse off and more like North Korea
The New Stack, Sponsored by Microsoft: Pay Us Money to Read Promotion of Slop Composed by Microsofters to Sell Their Proprietary Slopware
it's a self-promotional plug for someone who came from Microsoft
Claims That IBM Research Brazil is Shutting Down, Japan Impacted Also
As usual, the corporate media won't mention this
Links 19/11/2025: Google Nest Surveillance and Daily Telegraph Still Up for Sale
Links for the day
Gemini Links 19/11/2025: "Slack is a Sauna" and ClaudeBot Nuisance
Links for the day
Over at Tux Machines...
GNU/Linux news for the past day
IRC Proceedings: Tuesday, November 18, 2025
IRC logs for Tuesday, November 18, 2025
"GNU/Linux" No Longer a Pandora's Box
Cannot even make or crack a joke... when you have a target painted on your back
We Don't Keep Logs
Not for any considerable length of time
Wall Street Journal is Publishing Puff Pieces About Quantum
For IBM [...] a lot of articles about "AI" are basically a form of spam
Is the Lid Being Shut on Top of LLM Slop?
It sort of "feels" like slop is becoming passé
Celebrating Digital Sovereignty
Digital Sovereignty is connected very closely to the concept of Software Freedom
Your Web Site is Connected to the Net and the Server is Powered On, But Cloudflare Takes It All Down
Anything outsourced means that yet another party can get things wrong, resulting in problems for everyone else "in the chain"
The Register's Latest Slop Spam, Another Paid-for Article to Inflate the Bubble
Remember when celebrities advertised FTX?
Quite a Few Red Hat Layoffs These Days (or Departures)
Remember that if there are Red Hat Layoffs, they won't be called "Red Hat Layoffs" but instead be "IBM RAs" or some thing to that effect
Today is an Excellent Day To Remind People to Dump Clownflare (Cloudflare)
If people think that Clownflare (Cloudflare) will improve uptime and make access better (it sure makes accessibility far worse), remind them of all the times this clown show goes wrong, taking down with it a lot of the Web
Links 18/11/2025: Asbestos Fears, Delays for GAFAM Undersea Cable
Links for the day
Links 18/11/2025: "Bitcoin Showing Signs of Severe Collapse" and CEOs of GAFAM Finally Speak About a Slop Bubble
Links for the day
The "Nazi Bars"
We don't condone or condemn the label "Nazi Bar"
Apparent Red Hat Layoffs in "AI" (Supposedly a Strategic Area for IBM)
What is going on there?
TV Programmes in Geminispace
Sort of like teletext except more cross-platform
Gemini Protocol as a Growing Source of Audience (Mostly Technical People)
Clients for Gemini Protocol are available for almost every platform imaginable
Techrights' Assessment of Red Hat Layoffs in 2025 (Yes, They Happened!)
In short, Red Hat layoffs did occur this year, but even when they did the media did not mention these (and those would count as "IBM" regardless)
The GPU Bubble (GPUs Marketed by Useless Slop)
"they're selling GPUs for the sake of selling GPUs"
EPO Change May be Afoot, Keep Pushing and Hold Those Feet to the Fire
Backlash is brewing and societal trends reinforce backlash right now
Links 18/11/2025: CISA Advisories, Climate, "U.S. Layoffs Surge and Blaming AI is Part of the Smokescreen"
Links for the day
Gemini Links 18/11/2025: "Block Them All", Annex, Signed Commits, and "Cryptography of the Internet"
Links for the day
Over at Tux Machines...
GNU/Linux news for the past day
IRC Proceedings: Monday, November 17, 2025
IRC logs for Monday, November 17, 2025
Right Under the Nose of Mainstream Media
That the media fails to cover the matter mostly speaks volumes about the media
Formalities Officers at the EPO Face Uncertain Future, Administration Gets Asked About That
They're being too polite (perhaps) to people whose agenda is detrimental not just to the EPO but also the EPC