A text-based bookmark manager rendered in a web page
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

249 lines
7.4 KiB

11 months ago
*FR → LISEZMOI.md*
11 months ago
**Work in progress, if you encounter any issues regarding
installation or understanding what this is all about, please send an
email to contact@martinlemaire.fr or open an issue here and i'll be
happy to answer**
A browsable webpage generated from a textual database you might want to
use as a browser homepage. You can edit the database by editing the file
called BOOKMARKS or by running the provided script called
edit_bookmarks_dmenu.sh (requires dmenu). The script can be ran from the
command line but I suggest to bind it to a keystroke combination.
11 months ago
If you want to try with an example BOOKMARKS database (32kb) :
```
curl -O https://martinlemaire.fr/signet.sh/BOOKMARKS
```
then
```
git clone https://git.vvvvvvaria.org/clemtre/signet.sh.git
chmod +x signet.sh
./signet.sh
```
It produces the following html document :
11 months ago
index.html
![a browsable bookmark manager](https://www.martinlemaire.fr/signet.sh/demo.png)
A sample of its corresponding textual database, in the form of blankline
separated records with key/value fields :
11 months ago
BOOKMARKS
```
URL: http://fileformats.archiveteam.org/wiki/HEX_(Unifont)
Name: HEX (Unifont) - Just Solve the File Format Problem
Description:
Tags: bbb, hex
Date: 1704636690
Color: Pink
URL: http://robhagemans.github.io/monobit/
Name: Hoard of bitfonts
Description: Bitmap fonts collection
11 months ago
Tags: bitmap, fonts
Date: 1704639859
URL: https://en.wikipedia.org/wiki/Wish_(Unix_shell)
Name: wish (Unix shell) - Wikipedia
Description: a Tcl interpreter extended with Tk commands for unix.
Tags: gui, wish, tcl
Date: 1704646543
URL: https://www.kreativekorp.com/
Name: Rebecca G. Bettencourt
Description:
Tags: RGB, people, hide
Date: 1704648764
```
Given this database, signet will color the first link in pink and hide
the last one because of its "hide" tag.
11 months ago
# Presentation
## signet.sh
Signet.sh is a shell script parsing a bookmark database to a webpage.
It uses awk inside a here-doc declaration redirected to an html file.
I have created this script because I found the bookmarks manager from
firefox not great to use, to the point where I did not have the habit to
11 months ago
bookmark my browsing journeys. Firefox stores bookmarks in a sqlite
which is not human readable. Although it allows an export in json and
html, I wanted something text based and personal.
11 months ago
## Bookmarks database format
Only a Url is required, the rest of the fields are optional :
11 months ago
* URL : the url pasted from the clipboard (exits if no url given)
* Name : grabs </title> from the bookmarked page with curl
* Description : a description from the user
11 months ago
* Tags : comma separated keywords
11 months ago
* Date : posix time of the bookmarked link
11 months ago
* Color : css color (name, hex, rgb etc...)
11 months ago
11 months ago
## index.html structure generated by signet.sh
```
\<!DOCTYPE html>
\<html>
\<head>
\<title>⛵ → YY-MM-DD, H:M\</title>
\<script defer src="jquery-3.6.4.js">\</script>
\<script defer src="script.js">\</script>
\<link rel="stylesheet" href="style.css">
\<meta charset="utf-8" />
\</head>
\<body>
\<div id="cc">\</div>
\<textarea autofocus>\</textarea>
\<nav>
\<p>tag (amount)\</p>
\</nav>
\<ol>
\<li>
\<a href="URL">
\<section color="Color">
\<h5>URL\</h5>
\<h1>Name\</h1>
\<h2>Description\</h2>
\<h3>Tags\</h3>
\<h4>Date\</h4>
\</section>
\<a>
\</li>
\</ol>
\<footer>\</footer>
\</body>
\</html>
```
11 months ago
# Usage
## Add a bookmark :
11 months ago
11 months ago
To add a link, I select the URL of the page with Ctrl + l, then copy to
clipboard and run add.sh with Super + i.
11 months ago
11 months ago
__If anyone knows how to retrieve the url of the current browser page
without having to copy it and send it to clipboard, this would save two
steps out of three.__
In short : Ctrl + l, Ctrl + c, Super + i
(or shorter : Ctrl + l + c, Super + i)
Super + i because in my window manager (awesomewm) configuration file
located in ~/.config/awesome/rc.lua, I have the following lines:
```
awful.key({modkey}, "i", function()
awful.util.spawn_with_shell("add.sh") end,
{description = "Sends the link in clipboard to add.sh"}),
11 months ago
```
11 months ago
## Edit a bookmark :
11 months ago
11 months ago
Use your text editor of choice. Open the BOOKMARKS file and edit the
entry. The last entry is at the bottom.
11 months ago
11 months ago
If you use vim, with BOOKMARKS opened you can press in normal mode m +
B and it will save a mark to the file you can then access with ' + B
# Installation
Works on my machine : Ubuntu 20 LTS, it should work on any POSIX
compliant machine, macOS, linux* or bsd*. I'm curious to know how it
goes on windows :^)
clone the repo
11 months ago
11 months ago
```
git clone https://git.vvvvvvaria.org/clemtre/signet.sh.git
cd signet.sh
```
11 months ago
# Dependency :
11 months ago
11 months ago
To add a link via the proposed interface, we will need
to install dmenu ~~and htmlq~~.
* dmenu https://tools.suckless.org/dmenu/ (MIT/X)
* ~~htmlq https://github.com/mgdm/htmlq (MIT)~~ replaced by one
awk command
## dmenu
Dmenu is an interactive menu that allows us to select and write
values in a menu. These values can come from a program
provided as input from a pipe "|", for example:
```
ls | dmenu
```
displays a drop-down menu with the files in my directory.
In our script, to store the given tags in a variable, we can do:
```
tags=$(echo "" | dmenu -p "Enter comma-separated tags:")
```
11 months ago
### install dmenu :
https://askubuntu.com/questions/828450/how-to-install-dmenu
11 months ago
## ~~htmlq~~
Htmlq is an HTML parser written in Go. It doesn't matter which parser we
11 months ago
use, it seems that each language has its own.
11 months ago
We give to the program an html string and it filters through it using css
selectors returning the found html elements
Using javascript, retrieving all the \<h1> children of a \<section> can
be done with :
```
document.querySelectorAll('section h1')
```
11 months ago
In shell, it's more complicated since we don't have document object
model we can query. Htmlq is made for that:
11 months ago
```
cat fichier.html | htmlq 'section h1'
```
And to output only the text -- the javascript equivalent of .innerHTML:
```
cat fichier.html | htmlq 'section h1' --text
```
We use it to retrieve the title tag of the page to add:
```
curl page.html | htmlq 'title' --text
```
Pre-release patch:
```
curl $url | awk -v RS='</title>' \
'/<title>/ {gsub(/.*<title>/, ""); print}' |\
tr -d '\n'
```
For the moment this step is blocking. In case internet cuts while
bookmarking a link, you will have to wait for the end of the curl
attempt to move to the next field in the script :/ sorry!
11 months ago
# Repository structure :
11 months ago
* BOOKMARKS → A textual database of bookmarks
11 months ago
* edit_bookmarks_dmenu.sh → A script to add a link to the database using
dmenu
11 months ago
* dmenu
* ./signet.sh
11 months ago
* bookmark.sh → The shell script itself
11 months ago
* It generates a new html page from the link database
(default index.html)
11 months ago
* style.css → Stylesheet for index.html
* script.js → A bit of javascript for:
11 months ago
* search in the \<textarea>
* add background colors to entries that have them
* if the description field is empty, do not display it
* format posix time dates to YY-MM-DD format
11 months ago
11 months ago
/!\ Soon /!\
11 months ago
11 months ago
starred.sh → curl from the github user api and format it in the same
way as signet.sh without using jq
https://api.github.com/users/[user]/starred
11 months ago
# Other bookmark managers:
- nb https://xwmx.github.io/nb/ (AGPL-3.0)
- ??
11 months ago
# Credits
11 months ago
* Junicode (OFL-1.1)
11 months ago
https://psb1558.github.io/Junicode-font/
11 months ago
* dmenu (MIT/X)
11 months ago
https://tools.suckless.org/dmenu/
11 months ago
* jquery (MIT)
https://jquery.com/
11 months ago