9 releases

0.3.4 Mar 25, 2024
0.3.3 Apr 20, 2023
0.3.0 Jun 27, 2022
0.2.1 Feb 1, 2022
0.1.3 Jan 23, 2022

#150 in HTTP server

Download history 52/week @ 2024-02-18 30/week @ 2024-02-25 1/week @ 2024-03-03 21/week @ 2024-03-10 126/week @ 2024-03-24 47/week @ 2024-03-31

185 downloads per month

GPL-3.0 license

1.5MB
2.5K SLoC

JavaScript 1.5K SLoC // 0.1% comments Rust 1K SLoC // 0.0% comments Shell 7 SLoC // 0.2% comments

#+TITLE: 1History #+DATE: 2022-01-23T20:21:06+0800 #+AUTHOR: Jiacai Liu #+LANGUAGE: cn #+OPTIONS: toc:nil num:nil #+STARTUP: content

[https://crates.io/crates/onehistory] [https://github.com/1History/1History/actions/workflows/CI.yml]

#+begin_quote All your history in one file. #+end_quote

1History is a command line tool to backup your different browser histories into one file, and visualize them!

[https://www.producthunt.com/posts/1history?utm_source=badge-review&utm_medium=badge&utm_souce=badge-1history#discussion-body]

  • Features
  • Rich dashboards to visualize your history
  • Export as CSV file
  • Entirely offline, No need to worry about privacy leaks
  • Support Chrome/Firefox/Safari on macOS/Linux/Windows
  • Well-designed schemas to avoid history duplication when backup multiple times
  • No NPM, 1History is a single binary built mainly in Rust🦀

USAGE: onehistory [OPTIONS]

OPTIONS: -d, --db-file <DB_FILE> Database path [env: OH_DB_FILE=] [default: ~/onehistory.db] -h, --help Print help information -v, --verbose -V, --version Print version information

SUBCOMMANDS: backup Backup browser history to 1History export help Print this message or the help of the given subcommand(s) serve Start HTTP server to visualize history show Show default history files on your computer #+end_src ** Backup #+begin_src bash USAGE: onehistory backup [OPTIONS]

OPTIONS: -d, --disable-detect Disable auto detect history files

-D, --dry-run


-f, --history-files <HISTORY_FILES>
        SQLite file path of different browsers(History.db/places.sqlite...)

-h, --help
        Print help information

#+end_src =backup= is the main subcommand, it will import browser history into 1History.

1History will automatically detect history of different browsers by default, =show= subcommand will show what it can find.

Users can also use =-f= option to set other history files to backup, the history file has the following naming convention: | Browser | History Filename | |---------+------------------| | Chrome | History | | Firefox | places.sqlite | | Safari | History.db | #+begin_src bash

-f can be used multiple times

-d is required when doing backup with browsers open

onehistory backup -d -f ~/some-dir/History.db -f ~/another-dir/places.sqlite #+end_src

** Serve After backup browser history into 1History, the next step is to visualize those data.

=serve= subcommand will start a HTTP server at [http://127.0.0.1:9960], open this in your browser to explore.

  • Installation ** Homebrew #+begin_src bash brew install 1History/onehistory/onehistory #+end_src ** Binary The [[https://github.com/1History/1History/releases][release page]] includes precompiled binaries for Linux, macOS and Windows. ** Cargo #+begin_src bash cargo install onehistory #+end_src

  • Changelog See [[file:CHANGELOG.org][CHANGELOG]]

  • FAQ

  • =Error code 5: The database file is locked= :: This error happens if your browser is opened during backup, as SQLite allow only one open connection.

    Close the browser is one solution, or you can copy history file to other directory other than default location.

1History is distributed under [https://www.gnu.org/licenses/gpl-3.0.txt] license.

Dependencies

~41–56MB
~1M SLoC