GithubHelp home page GithubHelp logo

slw07g / chrome-search-engine-importer Goto Github PK

View Code? Open in Web Editor NEW
0.0 1.0 0.0 24 KB

A framework and Python script for sharing custom Chrome search engines

License: GNU General Public License v2.0

Python 100.00%

chrome-search-engine-importer's Introduction

Chrome Search Engine Importer

Publish to PyPI

Custom Search Engines in chrome can make searching for things in private/internal systems a lot more efficient and easier, so long as those systems allow you to input the search string in the URI.

Custom Search Engines can also function as keyword shortcuts to URLs, if you don't wish to fumble around with your bookmarks and would rather type in a keyword in the search bar + to take you to where you are trying to go.

However, when you collaborate with other people who often use the same systems that you do, it can be helpful to share these custom search gines with one another. The manual method for adding custom search engines does not scale well when you need to share a lot of them. Thus, the need for this script to make that manual process easier and the framework of defining custom search engine keywords as YAML files.

How does it work?

Defining search engine keywords in YAML

You will need to create a YML file with your hsortcuts like the example below. The example file, example_search_engines.yml also has some practical examples.

- name: Shortcut 1 Name
  keyword: shorcut1keyword
  url: https://shortcut1/url?q={searchTerms}
- name: Shortcut 2 Name
  keyword: shortcut2keyword
  url: https://shortcut2url.com/search/%s
- name: Virustotal UI
  keyword: vtui
  url: https://www.virustotal.com

NOTE: %s and {searchTerms} are synonymous. All occurrences of %s in the URL are replaced with {searchTerms} when being added to the database.

Using the script

Once you have defined your shortcuts, you may use the script, you must pass the path to the YML file to it. Example:

python3 chrome-search-engine-importer.py -e example_search_engines.yml

By default, the script will look in the default paths for Chrome profiles (on MacOS, Windows, and Linux). You will be given the option to choose which profiles found in the default paths to load the keyhwords in.

To bypass this, you may optionally use the -p flag to specify a path to a profile that is not in a default path.
NOTE: The path should point to the directory that has the sqlite database file Web Data inside of it.

> python3 chrome-search-engine-importer.py --help
Usage: chrome-search-engine-importer.py [OPTIONS]

Options:
  -e, --search-engines-file TEXT  Path to a YAML file with search engines
                                  defined  [required]
  -p, --profile TEXT              Path to a chrome profile. Useful if a target
                                  chrome profile is in a custom path.
  --help                          Show this message and exit.

The script will install any keywords in the YAML that do not already exist in the Web Data database. If you want to add these to be added, either adjust modify the keyword so that it is unique, or delete the existing keyword from your chrome search engines here.

You have to restart chrome

On Windows, Chrome needs to be closed while the script runs otherwise you will encounter an error when the script tries to swap out the Web Data sqlite database.

For the newly added keywords to be visible in chrome, you must relaunch Chrome so that it reloads the SQLite database. I recommend enabling the "Continue where you left off" Startup Option in Chrome so that your tabs recover after you restart the browser.

chrome-search-engine-importer's People

Contributors

slw07g avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.