HPI/doc/SETUP.org
2020-04-18 16:25:45 +01:00

7.2 KiB

Please don't be shy and raise issues if something in the instructions is unclear. You'd be really helping me, I want to make the setup as straightforward as possible!

Few notes

I understand people may not super familiar with Python, PIP or generally unix, so here are some short notes:

  • only python3 is supported, and more specifically, python >= 3.5.
  • I'm using pip3 command, but on your system you might only have pip. If your pip --version says python 3, feel free to use pip.
  • similarly, I'm using python3 in the documentation, but if your python --version says python3, it's okay to use python
  • when you are using pip install, always pass --user
  • throughout the guide I'm assuming the config directory is ~/.config, but it's different on Mac/Windows. See this if you're not sure what's your user config dir.

Setting up the main package

This is a required step

You can choose one of the following options:

install from PIP

This is the easiest way:

pip3 install --user HPI

local install

This is convenient if you're planning to add new modules or change the existing ones.

  1. Clone the repository: git clone git@github.com:karlicoss/HPI.git /path/to/hpi
  2. Go into the project directory: cd /path/to/hpi
  3. Run pip3 install --user -e . This will install the package in 'editable mode'. It will basically be a link to /path/to/hpi, which means any changes in the cloned repo will be immediately reflected without need to reinstall anything. It's extremely convenient for developing and debugging.

use without installing

This is less convenient, but gives you more control.

  1. Clone the repository: git clone git@github.com:karlicoss/HPI.git /path/to/hpi
  2. Go into the project directory: cd /path/to/hpi
  3. Install the dependencies: python3 setup.py --dependencies-only
  4. Use with_my script to get access to my. modules.

    For example:

    /path/to/hpi/with_my python3 -c 'from my.pinboard import bookmarks; print(list(bookmarks()))'
    

    It's also convenient to put a symlink to with_my somewhere in your system path so you can run it from anywhere, or add an alias in your bashrc:

    alias with_my='/path/to/hpi/with_my'
    

    After that, you can wrap your command in with_my to give it access to my. modules, e.g. see examples.

The benefit of this way is that you get a bit more control, explicitly allowing your scripts to use your data.

Setting up the modules

This is an optional step as some modules might work without extra setup. But it depends on the specific module.

private configuration (my.config)

If you're not planning to use private configuration (some modules don't need it) you can skip straight to the next step. Still, I'd recommend you to read anyway.

The configuration contains paths to the data on your disks, links to external repositories, etc.

By default, your config is expected in ~/.config/my

  • For example, mine looks like:

    ~/.config/my/my/config/__init__.py
    ~/.config/my/my/config/locations.py
    ~/.config/my/my/config/repos
    ~/.config/my/my/config/repos/endoexport
    ~/.config/my/my/config/repos/fbmessengerexport
    ~/.config/my/my/config/repos/kobuddy
    ~/.config/my/my/config/repos/monzoexport
    ~/.config/my/my/config/repos/pockexport
    ~/.config/my/my/config/repos/rexport
    
  • Another example is in mycfg_template:

    d mycfg_template/
    d mycfg_template/my
    d mycfg_template/my/config
    f mycfg_template/my/config/__init__.py
      ---
      """
      Feel free to remove this if you don't need it/add your own custom settings and use them
      """
    
      class hypothesis:
          # expects outputs from https://github.com/karlicoss/hypexport
          # (it's just the standard Hypothes.is export format)
          export_path = '/path/to/hypothesis/data'
      ---
    d mycfg_template/my/config/repos
    l mycfg_template/my/config/repos/hypexport -> /tmp/my_demo/hypothesis_repo
    

As you can see, generally you specify fixed paths (e.g. to your backups directory) in __init__.py. Feel free to add other files as well though to organize better, it's a real Python package after all!

Some things (e.g. links to external packages like hypexport) are specified as ordinary symlinks in repos directory. That way you get easy imports (e.g. import my.config.repos.hypexport.model) and proper IDE integration.

module dependencies

Dependencies are different for specific modules you're planning to use, so it's hard to specify.

Generally you can just try using the module and then install missing packages via pip3 install --user, should be fairly straightforward.

Usage examples

If you run your script with with_my wrapper, you'd have my in PYTHONPATH which gives you access to your data from within the script.

Polar

Polar doesn't require any setup as it accesses the highlights on your filesystem (should be in ~/.polar).

You can try if it works with:

python3 -c 'import my.reading.polar as polar; print(polar.get_entries())'

Kobo reader

Kobo provider allows you access the books you've read along with the highlights and notes. It uses exports provided by kobuddy package.

  • prepare the config

    1. Point ln -sfT /path/to/kobuddy ~/.config/my/my/config/repos/kobuddy
    2. Add kobo config to ~/.config/my/my/config/__init__.py

      class kobo:
          export_dir = 'path/to/kobo/exports'

After that you should be able to use it:

  python3 -c 'import my.books.kobo as kobo; print(kobo.get_highlights())'

Orger

You can use orger to get Org-mode representations of your data.

Some examples (assuming you've installed Orger):

Orger + Polar

This will convert Polar highlights into org-mode:

orger/modules/polar.py --to polar.org

demo.py

read/run demo.py for a full demonstration of setting up Hypothesis (it uses public annotations data from Github)