Harness the power of IPFS in your browser!
[!NOTE] This browser extension is currently maintained by the Shipyard team.
IPFS Companion harnesses the power of your locally running IPFS Kubo node (either through the IPFS Desktop app or the command-line daemon) directly inside your favorite Chromium-based or Firefox browser, enabling support for ipfs:// addresses, redirecting content-addressed websites and file paths to your local Gateway, easy IPFS file import and sharing, and more.
IPFS is a peer-to-peer hypermedia protocol designed to make the web faster, safer, more resilient, and more open. It enables completely distributed sites and applications that don’t rely on centralized hosting and stay true to the original vision of an open, flat web. Visit the IPFS Project website to learn more.
IPFS Companion detects requests for IPFS-like paths (such as /ipfs/{cid} or /ipns/{peerid_or_host-with-dnslink}) on any website. If a path is a valid IPFS address, it is redirected to load from your local gateway. The gateway at localhost will also automatically switch to a subdomain gateway to provide a unique origin for each website:
[!NOTE] Path gateway redirect flow:
- Step 1: Public gateway URL detected
https://ipfs.io/ipfs/QmbWqxBEKC3P8tqsKc98xmWNzrzDtRLMiMPL8wBuTGsMnR- Step 2: Redirect to local gateway
http://localhost:8080/ipfs/QmbWqxBEKC3P8tqsKc98xmWNzrzDtRLMiMPL8wBuTGsMnR- Step 3: Automatic upgrade to subdomain with origin isolation
http://bafybeigdyrzt5sfp7udm7hu76uh7y26nf3efuylqabf3oclgtqy55fbzdi.ipfs.localhost:8080
[!NOTE] Subdomain gateway redirect flow:
- Step 1: Subdomain gateway URL detected
https://bafybeigdyrzt5sfp7udm7hu76uh7y26nf3efuylqabf3oclgtqy55fbzdi.ipfs.dweb.link- Step 2: Redirect to local subdomain with origin isolation
http://bafybeigdyrzt5sfp7udm7hu76uh7y26nf3efuylqabf3oclgtqy55fbzdi.ipfs.localhost:8080
IPFS Companion detects DNSLink info in the DNS records of websites. If a site uses DNSLink (a few examples are https://docs.ipfs.tech, https://ipld.io, and http://tr.wikipedia-on-ipfs.org), IPFS Companion redirects the HTTP request to your local gateway:
[!NOTE] DNSLink redirect flow:
- Step 1: DNSLink-enabled website detected
http://docs.ipfs.tech- Step 2: Redirect to local gateway
http://localhost:8080/ipns/docs.ipfs.tech- Step 3: Automatic upgrade to subdomain with origin isolation
http://docs.ipfs.tech.ipns.localhost:8080/
x-ipfs-path headersIPFS Companion also upgrades transport to IPFS when it detects x-ipfs-path in HTTP response headers; this also acts as a fallback for cases when an IPFS path is not present in the URL. Learn more.
You can disable and re-enable local gateway redirects by several means:
x-ipfs-companion-no-redirect to the URL itself as a hash (example) or query parameter (example)IPFS Companion enables you to quickly and easily access common actions from your browser bar with just a few clicks:
You can toggle redirects (of any IPFS sub-resources) for an individual website under the Current Tab section of the main menu. If that site uses DNSLink, toggling off will restore the site’s original URL, too.
To temporarily suspend all IPFS integrations (redirects, API status content scripts, protocol handlers, etc.), use the on/off button at the top of the IPFS Companion menu.
IPFS Companion ships with a variety of experimental features. Some are disabled by default, so be sure to check out IPFS Companion’s Preferences to see them all.
ipfs://$cidipns://$cid_or_fqdnImportant! Make sure you have IPFS installed on your computer as well. IPFS Companion requires a local IPFS Kubo node running on your computer to function properly.
It’s also possible to grab vendor-specific packages for each release,
but these builds are not signed, nor will they automatically update. .zip bundles are meant only to be manually loaded via chrome://extensions (Chromium) or about:debugging (Firefox) for smoke-testing.
To work on IPFS Companion’s code, you’ll need to install it from source. Quick steps are below, but see the full developer notes for more detailed instructions and tips.
$ npm run dev-build chromium
$ npm run dev-build firefox # firefox:nightly works too!
All are welcome to help make IPFS Companion even better!
The release process has been documented here.
[!TIP] The best place to ask about IPFS Companion (or IPFS in general!) is in the official IPFS Forums, where you can search past discussions for others who may have had the same questions, too.
These frequently encountered troubleshooting situations may be helpful:
Site ^http://127.0.0.1:8080/(ipfs|ipns)* Anonymize
Site LOCAL Accept from LOCAL Deny ```