2016-03-19 22:51:21 +05:30
.TH "BUKU" "1" "Mar 2016" "Version 1.8" "User Commands"
2015-11-09 01:01:07 +05:30
.SH NAME
2016-03-25 22:09:45 +05:30
buku \- A private cmdline bookmark manager. Your mini web!
2015-11-09 01:01:07 +05:30
.SH SYNOPSIS
2015-12-20 01:43:46 +05:30
.B buku
2016-03-03 23:48:04 +05:30
.I OPTIONS
.RI [ URL ]
.RI [ TAGS ]
2016-03-21 01:23:57 +05:30
.I [KEYWORDS ...]
2015-11-09 01:01:07 +05:30
.SH DESCRIPTION
2015-12-20 01:43:46 +05:30
.B buku
2016-03-21 00:44:13 +05:30
is a command-line tool to save, tag and search bookmarks.
2015-11-09 02:46:01 +05:30
.PP
2016-03-21 00:44:13 +05:30
The SQLite3 database file is stored in \fB $HOME/.cache/bookmarks.db\fR for each user.
2015-11-10 13:28:37 +05:30
.SH OPERATIONAL NOTES
2016-03-03 23:48:04 +05:30
URL must precede the tags. Manual title with multiple keywords must be within quotes.
.PP
2015-12-20 01:43:46 +05:30
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.
2015-11-09 02:46:01 +05:30
.PP
2015-11-10 13:28:37 +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 '"' qoutes.
2015-11-09 02:46:01 +05:30
.PP
2016-03-25 19:42:49 +05:30
The same URL cannot be added twice. You can update tags and re-fetch title data. You can also insert a new bookmark at a free index.
2015-11-09 02:46:01 +05:30
.PP
2015-11-10 13:28:37 +05:30
You can either add or update or delete record(s) in one instance. A combination of these operations is not supported in a single run.
.PP
Search works in mysterious ways:
2015-11-11 17:53:03 +05:30
- Substrings match ('match' matches 'rematched') for URL, tags and title.
- All the keywords are treated together as a 'single' tag in the 'same order'. Bookmarks with partial or complete tag matches are shown in results.
2016-03-25 14:59:19 +05:30
- -s : match any of the keywords in URL or title. Order is irrelevant.
- -S : match all the keywords in URL or title. Order is irrelevant.
2016-03-25 19:45:28 +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.
2015-12-19 23:45:22 +05:30
.PP
2016-03-25 14:59:19 +05:30
AES256 is used for encryption. Optionally specify (-t) the number of hash iterations to use to generate key. Default is 8 iterations.
2016-03-20 13:01:34 +05:30
.PP
2016-03-25 14:59:19 +05:30
Encryption is optional and manual. 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 unecrypted on creation.
2015-11-09 01:01:07 +05:30
.SH OPTIONS
.TP
2016-03-25 14:59:19 +05:30
.BI \- a " URL" " " "[tags]"
2015-11-09 02:46:01 +05:30
Bookmark
.I URL
2015-11-09 05:21:25 +05:30
along with comma separated tags. A tag can have multiple words. The same URL cannot be added twice.
2015-11-09 01:01:07 +05:30
.TP
2015-11-09 02:46:01 +05:30
.BI \- d " N"
Delete bookmark at index
2015-11-09 01:01:07 +05:30
.I N
2016-03-25 14:59:19 +05:30
in DB (from -P output).
2015-11-09 01:01:07 +05:30
.TP
2015-11-09 02:46:01 +05:30
.B \- D
Delete ALL bookmarks.
2015-11-09 01:01:07 +05:30
.TP
2016-03-25 13:22:52 +05:30
.B \- e
Show all bookmarks with empty titles or no tags (for bookkeeping).
.TP
2016-03-16 23:33:15 +05:30
.B \- g
2016-03-26 00:08:14 +05:30
List all unique tags sorted aplhabetically.
2016-03-16 23:33:15 +05:30
.TP
2015-11-09 02:46:01 +05:30
.BI \- i " N"
2016-03-25 19:42:49 +05:30
Add a new record at free index
2015-11-09 02:46:01 +05:30
.I N
2016-03-25 19:42:49 +05:30
in DB.
2015-11-10 16:50:30 +05:30
.TP
2015-12-19 23:45:22 +05:30
.B \- k
Decrypt (unlock) the DB file.
.TP
.B \- l
Encrypt (lock) the DB file.
.TP
2016-03-25 23:53:26 +05:30
.BI \- m " title"
Manually specify the title, works with -a, -i, -u.
2016-03-03 23:48:04 +05:30
.TP
2015-11-10 16:50:30 +05:30
.BI \- o " N"
Open URL at DB index
.I N
in browser.
2015-11-09 01:01:07 +05:30
.TP
2015-11-10 00:02:10 +05:30
.BI \- p " N"
2015-11-10 16:50:30 +05:30
Show details of bookmark record stored at index
.I N
in DB.
2015-11-10 00:02:10 +05:30
.TP
.B \- P
2015-11-11 17:53:03 +05:30
Show all bookmark records from the DB along with actual index. Shows URL, title and tags.
2015-11-09 01:01:07 +05:30
.TP
2015-11-13 16:42:12 +05:30
.B \- R
2016-03-25 23:53:26 +05:30
Refresh titles for all bookmarks from the web. Titles are updated only if non-empty. Indexes, URLs and tags are retained.
2015-11-13 16:42:12 +05:30
.TP
2015-11-09 02:46:01 +05:30
.BI \- s " keywords"
2015-11-11 17:53:03 +05:30
Search bookmarks for a (partial) tag or any keyword and show the results. Prompts to enter result number to open in browser. Note that the sequential index number may not match the real index in database. DB index is shown in the end within '()'.
2015-11-11 17:34:57 +05:30
.TP
.BI \- S " keywords"
2016-03-25 14:59:19 +05:30
Search bookmarks for a (partial) tag or occurrence of all keywords in URL or title and show the results. Rest same as -s.
2015-11-09 01:01:07 +05:30
.TP
2015-12-23 00:03:22 +05:30
.BI \- t " N"
Use
.I N
2016-03-25 14:59:19 +05:30
(> 0) hash iterations to generate key, works with -k, -l.
2015-12-23 00:03:22 +05:30
.TP
2016-03-25 14:59:19 +05:30
.BI \- u " N" " " "URL" " " "[tags]"
2016-03-20 07:11:40 +05:30
Update all fields of bookmark at index
2015-11-09 02:46:01 +05:30
.I N
2015-11-10 16:50:30 +05:30
in DB.
2015-11-09 01:01:07 +05:30
.TP
2015-11-10 14:01:35 +05:30
.BI \- w
2016-03-25 14:59:19 +05:30
Fetch title data from the web. Works with -a, -i or -u options.
2015-11-10 14:01:35 +05:30
.TP
2015-11-10 23:28:37 -08:00
.BI \- x " N"
2016-03-25 14:59:19 +05:30
Show selective monochrome output. Works with -P. If
2015-11-10 23:28:37 -08:00
.I N
= 1, only URL is shown. If
.I N
= 2, URL and tags are shown in a single line. Useful for creating batch update scripts.
.TP
2015-11-09 02:46:01 +05:30
.BI \- z
2015-11-09 01:01:07 +05:30
Enable debugging.
.TP
2015-11-09 02:46:01 +05:30
.BI ""
2015-12-20 01:43:46 +05:30
Any other option shows help and exits buku.
2015-11-09 02:46:01 +05:30
.SH KEYS
2015-11-09 01:01:07 +05:30
.TP
.BI "1-N"
2015-11-09 02:46:01 +05:30
Open
.I Nth
2015-12-20 01:43:46 +05:30
search result in browser. Pressing 'Enter' exits buku.
2015-11-09 01:01:07 +05:30
.SH ENVIRONMENT
.TP
.BI BROWSER
2015-11-09 02:46:01 +05:30
Overrides the default browser. Ref:
2015-11-09 01:01:07 +05:30
.I http://docs.python.org/library/webbrowser.html
2016-03-19 00:14:33 +05:30
.SH EXAMPLES
.PP
.IP 1 . 4
\fB Add\fR a new bookmark with title \fB Linux magazine\fR & tags \fB linux news\fR and \fB open source\fR :
.PP
.EX
.IP
.B buku -a -m 'Linux magazine' http://tuxdiary.com linux news, open source
.EE
.PP
.IP "" 4
Note that URL must precede tags. Multiple words in title must be within quotes. The assigned automatic index 15012014 is unique, one greater than highest index already in use in database.
.PP
.IP 2 . 4
Add a bookmark, \fB fetch page title\fR information from web:
.PP
.EX
.IP
.B buku -a -w http://tuxdiary.com linux news, open source
.PP
.IP 3 . 4
\fB Update\fR existing bookmark at index 15012014 with a new tag:
.PP
.EX
.IP
.B buku -u 15012014 -w http://tuxdiary.com linux news, open source, magazine
2016-03-19 23:27:37 +05:30
.EE
.PP
.IP "" 4
Tags are updated too. Original tags are removed.
2016-03-19 00:14:33 +05:30
.PP
.IP 4 . 4
Update or \fB refresh full DB\fR :
.PP
.EX
.IP
.B buku -R
2016-03-19 23:27:37 +05:30
.EE
.PP
.IP "" 4
2016-03-25 00:17:57 +05:30
This operation does not modify the indexes, URLs or tags. Only titles, if non-empty, are refreshed.
2016-03-19 00:14:33 +05:30
.PP
.IP 5 . 4
\fB Delete\fR bookmark at index 15012014:
.PP
.EX
.IP
.B buku -d 15012014
2016-03-20 11:29:06 +05:30
.EE
.PP
.IP "" 4
The last index is moved to the deleted index to keep the DB compact.
2016-03-19 00:14:33 +05:30
.PP
.IP 6 . 4
\fB Delete all\fR bookmarks:
.PP
.EX
.IP
.B buku -D
.PP
.IP 7 . 4
List \fB all unique tags\fR alphabetically:
.PP
.EX
.IP
.B buku -g
.PP
.IP 8 . 4
\fB Insert\fR a bookmark at index 15012014 (fails if index or URL exists in database):
.PP
.EX
.IP
.B buku -i 15012014 -w http://tuxdiary.com/about linux news, open source
.PP
.IP 9 . 4
2016-03-19 21:50:14 +05:30
\fB Replace a tag\fR with new one:
.PP
.EX
.IP
.B buku -r 'old tag' 'new tag'
.PP
.IP 10 . 4
\fB Delete a tag\fR from DB:
.PP
.EX
.IP
.B buku -r 'old tag'
.PP
.IP 11 . 4
2016-03-19 00:14:33 +05:30
\fB Show info\fR on bookmark at index 15012014:
.PP
.EX
.IP
.B buku -p 15012014
.PP
2016-03-19 21:50:14 +05:30
.IP 12 . 4
2016-03-19 00:14:33 +05:30
\fB Show all\fR bookmarks with real index from database:
.PP
.EX
.IP
.B buku -P
.PP
2016-03-19 21:50:14 +05:30
.IP 13 . 4
2016-03-19 00:14:33 +05:30
\fB Open URL\fR at index 15012014 in browser:
.PP
.EX
.IP
.B buku -o 15012014
.PP
2016-03-19 21:50:14 +05:30
.IP 14 . 4
2016-03-19 00:14:33 +05:30
\fB Search\fR bookmarks for a tag matching \fB kernel debugging\fR or \fB ANY\fR of the keywords \fB kernel\fR and \fB debugging\fR in URL or title (separately):
.PP
.EX
.IP
.B buku -s kernel debugging
.PP
2016-03-19 21:50:14 +05:30
.IP 15 . 4
2016-03-19 00:14:33 +05:30
\fB Search\fR bookmarks for a tag matching \fB kernel debugging\fR or \fB ALL\fR the keywords \fB kernel\fR and \fB debugging\fR in URL or title (separately):
.PP
.EX
.IP
.B buku -S kernel debugging
.PP
2016-03-19 21:50:14 +05:30
.IP 16 . 4
2016-03-19 00:14:33 +05:30
Encrypt/decrypt DB with \fB custom number of iteration\fR to generate key:
.PP
.EX
.IP
.B buku -l -t 15
.PP
.EX
.IP
.B buku -k -t 15
.EE
.PP
.IP "" 4
The same number of iterations must be used for one lock & unlock instance.
.PP
2016-03-19 21:50:14 +05:30
.IP 17 . 4
2016-03-19 00:14:33 +05:30
Show \fB debug info\fR :
.PP
.EX
.IP
.B buku -z ...
2015-11-09 01:01:07 +05:30
.SH AUTHOR
Written by Arun Prakash Jana <engineerarun@gmail.com>.
.SH HOME
2015-12-20 01:43:46 +05:30
.I https://github.com/jarun/buku
2015-11-09 01:01:07 +05:30
.SH REPORTING BUGS
2015-12-20 01:43:46 +05:30
.I https://github.com/jarun/buku/issues
2015-11-09 01:01:07 +05:30
.SH COPYRIGHT
Copyright \(co 2015 Arun Prakash Jana <engineerarun@gmail.com>.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>.
.PP
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.