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:
Install it as a Python package.
Add it as a git submodule in your dotfiles repository.
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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8374b0352f4b77114e18f270e8063ddc36d5c0b7ec599c58001af0078e71a7c6 |
|
MD5 | dc4a138e950e571ef96391db6b966e12 |
|
BLAKE2b-256 | 058c260cafb074cedab0b6aaec4d55433971773fd8cb21d4dba78abd1652ced5 |
File details
Details for the file dotbot_firefox-1.1.0-py3-none-any.whl
.
File metadata
- Download URL: dotbot_firefox-1.1.0-py3-none-any.whl
- Upload date:
- Size: 5.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ec13121aa957ff2ce17f616c0d664af554605870419d79bc01296e6b6f7c95e3 |
|
MD5 | 684b0b0b88eebadaa4683753182c083b |
|
BLAKE2b-256 | 41cfa049d225cc71a51d42bbf77af2deccbc5781e4573776e2034def75b36a43 |