Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

usb

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

usb

Manage and search browser histories across multiple browsers and browser profiles.

  • 0.0.83.dev0
  • PyPI
  • Socket score

Maintainers
1

Build Status Build Status Build Status

United States of Browsers

A project to combine and organize history and bookmarks across multiple browsers and browser profiles.

EARLY DEV BUILD. NOT INTENDED FOR WIDESPREAD USE. USE AT YOUR OWN RISK.

The wiki has more info about the project's philosophy.

I use multiple browsers and multiple browser profiles. This scatters my history, bookmarks across multiple interfaces.

Whenever I wish to search something, I have to go through them all until I find them. I wish to build a tool which will read browser profile files and combine the history and bookmarks list, ready to be searched and organized automatically.

Initial idea is to read the broswer's sqlite3 database files and copy and combine the data in one place, then allow simultaneous keyword and date range search on it. More features for searching and organization and maybe an ML algo to recommend from within the combined history and the web will be implemented.

Note: Play with it, I haven't made it Demo-ready yet. It shouldn't damage anything, but if it is does... THIS IS A USE AT YOUR OWN RISK SOFTWARE.

Installation instructions are further down.
  • Built with python3.6
  • using Pycharm 2017.3 CE
  • On Windows 10 x64 Fall Creators Update
  • For Mozilla Firefox, Chrome, Opera, Vivaldi
  • May work with other Windows versions.

It is Windows ONLY for now. I got it working with my personal installation of Linux Mint. Watch this space.

Easy to make it work for other OSes. Changing path locations for browser profile folder should make it work on other OS. (TODO)

Following functionality has been implemented as of Jan 30, 2018:

  • Browser histories of Firefox, Chrome, Opera and Vivaldi can be combined into one database.
  • A web UI served by Flask.
  • Keyword and Date range search.

Future Plans:

  • Update duplicate entries. (?)
  • Refine the GUI using JS & AJAX.
  • Scraping the URL and getting the text back.
  • ML to pick out keywords from text and title.
  • Use that to tag and categorize the history entries
To Check it out: (Currently, instructions for command line only)
  1. Install the required software if it is not already installed.

  2. Open terminal (In windows, these are cmd.exe and powershell).

  3. Navigate to the directory/folder where you wish to store the files. In this example, we will do this on the windows Desktop. In the terminal window, type the command:

     cd C:\Users\<your username>\Desktop (press ENTER).
    
  4. Clone this repo's master branch using the command:

     git clone "https://github.com/kchawla-pi/united-states-of-browsers.git"
    
  5. Navigate into the newly created directory/folder:

     cd united-states-of-browsers
    
  6. Make a virtual environment using:

     python -m venv venv
    
  7. Activate the virtual environment:

     venv\Scripts\activate
    
  8. Install the required python packages:

     pip install -r requirements.txt
    
  9. Install the project:

     pip install .
    

    or if you wanna play with the code;

     pip install --editable .
    
  10. To merge the databases and launch the user interface, run:

     python .\united_states_of_browsers\run_usb.py
    
  11. Then go to your browser of choice and visit:

    localhost:5000
    
  12. To stop, go back to the same terminal window where the program is running and press Ctrl+C.

  13. Deactivate the virtual environment by typing deactivate and pressing ENTER.

Merging the database will generate an sqlite file in the ~\USB\ directory/folder, where ~ is the user directory/folder.
In windows this is typically C:\Users\<user name>

Currently tests are not available.

To run tests (requires pytest), type:

pytest

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc