Metadata-Version: 2.1
Name: galacteek
Version: 0.3.6
Summary: IPFS browser
Home-page: https://github.com/eversum/galacteek
Author: David Ferlier
Author-email: galacteek@gmx.co.uk
License: GPL3
Keywords: asyncio,aiohttp,ipfs
Platform: UNKNOWN
Classifier: Environment :: X11 Applications :: Qt
Classifier: Framework :: AsyncIO
Classifier: Topic :: Desktop Environment :: File Managers
Classifier: Topic :: Internet :: WWW/HTTP :: Browsers
Classifier: Development Status :: 4 - Beta
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: License :: OSI Approved :: GNU General Public License v3 (GPLv3)
Classifier: Topic :: System :: Filesystems
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Requires-Dist: aiofiles (==0.4.0)
Requires-Dist: aiohttp (==3.4.4)
Requires-Dist: aioipfs (==0.3.8)
Requires-Dist: async-generator (==1.10)
Requires-Dist: base58 (==1.0.2)
Requires-Dist: gitpython (==2.1.11)
Requires-Dist: jinja2 (==2.10)
Requires-Dist: json-traverse (==0.4)
Requires-Dist: jsonschema (==2.6.0)
Requires-Dist: logbook (==1.4.0)
Requires-Dist: multiaddr (==0.0.2)
Requires-Dist: protobuf (==3.6.1)
Requires-Dist: psutil (==5.4.7)
Requires-Dist: py-multibase (==1.0.1)
Requires-Dist: py-multicodec (==0.1.3)
Requires-Dist: pycryptodomex (==3.6.6)
Requires-Dist: pymultihash (==0.8.2)
Requires-Dist: pyqt5 (==5.11.3)
Requires-Dist: quamash (==0.6.1)
Requires-Dist: yarl (==1.2.6)
Provides-Extra: docs
Requires-Dist: sphinx (>=1.7.0) ; extra == 'docs'


=========
Galacteek
=========

.. image:: https://gitlab.com/galacteek/galacteek/raw/master/share/icons/galacteek.png
    :align: center

:info: A multi-platform IPFS_ browser

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

Platforms supported
===================

- Linux
- MacOS X
- FreeBSD

Installation
============

On Linux systems you can either use the AppImage (recommended) or install from PyPI.
On MacOS and other systems you can install from PyPI.

PyPI
----

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

.. code-block:: shell

    pip install galacteek

Upgrade with:

.. code-block:: shell

    pip install -U galacteek

Or building it from source:

.. code-block:: shell

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

Now just run the application with:

.. code-block:: shell

    galacteek

If you don't have go-ipfs_ already installed, the application will ask you
if you want to automatically download and install 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.

AppImage
--------

For Linux users (arch: *x86_64*), you can get an AppImage from the IPFS network
`here <https://ipfs.io/ipfs/QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7>`_
(**~138Mb**, release CID: **QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7**).

Just fetch the image (with wget for example or your favorite tool), and execute
it afterwards::

    wget https://ipfs.io/ipfs/QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7
    chmod u+x QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7
    ./QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7

Or if you already have an IPFS daemon installed and running::

    ipfs get QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7
    chmod u+x QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7
    ./QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7

Running the AppImage with the filename unchanged ensures that the
application will automatically pin itself (it will pin through IPFS the
AppImage that you are using). By doing so you can help redistributing the
software faster to the nodes close to you. Renaming the binary disables the
self-seeding feature::

    mv QmRdNCGFkZ1aZ8ZvihCyHokXr3vG7QF8ut1GnkU2s97oP7 Galacteek-0.3.5.AppImage

**Note**: go-ipfs_ version *0.4.18* is included in the AppImage.
For reference the AppImage is built with
`this script <https://github.com/eversum/galacteek/blob/master/AppImage/galacteek-appimage-build>`_.
You can use the same command-line arguments as with the regular *galacteek*
runner script. If you are filing an issue, please use the *-d* switch and
provide the debug output.

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**

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.

- Browsing sessions with automatic pinning (pins every page you browse)
- Feeds (following IPNS hashes)
- Sharing hashmarks over pubsub
- File manager with drag-and-drop support
- Basic built-in media player with IPFS-stored playlists
- Search content with the ipfs-search_ search engine
- Decentralized application development/testing with the Javascript API
  (using *window.ipfs*)

Keyboard shortcuts
==================

*Mod* is the *Control* key on Linux and the *Command* key on MacOS X.

Main window keyboard shortcuts
------------------------------

- **Mod + t**: Open a new IPFS browsing tab
- **Mod + s**: Search with ipfs-search
- **Mod + w**: Close current tab
- **Mod + m**: Open the IPFS hashmarks manager
- **Mod + f**: Open the file manager
- **Mod + o**: Browse IPFS path from the clipboard
- **Mod + e**: Explore IPFS path from the clipboard
- **Mod + g**: DAG view of IPFS object from the clipboard
- **Mod + p**: Pin IPFS object from the clipboard
- **Mod + i**: Open the IPLD explorer for the IPFS object referenced in the clipboard
- **Mod + u**: Show pinning status

Browser keyboard shortcuts
--------------------------

- **Mod + b**: Bookmark current page
- **Mod + l**: Load an IPFS CID
- **Mod + r** or **F5**: Reload the current page
- **Mod + +**: Zoom in
- **Mod + -**: Zoom out

IPFS views keyboard shortcuts (file manager, hash views, dag viewer)
--------------------------------------------------------------------

- **Mod + c** or **Mod + y**: Copy selected item's hash (CID) to the clipboard
- **Mod + a**: Copy selected item's IPFS path to the clipboard
- **Mod + w**: Close tab/hash view

Screenshots
===========

.. figure:: https://gitlab.com/galacteek/galacteek/raw/master/screenshots/browse-wikipedia-small.png
    :target: https://gitlab.com/galacteek/galacteek/raw/master/screenshots/browse-wikipedia.png
    :align: center
    :alt: Browsing the Wikipedia mirror over IPFS

    Browsing the Wikipedia mirror over IPFS

Requirements
============

- python3 >= 3.5.3 (it is strongly suggested to use python>=3.6)
- go-ipfs_ > 0.4.7
- qt5
- PyQt5 with QtWebEngine support
- 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 of the beautiful artwork (under the Creative Commons CC-BY-SA license)
from the ipfs-logo_ project's repository is included, unchanged.

Main icon made by srip_ (flaticon, CC by 3.0)

.. _aiohttp: https://pypi.python.org/pypi/aiohttp
.. _aioipfs: https://gitlab.com/cipres/aioipfs
.. _aiomonitor: https://github.com/aio-libs/aiomonitor
.. _quamash: https://github.com/harvimt/quamash
.. _go-ipfs: https://github.com/ipfs/go-ipfs
.. _dist.ipfs.io: https://dist.ipfs.io
.. _IPFS: https://ipfs.io
.. _ipfs-logo: https://github.com/ipfs/logo
.. _ipfs-search: https://ipfs-search.com
.. _ipfs-css: https://github.com/ipfs-shipyard/ipfs-css
.. _releases: https://github.com/eversum/galacteek/releases
.. _srip: https://www.flaticon.com/authors/srip


