Skip to main content

Distributed web browser

Project description

https://gitlab.com/galacteek/galacteek/raw/master/share/icons/galacteek.png
info:

A multi-platform browser for the distributed web

galacteek is an experimental multi-platform Qt5-based browser/toolbox for the IPFS peer-to-peer network.

Platforms supported

  • Linux (main target)

  • FreeBSD (or any BSD OS, as long as you have PyCryptodome)

  • MacOS (experimental)

If it works for you, great, but most likely it won’t :) This started as an experiment with quamash and is WIP.

Installation

On Linux systems you can use the AppImage (from the releases page) or install from PyPI. On MacOS and other systems you’ll need to install from PyPI.

PyPI

You need to have python>=3.6 and pip installed. From a virtualenv, or as root, install with:

pip install galacteek

Upgrade with:

pip install -U galacteek

Or building it from source:

pip install -r requirements.txt
python setup.py build install

Now just run the application with:

galacteek

If you don’t have go-ipfs already installed, the application will ask you if you want to automatically download it from dist.ipfs.io You need a recent version of go-ipfs (> 0.4.7) with the new DAG API.

For the media player to work on Linux, you will need to install the gstreamer (1.x) package and all the gstreamer plugins.

There is experimental support for reading QR codes containing IPFS addresses, using pyzbar. pyzbar depends on the zbar shared library, so make sure it’s installed on your system (on Linux look for a libzbar or libzbar0 package and install it, on MacOS install it with brew install zbar).

AppImage

For Linux users (arch: x86_64), you can get an AppImage from the releases page. The script used to build the image can be found here

Command-line usage

Use the -d command-line switch to enable debugging output. Using –profile gives you the ability to have separate application profiles (main is the default profile). Use –help for all options.

Development: Use –monitor to enable event-loop monitoring with aiomonitor (install aiomonitor manually as it’s not a dependency). Then connect to the aiomonitor interface with nc localhost 50101

URL schemes

As much as possible we’re trying to follow the in-web-browsers specs (URL notations are taken from there).

ipfs:// and ipns://

These are what could be considered the native schemes. The scheme handler for these schemes supports the following URL formats:

ipfs://{cidv1base32}/path/to/resource
ipns://{fqdn-with-dnslink}/path/to/resource

This scheme handler makes the requests asynchronously on the daemon (it does not use the go-ipfs’s HTTP gateway). The root CID or IPNS domain of the URL is considered the authority.

We are using CIDv1 by default for all content (and starting with go-ipfs v0.4.21, they will be base32-encoded by default). If you’re accessing an object within a base58-encoded CIDv1, the root CID will automatically be converted to its base32 representation so that you can use the native ipfs:// scheme.

When you are using the native handler, the URL’s background color should change (you’re using base32 after all!) and will look something like this:

https://gitlab.com/galacteek/galacteek/raw/master/screenshots/ipfs-scheme-urlbar.png

Note: this is a recent implementation, please report any issues. MIME type detection for rendered resources could be slow on platforms that don’t have libmagic.

dweb:/

This is the legacy scheme and it will be automatically used when accessing content rooted under CIDv0 objects. Because it proxies the requests to the daemon’s HTTP gateway, it can handle anything that the daemon supports:

dweb:/ipfs/{cidv0}/path/to/resource
dweb:/ipfs/{cidv1b32}/path/to/resource
dweb:/ipfs/{cidv1b58}/path/to/resource
dweb:/ipns/{fqdn-with-dnslink}/path/to/resource
dweb:/ipns/{libp2p-key-in-base58}/path/to/resource

ens://

There is support for accessing IPFS-hosted websites that are registered on the Ethereum Name Service (see ENS). Just use ens://mydomain.eth for example as a URL in the browser and you will be redirected to the IPFS website referenced on ENS for this domain.

Go to ens://blog.almonit.eth to find a list of some ENS+IPFS websites.

Features

galacteek can either spawn an IPFS daemon and use it as transport, or connect to an existing IPFS daemon. By default it will try to run a daemon. You can change the IPFS connection settings by clicking on the settings icon in the toolbar and restart the application afterwards. If using a custom daemon, you should enable pubsub or some features won’t be available.

  • Browsing sessions with automatic pinning (pins every page you browse)

  • File manager with drag-and-drop support

  • Search content with the ipfs-search search engine

  • Atom feeds (subscribe to feeds on the dweb)

  • ENS (Ethereum Name Service) resolving (access to ENS+IPFS websites)

  • Sharing hashmarks over pubsub

  • Basic built-in media player with IPFS-stored playlists

  • Image viewer

  • QR codes from images

  • Decentralized application development/testing with the Javascript API (using window.ipfs)

Keyboard shortcuts

Please see the shortcuts page (or from the application, click on the Information icon in the toolbar, which will open the documentation).

Screenshots

Browsing the Wikipedia mirror over IPFS

Browsing the Wikipedia mirror over IPFS

QR codes

IPFS QR codes

Contributions and contact

Contributions and ideas are more than welcome! Contact by mail at: galacteek AT protonmail DOT com

If you want to donate to this project please use the Patreon page

Requirements

  • python3 >= 3.6

  • go-ipfs >= 0.4.7

  • PyQt5 >= 5.12.2

  • PyQtWebengine >= 5.12

  • gstreamer (on Linux) for media player support

  • quamash

  • aiohttp

  • aioipfs

License

galacteek is offered under the GNU GPL3 license

Some elements from the ipfs-css repository (CSS files and fonts) are included.

Some icons from the “Oxygen” icons set are included.

Some of the beautiful artwork (under the Creative Commons CC-BY-SA license) from the ipfs-logo project’s repository is included, unchanged.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

galacteek-0.4.7.tar.gz (2.6 MB view details)

Uploaded Source

Built Distribution

galacteek-0.4.7-py3-none-any.whl (3.2 MB view details)

Uploaded Python 3

File details

Details for the file galacteek-0.4.7.tar.gz.

File metadata

  • Download URL: galacteek-0.4.7.tar.gz
  • Upload date:
  • Size: 2.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.8

File hashes

Hashes for galacteek-0.4.7.tar.gz
Algorithm Hash digest
SHA256 aa3752c6b4a329bfa59a7721884904f449e947c3cca24ee81ce69c31a7619c68
MD5 49b42e8d38c9112d3f39e27bf3391faa
BLAKE2b-256 d9843e82e112cf8be1db626e8e24547c1aa0254b0aa46b02c6196ddda5bcc0d6

See more details on using hashes here.

Provenance

File details

Details for the file galacteek-0.4.7-py3-none-any.whl.

File metadata

  • Download URL: galacteek-0.4.7-py3-none-any.whl
  • Upload date:
  • Size: 3.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.8

File hashes

Hashes for galacteek-0.4.7-py3-none-any.whl
Algorithm Hash digest
SHA256 4da3ffbe7fcfa718ecde7e069012fdec7028425e914d10c48787d54b67f0a9a9
MD5 cb02acc2f96df9e6d118303b2fda2c82
BLAKE2b-256 9c49c8866e6fc8ef4e1d6814012f62b849d832d1a3d036f1c0dc08ccc79b2a31

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page