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-04-23 11:16:27 +05:30
< / p >
2016-04-23 02:41:16 +05:30
< p align = "center" >
2016-04-23 20:22:43 +05:30
< a href = "https://asciinema.org/a/6x3nu7ez9t0flk1knhiabwduv" > < img src = "https://asciinema.org/a/6x3nu7ez9t0flk1knhiabwduv.png" alt = "Asciicast" width = "600" / > < / a >
2016-04-23 02:41:16 +05:30
< / p >
2015-11-10 12:45:35 +05:30
2016-04-21 10:29:57 +05:30
`buku` is a powerful cmdline bookmark management utility written in Python3 and SQLite3. When I started writing it, I couldn't find a flexible cmdline solution with a portable database. Hence, `Buku` (after my son's nickname).
2016-02-28 16:38:04 +05:30
2016-05-24 11:51:43 +05:30
`buku` can handle piped input, which lets you combine it with `xsel` (on Linux) and add bookmarks from anywhere without touching the terminal.
2016-05-23 14:32:46 +05:30
2016-03-26 22:51:40 +05:30
Ref: [buku & xsel: add selected or copied URL as bookmark ](http://tuxdiary.com/2016/03/26/buku-xsel/ )
2016-02-28 16:38:04 +05:30
2016-04-17 15:37:22 +05:30
Find `buku` useful? If you would like to donate, visit the
2016-04-26 14:06:14 +05:30
[![Donate Button ](https://img.shields.io/badge/paypal-donate-orange.svg?maxAge=2592000 )](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick& hosted_button_id=RMLTQ76JSXJ4Q) page.
2016-02-28 16:38:04 +05:30
2016-05-02 22:52:26 +05:30
Copyright (C) 2015-2016 [Arun Prakash Jana ](mailto:engineerarun@gmail.com ).
2016-04-26 13:49:16 +05:30
2015-11-09 03:34:49 +05:30
# Features
2016-05-23 14:32:46 +05:30
2016-05-23 05:06:41 +05:30
- Add, tag, comment on, search, update, remove bookmarks
- Fetch page title from the web (default) or add manually
- Import HTML bookmark exports from Firefox, Google Chrome or IE
- Open search results directly in browser
2016-05-17 13:49:50 +05:30
- Manual password protection using AES256 encryption
- Modify or delete tags, list all unique tags alphabetically
2016-05-23 05:06:41 +05:30
- Refresh all bookmarks online in one shot
2016-05-15 13:04:56 +05:30
- Tab-completion scripts for Bash, Fish and Zsh
2016-05-18 08:18:27 +05:30
- Man page with examples
- Several options for power users (see help or man page)
2016-05-17 14:04:04 +05:30
- Fast and clean interface
2015-11-09 03:34:49 +05:30
- Minimal dependencies
2016-04-20 00:27:58 +05:30
# Table of Contents
2016-05-23 14:32:46 +05:30
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 )
2016-05-15 13:04:56 +05:30
- [Shell completion ](#shell-completion )
2016-04-20 00:27:58 +05:30
- [Installing with a package manager ](#installing-with-a-package-manager )
- [Usage ](#usage )
- [Cmdline options ](#cmdline-options )
- [Operational notes ](#operational-notes )
- [Examples ](#examples )
- [Contributions ](#contributions )
- [Developers ](#developers )
2015-11-09 03:34:49 +05:30
# Installation
2016-05-23 14:32:46 +05:30
2016-02-28 19:41:27 +05:30
## Dependencies
2016-05-23 14:32:46 +05:30
2015-12-20 01:43:46 +05:30
`buku` requires Python 3.x to work.
2015-11-09 03:34:49 +05:30
2016-02-28 19:41:27 +05:30
For optional encryption support, install PyCrypto module. Run:
$ sudo pip3 install pycrypto
or on Ubuntu:
$ sudo apt-get install python3-crypto
2016-05-23 14:32:46 +05:30
2016-03-24 14:16:07 +05:30
## Installing from this repository
2016-05-23 14:32:46 +05:30
2016-02-28 19:41:27 +05:30
If you have git installed, run:
$ 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-05-23 14:32:46 +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
2016-05-23 14:32:46 +05:30
`PREFIX` is supported. You may need to use `sudo` with `PREFIX` depending on your permissions on destination directory.
2015-12-19 23:45:22 +05:30
2016-02-28 19:41:27 +05:30
## Running as a standalone utility
2016-05-23 14:32:46 +05:30
2016-02-28 19:41:27 +05:30
`buku` is a standalone utility. From the containing directory, run:
$ ./buku
2016-05-23 14:32:46 +05:30
2016-05-15 13:04:56 +05:30
## Shell completion
2016-05-23 14:32:46 +05:30
2016-05-24 18:28:33 +05:30
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 ).
Install shell completion scripts:
$ sudo make install.comp
Remove shell completion scripts:
$ sudo make uninstall.comp
`PREFIX` is supported.
2016-05-23 14:32:46 +05:30
2016-02-28 19:41:27 +05:30
## Installing with a package manager
2016-05-23 14:32:46 +05:30
2016-02-28 19:41:27 +05:30
`buku` is also available on
2016-04-22 10:47:00 +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, or its Linux fork, [Linuxbrew ](https://github.com/Linuxbrew/linuxbrew/blob/master/Library/Formula/buku.rb )
2016-02-09 11:42:08 +05:30
2015-11-09 03:59:17 +05:30
# Usage
2016-05-23 14:32:46 +05:30
2016-03-26 00:17:51 +05:30
## Cmdline options
2016-05-23 14:32:46 +05:30
2016-05-18 08:18:27 +05:30
**NOTE:** If you are using `buku` v1.9 or below please refer to the installed man page or program help.
2016-04-29 23:39:39 +05:30
2016-05-23 05:06:41 +05:30
usage: buku [-a URL [tags ...]] [-u [N]] [-i path] [-d [N]]
2016-05-20 23:56:01 +05:30
[--url keyword] [--tag [...]] [-t [...]] [-c [...]]
2016-05-18 22:53:08 +05:30
[-s keyword [...]] [-S keyword [...]] [--st [...]]
2016-04-29 23:39:39 +05:30
[-k [N]] [-l [N]] [-p [N]] [-f N]
2016-05-20 23:56:01 +05:30
[-r oldtag [newtag ...]] [-j] [-o N] [-z] [-h]
2016-03-21 01:23:57 +05:30
2016-05-12 14:30:02 +05:30
A private 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
2016-05-20 23:56:01 +05:30
-u, --update [N] update fields of bookmark at DB index N
2016-04-29 23:39:39 +05:30
refresh all titles, if no arguments
2016-05-20 23:56:01 +05:30
refresh title of bookmark at N, if only
2016-05-21 22:59:41 +05:30
N is specified without any edit options
2016-05-20 23:56:01 +05:30
-d, --delete [N] delete bookmark at DB index N
delete all bookmarks, if no arguments
2016-05-23 05:06:41 +05:30
-i, --import path import bookmarks from html file; Firefox,
Google Chrome and IE formats supported
2016-05-21 22:59:41 +05:30
-h, --help show this information
edit options:
2016-05-21 18:45:56 +05:30
--url keyword specify url, works with -u only
2016-05-21 12:43:34 +05:30
--tag [...] set comma-separated tags, works with -a, -u
2016-05-23 12:11:42 +05:30
clears tags, if no arguments
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
2016-05-18 22:53:08 +05:30
--st, --stag [...] search bookmarks by tag
list all 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:
-p, --print [N] show details of bookmark at DB index N
show all bookmarks, if no arguments
-f, --format N modify -p output
N=1: show only URL, N=2: show URL and tag
-r, --replace oldtag [newtag ...]
2016-05-23 12:11:42 +05:30
replace oldtag with newtag everywhere
2016-04-29 23:39:39 +05:30
delete oldtag, if no newtag
2016-05-23 12:11:42 +05:30
-j, --json Json formatted output for -p, -s, -S, --st
2016-05-15 11:33:02 +05:30
-o, --open N open bookmark at DB index N in web browser
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-05-24 21:39:59 +05:30
double Enter exit buku
2016-02-28 16:38:04 +05:30
2016-02-28 19:41:27 +05:30
## Operational notes
2016-05-23 14:32:46 +05:30
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** .
2016-05-23 14:32:46 +05:30
- Before version 1.9, buku stored its database in $HOME/.cache/buku/bookmarks.db. If the file exists, buku automatically moves it to new location.
- 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-04-27 22:37: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-05-01 10:03:21 +05:30
- URLs are unique in DB. The same URL cannot be added twice. You can update tags and re-fetch title data.
2016-05-23 14:32:46 +05:30
- **Update** operation:
2016-05-23 12:03:57 +05:30
- 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 index number is passed without any other options (--url, --title, --tag and --comment), read the URL from DB and update title from web.
2016-05-23 14:32:46 +05:30
- **Search** works in mysterious ways:
2016-04-20 00:38:39 +05:30
- Case-insensitive.
2016-04-20 00:02:28 +05:30
- Substrings match (`match` matches `rematched` ) for URL, title and tags.
2016-05-23 12:03:57 +05:30
- -s : match any of the keywords in URL, title or tags.
- -S : match all the keywords in URL, title or tags.
- --st : search bookmarks by tag, or show all tags alphabetically.
2016-05-18 08:18:27 +05:30
- You can search bookmarks by tag (see [examples ](#examples )).
2016-05-01 10:03:21 +05:30
- Search results are indexed serially. This index is different from actual database index of a bookmark record which is shown within `[]` after the URL.
2016-05-17 13:49:50 +05:30
- Auto DB compaction: when a record is deleted, the last record is moved to the index.
2016-05-23 14:32:46 +05:30
- **Encryption** is optional and manual. AES256 algorithm is used. If you choose 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
2015-11-09 04:02:12 +05:30
# Examples
2016-05-23 14:32:46 +05:30
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
2016-05-01 10:03:21 +05:30
2. **Add** a bookmark with tags `linux news` and `open source` & **custom title** `Linux magazine` :
2016-02-28 20:02:10 +05:30
2016-05-01 10:03:21 +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
2016-05-01 10:03:21 +05:30
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
2016-05-01 10:03:21 +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-05-23 05:06:41 +05:30
7. Import bookmarks:
$ buku -i bookmarks.html
HTML exports from Firefox, Google Chrome and IE are supported.
8. **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-05-23 05:06:41 +05:30
9. **Update** or refresh **full DB** with page titles from the web:
2016-02-28 20:02:10 +05:30
2016-05-01 10:03:21 +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-05-23 05:06:41 +05:30
10. **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-05-23 05:06:41 +05:30
11. **Delete all** bookmarks:
2016-02-28 20:02:10 +05:30
2016-05-01 10:03:21 +05:30
$ buku -d
2016-05-23 05:06:41 +05:30
12. **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-05-23 05:06:41 +05:30
13. **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-05-23 05:06:41 +05:30
14. **Search** bookmarks with **tag** `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-05-01 10:03:21 +05:30
Note the commas (,) before and after the tag. Comma is the tag delimiter in DB.
2016-05-23 05:06:41 +05:30
15. List **all unique tags** alphabetically:
2016-05-01 14:13:26 +05:30
2016-05-18 22:53:08 +05:30
$ buku --st
2016-05-23 05:06:41 +05:30
16. **Encrypt or decrypt** DB with **custom number of iterations** (15) to generate key:
2016-02-28 20:02:10 +05:30
2016-05-01 10:03:21 +05:30
$ buku -l 15
$ buku -k 15
2016-05-01 14:25:32 +05:30
The same number of iterations must be used for one lock & unlock instance. Default is 8.
2016-05-23 05:06:41 +05:30
17. **Show details** of bookmark at index 15012014:
2016-05-01 14:13:26 +05:30
$ buku -p 15012014
2016-05-23 05:06:41 +05:30
18. **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-05-23 05:06:41 +05:30
19. **Replace tag** 'old tag' with 'new tag':
2016-05-01 14:13:26 +05:30
$ buku -r 'old tag' new tag
2016-05-23 05:06:41 +05:30
20. **Delete tag** 'old tag' from DB:
2016-05-01 14:13:26 +05:30
$ buku -r 'old tag'
2016-05-23 05:06:41 +05:30
21. **Open URL** at index 15012014 in browser:
2016-05-01 14:13:26 +05:30
$ buku -o 15012014
2016-05-23 11:51:29 +05:30
22. 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-05-23 11:51:29 +05:30
23. More **help** :
2016-02-28 20:02:10 +05:30
2016-05-23 11:51:29 +05:30
$ buku
$ man buku
2015-11-09 03:34:49 +05:30
2015-11-10 12:04:37 +05:30
# Contributions
2016-05-23 14:32:46 +05:30
2016-05-02 20:46:33 +05:30
Pull requests are welcome. Please visit [#14 ](https://github.com/jarun/Buku/issues/14 ) for a list of TODOs.
2015-11-10 12:04:37 +05:30
2016-02-28 16:38:04 +05:30
# Developers
2016-05-23 14:32:46 +05:30
2016-02-01 20:16:26 +05:30
[Arun Prakash Jana ](mailto:engineerarun@gmail.com )
2016-02-28 16:38:04 +05:30
Special thanks to the community for valuable suggestions and ideas.