Personal dotfiles. The installation supports Arch and Debian based systems.
Find a file
2021-03-05 20:18:45 +01:00
dotfiles Move pacman hooks in dotfiles 2021-03-05 20:04:57 +01:00
.gitignore Add include function: move repos to a separate config file, hidden 2021-03-03 19:35:48 +01:00
.talismanrc Add conditionals to grub and pacman.conf commands to validate integrity 2021-02-25 10:04:05 +01:00
borg_backup.sh Rename SSH_REPO to a more specific BORG_REPO 2020-11-02 08:46:02 +01:00
configs.yml Start explaining the yml commands 2021-03-05 20:18:45 +01:00
firefox_addons.txt Add Google Container to Firefox 2021-02-21 08:50:26 +01:00
install.py Start explaining the yml commands 2021-03-05 20:18:45 +01:00
README.md Start explaining the yml commands 2021-03-05 20:18:45 +01:00
requirements.txt Add path 2020-04-18 21:05:02 +02:00
secrets.template Forgot a c in exclude 2020-12-06 16:06:50 +01:00
shellcheck_binary_fix.sh Update shellcheck binary url 2020-09-05 11:11:31 +02:00
todo Add include function: move repos to a separate config file, hidden 2021-03-03 19:35:48 +01:00

Getting started

The Python requirements are all in requirements.txt, so before starting you need to issue the following command:

$ pip install -r requirements.txt --user

without using sudo. Using sudo with pip is a bad idea because it will interfere with your distribution's package manager.

If you're on a fresh install, you won't have pip installed, so you'll need:

$ sudo pacman -S python-pip

or

$ sudo apt install python3-pip

The authentication details are stored in secrets. Therefore, you have a template secrets.template that you need to copy and rename:

$ cp secrets{.template,}

Modify the resulting file, and then run ./install.py with needed flags (./install.py -h is your friend).

About the files in the repo

  • borg_backup.sh
    Borg backup script. Used by a pacman hook to backup my system, but it can also be run manually.

  • configs.yml
    Lists the things to install, which includes programs, symlinks, git clones, shell commands...

  • dotfiles/
    The actual dotfiles. They are symlinked to the location that the system expects to find them.

  • firefox_addons.txt
    I like to install my Firefox add-ons manually in the Firefox add-on manager, so this file just reminds me what to install and includes the urls to each add-on.

  • install.py
    Installs everything using configs.yml. This is the file to actually run.

  • secrets.template
    Contains environment variables for authentication and personnalization. Use it to create a file named secrets.

  • shellcheck_binary_fix.sh
    When running this on ARM, pacman there was no shellcheck package, so this script installs the pre-compiled binary instead. If your package manager finds shellcheck, this script won't run.

  • todo
    Never seems to remain empty...

YML commands

configs.yml contains instructions as keys, which trigger commands. Here is a brief explanation of the implemented commands:

  • clone
    Performs a git clone.

  • copy
    Copy a file.

  • download
    Download a file with a URL.

  • install
    Use the package manager to install a package.

  • include
    Include another config file (also yml).

  • run
    Pass a line of text to a subshell.

  • depend
    Install another part of the config file before.

  • symlink
    Make a symlink.

  • symlink_dir
    Make a symlink to a directory.

  • append
    Append text to the end of a file.

  • write
    Write text to a file, overwriting if it exists.

Thanks

The idea for the architecture was taken from Dimitri Merejkowsky's GitHub.