Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/agzam/browser-hist.el

Search through browser history, in Emacs
https://github.com/agzam/browser-hist.el

browser-history emacs

Last synced: 2 months ago
JSON representation

Search through browser history, in Emacs

Awesome Lists containing this project

README

        

#+title: Search through the Browser history, in Emacs

** Description
Browsers usually keep their history in a sqlite database, and it's trivial to extract it. This package allows you to search through your browser history by URL and the Page Title.
** Requirements
*For Emacs versions prior 29, install sqlite.el*

Emacs 29 has built-in support for sqlite, but any prior versions of Emacs need [[https://gitlab.com/cnngimenez/sqlite.el][sqlite.el]] installed.

Note that if you add the package to your config and at some point do switch to Emacs 29, you'd have to remove it because Emacs 29 also includes a package with the same exact name.

It's probably possible to wrap the package declaration in a check like:
#+begin_src emacs-lisp
(unless (and (fboundp 'sqlite-available-p)
(sqlite-available-p))
(package! sqlite))
#+end_src
But I'm not sure if that would properly work, and of course, it all depends on the package manager you're using.

** How to use it
*** 1. Install the package using your favorite package manager.
e.g., for Doom:

packages.el:
#+begin_src emacs-lisp
(package! browser-hist :recipe (:host github :repo "agzam/browser-hist.el"))

;; For Emacs versions prior 29
(package! sqlite)
#+end_src

config.el:
#+begin_src emacs-lisp
;; For Emacs versions prior 29
(use-package! sqlite)

(use-package! browser-hist
:init
(require 'embark) ; load Embark before the command (if you're using it)
:config
(setq browser-hist-default-browser 'firefox)
:commands (browser-hist-search))
#+end_src

*** 2. Set the mandatory variable(s)
- =browser-hist-default-browser= - set this var, the package doesn't know yet how to resolve the default browser automatically

example:
#+begin_src elisp
(setq browser-hist-default-browser 'chrome)
#+end_src

- Optionally, you may have to set =browser-hist-db-paths=. The package should resolve these paths automatically. But if it fails you, the first thing I would suggest is to check the values that var holds and make sure that the path to the DB is correct. You can set the paths explicitly, like so:

#+begin_src elisp
(setq browser-hist-db-paths
'((chrome . "$HOME/Library/Application Support/Google/Chrome/Default/History")
(brave . "$HOME/Library/Application Support/BraveSoftware/Brave-Browser/Default/History")
(firefox . "$HOME/Library/Application Support/Firefox/Profiles/*.default-release/places.sqlite")))
#+end_src

You may even ignore the browsers you don't use; right now the package works only with a single browser. I'm considering adding data retrieval for multiple browsers at some point.

- Set minimum number of chars (optional)

#+begin_src elisp
(setq browser-hist-minimum-query-length 2) ; default is 3
#+end_src

- Set cache invalidation (optional)

The browser history database needs to be copied every time. Depending on its size, it may take a second or more. If you don't necessarily care for the most recent items in the history and only want to occasionally search for older items, you may want to set the cache timeout value. This way, the search dialog will open faster, at the expense of missing some of the most recent items. In my experience, however, this variable almost always can remain at 0 and not affect performance at all.

#+begin_src elisp
(setq browser-hist-cache-timeout 60) ; default is 0
#+end_src

The main search command can be called with a prefix argument that forces it to ignore cached DB and copy it anew.

**** Important note for Safari (Mac) users
Make sure that Emacs has Full Disk Access. Otherwise, the system won't even let it touch the file.

Go to *Preferences -> Privacy & Security -> Full Disk Access*, and add Emacs. Make sure Emacs has access to the folder, run =M-x find-file= and navigate to ~$HOME/Library/Safari/~ - it should let you.

*** 3. Try it
There's only one command right now, =browser-hist-search=, try running it and see if it works. Let me know if it doesn't.

** FAQ
*** What's the point? Why even have this if you can do it in the browser?
- It's convenient and a bit faster to bind the command to a key.
- And then, using an [[https://github.com/oantolin/embark][Embark]] Action you can open the link in EWW, in XWidget, or any other browser (not necessarily the history origin one).
- You can also narrow the search and export the results into a separate buffer using Embark Collect.
- It opens some other possibilities like sending a link to a browser but forcing it to find the tab (if there's an open one already, e.g., why open another GMail tab?) /That could be done using Applescript on Mac, xdotool or TabFS on Linux/.
- Or maybe open the link in a private tab of a chosen browser.
- I'm also hoping at some point to collect data from multiple browsers.