buku/README.md

409 lines
18 KiB
Markdown
Raw Permalink Normal View History

2016-04-23 02:41:16 +05:30
<h1 align="center">Buku</h1>
2015-11-10 12:45:35 +05:30
2016-04-23 11:16:27 +05:30
<p align="center">
2016-05-24 08:48:02 +05:30
<a href="https://github.com/jarun/Buku/releases/latest"><img src="https://img.shields.io/github/release/jarun/buku.svg" alt="Latest release" /></a>
2016-04-23 11:16:27 +05:30
<a href="https://aur.archlinux.org/packages/buku"><img src="https://img.shields.io/aur/version/buku.svg" alt="AUR" /></a>
<a href="http://braumeister.org/formula/buku"><img src="https://img.shields.io/homebrew/v/buku.svg" alt="Homebrew" /></a>
2016-04-26 14:06:14 +05:30
<a href="https://github.com/jarun/buku/blob/master/LICENSE"><img src="https://img.shields.io/badge/license-GPLv3-yellow.svg?maxAge=2592000" alt="License" /></a>
2016-06-04 06:02:38 +05:30
<a href="https://travis-ci.org/jarun/Buku"><img src="https://travis-ci.org/jarun/Buku.svg?branch=master" alt="Build Status" /></a>
2016-04-23 11:16:27 +05:30
</p>
2016-04-23 02:41:16 +05:30
<p align="center">
2016-09-21 10:33:57 +05:30
<a href="https://asciinema.org/a/2bc3vq5ndxfvg0sm9jp8xlz03"><img src="https://asciinema.org/a/2bc3vq5ndxfvg0sm9jp8xlz03.png" alt="Asciicast" width="734"/></a>
2016-04-23 02:41:16 +05:30
</p>
2015-11-10 12:45:35 +05:30
2016-10-11 10:41:07 +05:30
`buku` is a powerful bookmark management utility written in Python3 and SQLite3. When I started writing it, I couldn't find a flexible cmdline solution with a private, portable, merge-able database along with browser integration. Hence, `buku` (after my son's nickname).
2016-02-28 16:38:04 +05:30
2016-10-12 00:28:08 +05:30
With tagging and multiple options to search bookmarks, including a deep scan mode (particularly for URLs), finding a bookmark is very easy. Multiple search results can be opened in the browser at once.
2016-10-11 10:41:07 +05:30
2016-10-12 00:28:08 +05:30
Though a terminal utility, it's possible to add bookmarks to `buku` without touching the terminal! Refer to the section on [GUI integration](#gui-integration). If you prefer the terminal, thanks to the shell completion scripts, you don't need to memorize any of the options. There's an Easter egg to revisit random forgotten bookmarks too.
2016-02-28 16:38:04 +05:30
2016-09-11 20:54:33 +05:30
<br>
<p align="center">
<a href="https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=RMLTQ76JSXJ4Q"><img src="https://img.shields.io/badge/paypal-donate-orange.svg?maxAge=2592000" alt="Donate" /></a>
&nbsp;
<a href="https://gitter.im/jarun/Buku"><img src="https://img.shields.io/gitter/room/jarun/buku.svg?maxAge=2592000" alt="gitter chat" /></a>
</p>
2016-04-26 13:49:16 +05:30
2016-08-27 20:07:07 +05:30
## Table of Contents
2016-09-05 21:57:11 +05:30
- [Features](#features)
2016-04-20 00:27:58 +05:30
- [Installation](#installation)
- [Dependencies](#dependencies)
- [Installing from this repository](#installing-from-this-repository)
- [Running as a standalone utility](#running-as-a-standalone-utility)
- [Installing with a package manager](#installing-with-a-package-manager)
2016-06-12 23:09:03 +05:30
- [Debian package](#debian-package)
2016-09-11 20:54:33 +05:30
- [Shell completion](#shell-completion)
2016-04-20 00:27:58 +05:30
- [Usage](#usage)
- [Cmdline options](#cmdline-options)
- [Operational notes](#operational-notes)
2016-10-01 21:49:14 +05:30
- [GUI integration](#gui-integration)
- [Add bookmarks to buku](#add-bookmarks-to-buku)
- [Import bookmarks to browser](#import-bookmarks-to-browser)
2016-04-20 00:27:58 +05:30
- [Examples](#examples)
- [Contributions](#contributions)
2016-05-31 21:51:10 +05:30
- [Mentions](#mentions)
2016-09-11 20:54:33 +05:30
- [Copyright](#copyright)
2016-04-20 00:27:58 +05:30
2016-09-05 21:57:11 +05:30
## Features
2016-09-13 13:10:12 +05:30
- Add, open, tag, comment on, search, update, remove URLs
- Portable, merge-able database, to sync between systems
2016-09-05 21:57:11 +05:30
- Import/export bookmarks HTML (Firefox, Google Chrome, IE compatible)
- Fetch page title from web, refresh all titles in a go
2016-09-13 13:10:12 +05:30
- Open (multiple) search results directly in default browser
2016-09-05 21:57:11 +05:30
- Manual password protection using AES256 encryption
- Tab-completion scripts (Bash, Fish, Zsh), man page with examples
- Several options for power users (see help or man page)
- Fast and clean interface, distinct symbols for record fields
- Minimal dependencies
2016-08-27 20:07:07 +05:30
## Installation
2016-08-27 20:07:07 +05:30
### Dependencies
2016-06-12 23:09:03 +05:30
`buku` requires Python 3.3 or later.
2015-11-09 03:34:49 +05:30
2016-09-05 21:57:11 +05:30
To install package dependencies, run:
$ sudo pip3 install cryptography beautifulsoup4
2016-02-28 19:41:27 +05:30
or on Ubuntu:
$ sudo apt-get install python3-cryptography python3-bs4
2016-08-27 20:07:07 +05:30
### Installing from this repository
2016-02-28 19:41:27 +05:30
If you have git installed, run:
2016-08-14 01:01:35 +05:30
$ git clone https://github.com/jarun/Buku/
or download the latest [stable release](https://github.com/jarun/Buku/releases/latest) or [development version](https://github.com/jarun/Buku/archive/master.zip).
2016-02-28 19:41:27 +05:30
Install to default location (`/usr/local`):
2016-02-28 19:41:27 +05:30
2016-04-10 18:11:00 +05:30
$ sudo make install
To remove, run:
2015-11-09 03:34:49 +05:30
2016-02-28 19:41:27 +05:30
$ sudo make uninstall
`PREFIX` is supported. You may need to use `sudo` with `PREFIX` depending on your permissions on destination directory.
2016-08-27 20:07:07 +05:30
### Running as a standalone utility
2016-02-28 19:41:27 +05:30
`buku` is a standalone utility. From the containing directory, run:
$ ./buku
2016-08-27 20:07:07 +05:30
### Installing with a package manager
2016-02-28 19:41:27 +05:30
`buku` is also available on
2016-10-20 08:41:18 +05:30
- [AUR](https://aur.archlinux.org/packages/buku/) for Arch Linux
- Void Linux repos ( `$ sudo xbps-install -S buku` )
- [Homebrew](http://braumeister.org/formula/buku) for OS X
- [Debian Sid](https://packages.debian.org/sid/buku)
- [Ubuntu PPA](https://launchpad.net/~twodopeshaggy/+archive/ubuntu/jarun/)
2016-02-09 11:42:08 +05:30
2016-08-27 20:07:07 +05:30
### Debian package
2016-06-12 23:09:03 +05:30
If you are on a Debian (including Ubuntu) based system visit [the latest stable release](https://github.com/jarun/Buku/releases/latest) and download the `.deb` package. To install, run:
2016-06-12 23:09:03 +05:30
$ sudo dpkg -i buku-$version-all.deb
Please substitute `$version` with the appropriate package version.
2016-09-11 20:54:33 +05:30
## Shell completion
Shell completion scripts for Bash, Fish and Zsh can be found in respective subdirectories of [auto-completion/](https://github.com/jarun/Buku/blob/master/auto-completion). Please refer to your shell's manual for installation instructions.
2016-10-01 21:49:14 +05:30
`buku` has a [rofi frontend](https://github.com/carnager/buku_run) written by Rasmus Steinke.
2016-08-27 20:07:07 +05:30
## Usage
2016-08-27 20:07:07 +05:30
### Cmdline options
2016-06-08 22:27:50 +05:30
usage: buku [OPTIONS] [KEYWORD [KEYWORD ...]]
2016-06-22 20:17:33 +05:30
A powerful command-line bookmark manager. Your mini web!
2016-02-28 19:41:27 +05:30
2016-04-29 23:39:39 +05:30
general options:
-a, --add URL [tags ...]
2016-05-19 08:54:46 +05:30
bookmark URL with comma-separated tags
-u, --update [...] update fields of bookmark at DB indices
2016-10-11 13:09:58 +05:30
accepts indices and ranges
2016-04-29 23:39:39 +05:30
refresh all titles, if no arguments
refresh titles of bookmarks at indices,
if no edit options are specified
2016-06-17 02:38:38 +05:30
-d, --delete [...] delete bookmarks. Valid inputs: either
a hyphenated single range (100-200),
OR space-separated indices (100 15 200)
2016-07-10 21:15:43 +05:30
delete search results with search options
2016-05-20 23:56:01 +05:30
delete all bookmarks, if no arguments
-h, --help show this information and exit
edit options:
--url keyword specify url, works with -u only
2016-07-11 22:48:40 +05:30
--tag [+|-] [...] set comma-separated tags, works with -a, -u
clear tags, if no arguments
append specified tags, if preceded by '+'
remove specified tags, if preceded by '-'
2016-04-29 23:39:39 +05:30
-t, --title [...] manually set title, works with -a, -u
2016-05-20 23:56:01 +05:30
if no arguments:
-a: do not set title, -u: clear title
2016-05-18 01:41:31 +05:30
-c, --comment [...] description of the bookmark, works with
-a, -u; clears comment, if no arguments
2016-04-29 23:39:39 +05:30
search options:
-s, --sany keyword [...]
search bookmarks for ANY matching keyword
-S, --sall keyword [...]
search bookmarks with ALL keywords
2016-05-18 22:53:08 +05:30
special keyword -
2016-04-29 23:39:39 +05:30
"blank": list entries with empty title/tag
--deep match substrings ('pen' matches 'opened')
2016-05-18 22:53:08 +05:30
--st, --stag [...] search bookmarks by tag
2016-06-08 22:27:50 +05:30
list tags alphabetically, if no arguments
2016-04-29 23:39:39 +05:30
encryption options:
-l, --lock [N] encrypt DB file with N (> 0, default 8)
hash iterations to generate key
-k, --unlock [N] decrypt DB file with N (> 0, default 8)
hash iterations to generate key
power toys:
-e, --export file export bookmarks to Firefox format html
2016-09-20 23:32:04 +05:30
use --tag to export only specific tags
-i, --import file import bookmarks from html file; Firefox,
Google Chrome and IE formats supported
-m, --merge file merge bookmarks from another buku database
-p, --print [...] show details of bookmark by DB index
accepts indices and ranges
2016-04-29 23:39:39 +05:30
show all bookmarks, if no arguments
2016-10-11 11:38:03 +05:30
-f, --format N modify -p output. N=1: show only URL,
N=2: show URL and tag, N=3: show only title
2016-04-29 23:39:39 +05:30
-r, --replace oldtag [newtag ...]
replace oldtag with newtag everywhere
2016-04-29 23:39:39 +05:30
delete oldtag, if no newtag
-j, --json Json formatted output for -p, -s, -S, --st
--noprompt do not show the prompt, run and exit
2016-10-01 20:59:53 +05:30
-o, --open [N] open bookmark at DB index N in web browser
open a random index if N is omitted
2016-04-29 23:39:39 +05:30
-z, --debug show debug information and additional logs
prompt keys:
1-N open the Nth search result in web browser
2016-09-05 13:48:21 +05:30
ranges, space-separated result indices work
2016-05-24 21:39:59 +05:30
double Enter exit buku
2016-02-28 16:38:04 +05:30
2016-07-03 15:36:50 +05:30
symbols:
> title
+ comment
# tags
2016-08-27 20:07:07 +05:30
### Operational notes
2016-04-24 20:07:51 +05:30
- The SQLite3 database file is stored in:
- **$XDG_DATA_HOME/buku/bookmarks.db**, if XDG_DATA_HOME is defined (first preference) or
- **$HOME/.local/share/buku/bookmarks.db**, if HOME is defined (second preference) or
2016-05-01 10:07:16 +05:30
- the **current directory**.
- It's advisable to copy URLs directly from the browser address bar, i.e., along with the leading `http://` or `https://` token. buku looks up title data (found within <title></title> tags of HTML) from the web ONLY for fully-formed HTTP(S) URLs.
2016-06-28 23:21:19 +05:30
- If the URL contains characters like `;`, `&` or brackets they may be interpreted specially by the shell. To avoid it, add the URL within single or double quotes (`'`/`"`).
2016-10-11 13:09:58 +05:30
- URLs are unique in DB. The same URL cannot be added twice.
- **Tags**:
2016-10-11 13:09:58 +05:30
- Comma (`,`) is the tag delimiter in DB. A tag cannot have comma(s) in it. Tags are filtered (for unique tags) and sorted. Tags can be replaced.
- **Update** operation:
- If --title, --tag or --comment is passed without argument, clear the corresponding field from DB.
- If --url is passed (and --title is omitted), update the title from web using the URL.
- If indices are passed without any other options (--url, --title, --tag and --comment), read the URLs from DB and update titles from web.
2016-06-17 02:38:38 +05:30
- **Delete** operation:
- When a record is deleted, the last record is moved to the index.
2016-06-17 10:54:55 +05:30
- Delete doesn't work with range and indices provided together as arguments. It's an intentional decision to avoid extra sorting, in-range checks and to keep the auto-DB compaction functionality intact. On the same lines, indices are deleted in descending order.
2016-07-10 21:15:43 +05:30
- Can delete bookmarks matching a search, when combined with any of the search options.
- **Search** works in mysterious ways:
2016-04-20 00:38:39 +05:30
- Case-insensitive.
- Matches exact words in URL, title and tags.
- -s : match any of the keywords in URL, title or tags.
- -S : match all the keywords in URL, title or tags.
- --deep : match **substrings** (`match` matches `rematched`) in URL, title and tags.
- --st : search bookmarks by tag, or show all tags alphabetically.
2016-06-06 22:56:12 +05:30
- Search results are indexed serially. This index is different from actual database index of a bookmark record which is shown in bold within `[]` after the URL.
2016-10-11 13:09:58 +05:30
- **Encryption** is optional and manual. AES256 algorithm is used. To use encryption, the database file should be unlocked (-k) before using buku and locked (-l) afterwards. Between these 2 operations, the database file lies unencrypted on the disk, and NOT in memory. Also, note that the database file is *unencrypted on creation*.
2016-02-28 16:38:04 +05:30
2016-10-01 21:49:14 +05:30
## GUI integration
![buku](http://i.imgur.com/8Y6PTPw.png)
`buku` can integrate in a GUI environment with simple tweaks.
### Add bookmarks to buku
2016-10-03 10:20:30 +05:30
With support for piped input, it's possible to add bookmarks to `buku` using keyboard shortcuts on Linux and OS X. CLIPBOARD (plus PRIMARY on Linux) text selections can be added directly this way. The additional utility required is `xsel` (on Linux) or `pbpaste` (on OS X).
2016-10-01 21:49:14 +05:30
2016-10-03 10:20:30 +05:30
The following steps explore the procedure on Linux with Ubuntu as the reference platform.
2016-10-01 21:49:14 +05:30
1. To install `xsel` on Ubuntu, run:
$ sudo apt install xsel
2. Create a new script `bukuadd` with the following content:
#!/bin/bash
xsel | buku -a
`-a` is the option to add a bookmark.
3. Make the script executable:
$ chmod +x bukuadd
4. Copy it somewhere in your `PATH`.
5. Add a new keyboard shortcut to run the script. I use `<Alt-b>`.
#### Test drive
2016-10-03 10:20:30 +05:30
Select a URL anywhere or copy a link and press the keyboard shortcut to add it to the `buku` database. The addition might take a few seconds to reflect depending on your internet speed and the time `buku` needs to fetch the title from the URL. To avoid title fetch from the web, add the `-t` option to the script.
2016-10-01 21:49:14 +05:30
To verify that the bookmark has indeed been added, run:
$ buku -p | tail -3
and check the entry.
#### Tips
- To add the last visited URL in Firefox to `buku`, use the following script:
#!/bin/bash
sqlite3 $HOME/.mozilla/firefox/*.default/places.sqlite "select url from moz_places where last_visit_date=(select max(last_visit_date) from moz_places)" | buku -a
- If you want to tag these bookmarks, look them up later using:
$ buku -S blank
Use option `-u` to tag these bookmarks.
### Import bookmarks to browser
2016-10-03 10:20:30 +05:30
`buku` can export (or import) bookmarks in HTML format recognized by Firefox, Google Chrome and Internet Explorer.
2016-10-01 21:49:14 +05:30
To export all bookmarks, run:
$ buku --export path_to_bookmarks.html
To export specific tags, run:
$ buku --export path_to_bookmarks.html --tag tag 1, tag 2
Once exported, import the html file in your browser.
2016-08-27 20:07:07 +05:30
## Examples
2016-05-18 01:41:31 +05:30
1. **Add** a bookmark with **tags** `linux news` and `open source`, **comment** `Informative website on Linux and open source`, **fetch page title** from the web:
2016-04-21 20:59:32 +05:30
2016-05-20 23:56:01 +05:30
$ buku -a https://tuxdiary.com linux news, open source -c Informative website on Linux and open source
Title: [TuxDiary Linux, open source, command-line, leisure.]
Added at index 336
336. https://tuxdiary.com
> TuxDiary Linux, open source, command-line, leisure.
+ Informative website on Linux and open source
# linux news,open source
where, >: title, +: comment, #: tags
2. **Add** a bookmark with tags `linux news` and `open source` & **custom title** `Linux magazine`:
2016-02-28 20:02:10 +05:30
$ buku -a http://tuxdiary.com linux news, open source -t 'Linux magazine'
2016-02-28 20:02:10 +05:30
Added at index 15012014
Note that URL must precede tags.
3. **Add** a bookmark **without a title** (works for update too):
2016-02-28 20:02:10 +05:30
$ buku -a http://tuxdiary.com linux news, open source -t
2016-05-20 23:56:01 +05:30
4. **Update** existing bookmark at index 15012014 with new URL, tags and comments, fetch title from the web:
$ buku -u 15012014 --url http://tuxdiary.com/ --tag linux news, open source, magazine -c site for Linux utilities
2016-05-21 00:16:44 +05:30
5. **Fetch and update only title** for bookmark at 15012014:
2016-05-20 23:56:01 +05:30
$ buku -u 15012014
2016-05-21 00:16:44 +05:30
6. **Update only comment** for bookmark at 15012014:
2016-05-20 23:56:01 +05:30
$ buku -u 15012014 -c this is a new comment
Applies to --url, --title and --tag too.
2016-09-20 23:32:04 +05:30
7. **Export** bookmarks tagged `tag 1` or `tag 2`:
$ buku -e bookmarks.html tag 1, tag 2
All bookmarks are exported if --tag is not specified.
8. **Import** bookmarks:
$ buku -i bookmarks.html
HTML exports from Firefox, Google Chrome and IE are supported.
2016-09-20 23:32:04 +05:30
9. **Delete only comment** for bookmark at 15012014:
2016-02-28 20:02:10 +05:30
2016-05-20 23:56:01 +05:30
$ buku -u 15012014 -c
Applies to --title and --tag too. URL cannot be deleted without deleting the bookmark.
2016-09-20 23:32:04 +05:30
10. **Update** or refresh **full DB** with page titles from the web:
2016-02-28 20:02:10 +05:30
$ buku -u
2016-05-20 23:56:01 +05:30
This operation does not modify the indexes, URLs, tags or comments. Only title is refreshed if fetched title is non-empty.
2016-09-20 23:32:04 +05:30
11. **Delete** bookmark at index 15012014:
2016-02-28 20:02:10 +05:30
$ buku -d 15012014
2016-03-20 11:23:59 +05:30
Index 15012020 moved to 15012014
The last index is moved to the deleted index to keep the DB compact.
2016-09-20 23:32:04 +05:30
12. **Delete all** bookmarks:
2016-02-28 20:02:10 +05:30
$ buku -d
2016-09-20 23:32:04 +05:30
13. **Delete** a **range or list** of bookmarks:
2016-06-17 02:38:38 +05:30
$ buku -d 100-200 // delete bookmarks from index 100 to 200
$ buku 100 15 200 // delete bookmarks at indices 100, 15 and 200
2016-09-20 23:32:04 +05:30
14. **Search** bookmarks for **ANY** of the keywords `kernel` and `debugging` in URL, title or tags:
2016-02-28 20:02:10 +05:30
$ buku -s kernel debugging
2016-09-20 23:32:04 +05:30
15. **Search** bookmarks with **ALL** the keywords `kernel` and `debugging` in URL, title or tags:
2016-02-28 20:02:10 +05:30
$ buku -S kernel debugging
2016-09-20 23:32:04 +05:30
16. **Search** bookmarks **tagged** `general kernel concepts`:
2016-04-19 23:00:06 +05:30
2016-05-18 21:36:54 +05:30
$ buku --st general kernel concepts
2016-09-20 23:32:04 +05:30
17. List **all unique tags** alphabetically:
2016-05-01 14:13:26 +05:30
2016-05-18 22:53:08 +05:30
$ buku --st
2016-09-20 23:32:04 +05:30
18. **Encrypt or decrypt** DB with **custom number of iterations** (15) to generate key:
2016-02-28 20:02:10 +05:30
$ buku -l 15
$ buku -k 15
2016-09-05 21:21:06 +05:30
The same number of iterations must be specified for one lock & unlock instance. Default is 8, if omitted.
19. **Show details** of bookmark at index 15012014 and ranges 20-30, 40-50:
2016-05-01 14:13:26 +05:30
$ buku -p 20-30 15012014 40-50
2016-09-20 23:32:04 +05:30
20. **Show all** bookmarks with real index from database:
2016-05-01 14:13:26 +05:30
$ buku -p
2016-05-03 23:22:36 +05:30
$ buku -p | more
2016-09-20 23:32:04 +05:30
21. **Replace tag** 'old tag' with 'new tag':
2016-05-01 14:13:26 +05:30
$ buku -r 'old tag' new tag
2016-09-20 23:32:04 +05:30
22. **Delete tag** 'old tag' from DB:
2016-05-01 14:13:26 +05:30
$ buku -r 'old tag'
2016-09-20 23:32:04 +05:30
23. **Append (or delete) tags** 'tag 1', 'tag 2' to (or from) existing tags of bookmark at index 15012014:
2016-06-12 16:18:10 +05:30
$ buku -u 15012014 --tag + tag 1, tag 2
2016-07-11 22:48:40 +05:30
$ buku -u 15012014 --tag - tag 1, tag 2
2016-09-20 23:32:04 +05:30
24. **Open URL** at index 15012014 in browser:
2016-05-01 14:13:26 +05:30
$ buku -o 15012014
2016-09-20 23:32:04 +05:30
25. To list bookmarks with no title or tags for **bookkeeping**:
2016-03-29 18:13:43 +05:30
2016-05-01 19:14:17 +05:30
$ buku -S blank
2016-09-20 23:32:04 +05:30
26. More **help**:
2016-02-28 20:02:10 +05:30
$ buku
$ man buku
2015-11-09 03:34:49 +05:30
2016-08-27 20:07:07 +05:30
## Contributions
2016-09-11 20:54:33 +05:30
Pull requests are welcome. Please visit [#39](https://github.com/jarun/Buku/issues/39) for a list of TODOs.
2015-11-10 12:04:37 +05:30
2016-08-27 20:07:07 +05:30
## Mentions
2016-05-31 21:51:10 +05:30
- [One Thing Well](http://onethingwell.org/post/144952807044/buku)
2016-10-03 10:20:30 +05:30
- [It's F.O.S.S.](https://itsfoss.com/buku-command-line-bookmark-manager-linux/)
2016-05-31 21:51:10 +05:30
2016-09-11 20:54:33 +05:30
## Copyright
2016-09-11 20:54:33 +05:30
Copyright (C) 2015-2016 [Arun Prakash Jana](mailto:engineerarun@gmail.com)