Skip to content

Latest commit

 

History

History
68 lines (50 loc) · 3.49 KB

README.md

File metadata and controls

68 lines (50 loc) · 3.49 KB

ipfs daemon in a webextension

This is a demo of running ipfs from a webextension.

Usage

Install Go

This requires Go 1.7 or higher. If you don't have it: Download Go 1.7+.

Install script

On linux and OSX, the install script should work (though no guarantees, its very new and not well tested)

BROWSER can be any of firefox, googlechrome or chromium

[why@laptop]$ ./install.sh BROWSER

Once that completes, load the extension into your browser.

Firefox

For firefox, go to about:debugging and click the "Load Temporary Add-on" button on the right. In the file explorer that pops up, navigate to this directory and select the manifest.json file.

Chromium

For chrome, go to chrome://extensions and click the "Load unpacked extension" button at the top. In the file explorer that pops up, navigate to this directory, and select it (select the directory itself, not the manifest.json file).

Try it out!

Now, assuming it all worked properly, you should be able to visit any site in ipfs via the ipfs.io gateway and the request will be automatically redirected to your locally running ipfs node. Try going to something like https://ipfs.io/ipfs/QmZNtENBtGvgzPED3Uqt6zxxKAkCGWWQ1XedBVAH7agGSZ and watch the url bar change from ipfs.io to localhost.

Manual Installation

If the previous instructions didnt work, you can try to do what the install script does manually:

  • Edit the ipfs.json file so that the path field points to the script in this repo (wherever you happened to have cloned it).
  • Move the ipfs.json file to be inside ~/.mozilla/native-message-hosts/ (this path is different for each OS and browser)
  • Edit the localgatewayurl variable in the background.js file to point to whatever your local gateway is configured to be.
  • Either init an ipfs node with IPFS_PATH set to /tmp/ff-ipfs, or change the run-ipfs.sh script so that IPFS_PATH points to an initialized ipfs repo. (leaving it blank is acceptable if you want to use the default location of ~/.ipfs)
  • Open up firefox (must be at least version 49 i think), and go to about:debugging
  • Click "Load Temporary Add-on" and navigate to and select the manifest.json file in this directory.
  • Try loading pages like https://ipfs.io/ipns/ipfs.io and it should redirect to localhost.
  • Do a little dance, and get yourself some coffee

Potential Future Architecture

The way i see this extension working when "done" is roughly as follows:

  • Extension ships with a small shell script that is able to download an ipfs-manager type program that does a few things:
    • communications with firefox via nativeMessaging (does the length prefixed json message stuff)
    • Is able to download, init, start and stop an ipfs daemon
    • Is able to control the ipfs daemon via messages from the webextension

All requests to the ipfs.io gateway should be redirected locally, and the protocol handlers for fs:// should be respected.

Done this way, the extension can self-update and provide a seamless user experience.

Troubleshooting

If the installation doesnt work, please file an issue.

If the installation succeeds, but the extension doesnt appear to be working properly, here are a few things to try:

In firefox, error messages from the process get sent to the developer console. Check here for any issues. In chrome, error messages get sent out to chromes error logs on stderr. To see these, you'll need to start chrome from a terminal.

Check if an ipfs daemon is running with: ps aux | grep ipfs