Skip to main content

Configure your Firefox profile(s) using dotbot

Project description

Configure your Firefox profile(s) using dotbot.


Table of contents

What you can do with it

When Firefox starts, it will look for a user.js file in your profile directory. If found, the user.js settings will be copied to prefs.js and used.

You can enforce a consistent Firefox configuration across all your profiles by using dotbot-firefox to create symlinks to a custom user.js. The plugin will find Firefox profile directories that contain a prefs.js file and will use dotbot’s builtin Link plugin to create the symlinks.

Installation

There are two ways to install and use the plugin:

  1. Install it as a Python package.

  2. Add it as a git submodule in your dotfiles repository.

  3. Copy dotbot_firefox.py into your dotfiles directory.

Python package

If you want to install dotbot-firefox as a Python package (for example, if you’re using a virtual environment), then you can install the plugin using pip:

pip install dotbot-firefox

Then, when running dotbot, use the -p or --plugin option to tell dotbot to load the plugin:

dotbot [...] --plugin dotbot_firefox [...]

If you’re using one of dotbot’s install scripts, you’ll need to edit that file to add the --plugin option.

Git submodule

If you want to track dotbot-firefox as a git submodule (for example, if you manage your dotfiles using git) then you can add the plugin repository as a submodule using git:

git submodule add https://github.com/kurtmckee/dotbot-firefox.git

This will clone the repository to a directory named dotbot-firefox. Then, when running dotbot, use the -p or --plugin option to tell dotbot to load the plugin:

dotbot [...] --plugin dotbot-firefox/dotbot_firefox.py [...]

Note that you may need to initialize the plugin’s git submodule when you clone your dotfiles repository or pull new changes to another computer. The command for this will look something like:

git submodule update --init dotbot-firefox

Copy dotbot_firefox.py

If desired, you can copy dotbot_firefox.py to your dotfiles directory. You might choose to do this if you already use other plugins and have configured dotbot to load all plugins from a plugin directory.

If you copy dotbot_firefox.py to the root of your dotfiles directory then, when running dotbot, use the -p or --plugin option to tell dotbot to load the plugin:

dotbot [...] --plugin dotbot_firefox.py [...]

If you copy dotbot_firefox.py to a directory containing other plugins, you can use dotbot’s --plugin-dir option to load all plugins in the directory. In the example below, the plugin directory is named dotbot-plugins:

dotbot [...] --plugin-dir dotbot-plugins [...]

Configuration

First, create a user.js file in the dotfiles directory that dotbot manages. For example, it could contain this configuration to set your homepage:

user_pref("browser.startup.homepage", "https://dashboard.example");

(MozillaZine maintains an extensive list of Firefox configuration settings.)

Then, add a firefox directive to your dotbot config with a user.js key. The value of the key follows the syntax of the dotbot Link plugin.

# Example 1:
# "user.js" can be specified as a string.
firefox:
  user.js: firefox/user.js


# Example 2:
# "user.js" can have no value, and will be found
# in the same directory as your dotbot config file.
firefox:
  user.js:


# Example 3:
# The extended Link plugin syntax is supported.
firefox:
  user.js:
    path: firefox/user.js
    force: true

Firefox profile locations

The dotbot-firefox plugin is aware of the following default directories:

  • %APPDATA%\Mozilla\Firefox\Profiles (Windows)

  • ~/Library/Application Support/Firefox/Profiles (Mac OS)

  • ~/.mozilla/firefox (Linux)

  • ~/snap/firefox/common/.mozilla/firefox (Firefox Snap for Linux)

  • ~/.var/app/org.mozilla.firefox/.mozilla/firefox (Firefox Flatpak for Linux)

Only profile subdirectories that contain a prefs.js file will be considered valid by the plugin.

Development

To set up a development environment, clone the dotbot-firefox plugin’s git repository. Then, follow these steps to create a virtual environment and run the unit tests locally:

# Create the virtual environment
$ python -m venv .venv

# Activate the virtual environment (Linux)
$ . .venv/bin/activate

# Activate the virtual environment (Windows)
$ & .venv/Scripts/Activate.ps1

# Update pip and setuptools, and install wheel
(.venv) $ pip install -U pip setuptools wheel

# Install poetry and tox
(.venv) $ pip install poetry tox

# Install all dependencies
(.venv) $ poetry install

# Run the unit tests locally
(.venv) $ tox

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dotbot_firefox-1.1.0.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

dotbot_firefox-1.1.0-py3-none-any.whl (5.4 kB view details)

Uploaded Python 3

File details

Details for the file dotbot_firefox-1.1.0.tar.gz.

File metadata

  • Download URL: dotbot_firefox-1.1.0.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for dotbot_firefox-1.1.0.tar.gz
Algorithm Hash digest
SHA256 8374b0352f4b77114e18f270e8063ddc36d5c0b7ec599c58001af0078e71a7c6
MD5 dc4a138e950e571ef96391db6b966e12
BLAKE2b-256 058c260cafb074cedab0b6aaec4d55433971773fd8cb21d4dba78abd1652ced5

See more details on using hashes here.

File details

Details for the file dotbot_firefox-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for dotbot_firefox-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ec13121aa957ff2ce17f616c0d664af554605870419d79bc01296e6b6f7c95e3
MD5 684b0b0b88eebadaa4683753182c083b
BLAKE2b-256 41cfa049d225cc71a51d42bbf77af2deccbc5781e4573776e2034def75b36a43

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page