93

GitHub - twpayne/chezmoi: chezmoi is a tool for managing your dotfiles across mu...

 5 years ago
source link: https://github.com/twpayne/chezmoi
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

README.md

chezmoi

Build Status GoDoc Report Card

chezmoi is a tool for managing your dotfiles across multiple machines.

Features

  • Declarative: you declare the desired state of files and directories in your home directory and chezmoi updates your home directory to match that state.

  • Flexible: your dotfiles can be templates (using text/template syntax). Predefined variables allow you to change behaviour depending on operating system, architecture, and hostname.

  • Robust: chezmoi updates all files atomically (using google/renameio) so you are never left with incomplete files that could lock you out, even if the update process is interrupted.

  • Portable: chezmoi's configuration uses only visible, regular files and directories and so is portable across version control systems and operating systems.

  • Transparent: chezmoi includes verbose and dry run modes so you can review exactly what changes it will make to your home directory before making them.

  • Practical: chezmoi manages hidden files (dot files), directories, private, and executable files.

  • Fast, easy to use, and familiar: chezmoi runs in fractions of a second and includes commands to make most operations trivial. You can use the version control system of your choice to manage your configuration, and many different formats (e.g. JSON, YAML, TOML, etc.) are supported for the configuration file.

Quick start

Install it:

$ go get -u github.com/twpayne/chezmoi

Manage an existing file with chezmoi:

$ chezmoi add ~/.bashrc

This will create a directory called ~/.chezmoi with permissions 0600 where chezmoi will store its state, if it does not already exist, and copy ~/.bashrc to ~/.chezmoi/dot_bashrc.

You should manage your ~/.chezmoi directory with the version control system of your choice. chezmoi will ignore all files and directories beginning with a . in this directory, so directories like .git and .hg will not pollute your home directory.

Edit the desired state:

$ chezmoi edit ~/.bashrc

This will open ~/.chezmoi/dot_bashrc in your $EDITOR. Make some changes and save them.

See what changes chezmoi would make:

$ chezmoi diff

Apply the changes:

$ chezmoi -v apply

All chezmoi commands accept the -v (verbose) flag to print out exactly what changes they will make to the file system, and the -n (dry run) flag to not make any actual changes. The combination -n -v is very useful if you want to see exactly what changes would be made.

For a full list of commands run:

$ chezmoi help

Using templates to manage files that vary from machine to machine

The primary goal of chezmoi is to manage configuration files across multiple machines, for example your personal macOS laptop, your work Ubuntu desktop, and your work Linux laptop. You will want to keep much configuration the same across these, but also need machine-specific configurations for email addresses, credentials, etc. chezmoi achieves this functionality by using text/template for the source configuration files where needed.

For example, your home ~/.gitconfig on your personal machine might look like:

[user]
    name = John Smith
    email = [email protected]

Whereas at work it might be:

[user]
    name = John Smith
    email = [email protected]

To handle this, on each machine create a file called ~/.chezmoi.yaml defining what might change. For your home machine:

data:
  name: John Smith
  email: [email protected]

If you intend to store private data (e.g. access tokens) in ~/.chezmoi.yaml, make sure it has mode 0600. See "Keeping data private" below for more discussion on this.

If you prefer, you can use any format supported by Viper for your configuration file. This includes JSON, YAML, TOML, and more.

Then, add ~/.gitconfig to chezmoi using the -T flag to automatically turn it in to a template:

$ chezmoi add -T ~/.gitconfig

You can then open the template (which will be saved in the file ~/.chezmoi/dot_gitconfig.tmpl):

$ chezmoi edit ~/.gitconfig

The file should look something like:

[user]
    name = {{ .name }}
    email = {{ .email }}

chezmoi will substitute the variables from the data section of your ~/.chezmoi.yaml file when calculating the desired state of .gitconfig.

For more advanced usage, you can use the full power of the text/template language to include or exclude sections of file. chezmoi provides the following automatically populated variables:

Variable Value chezmoi.arch Architecture, e.g. amd64, arm, etc. as returned by runtime.GOARCH. chezmoi.group The group of the user running chezmoi. chezmoi.homedir The home directory of the user running chezmoi. chezmoi.hostname The hostname of the machine chezmoi is running on. chezmoi.os Operating system, e.g. darwin, linux, etc. as returned by runtime.GOOS. chezmoi.username The username of the user running chezmoi.

For example, in your ~/.chezmoi/dot_bashrc.tmpl you might have:

# common config
export EDITOR=vi

# machine-specific configuration
{{- if .chezmoi.hostname eq "work-laptop" }}
# this will only be included in ~/.bashrc on work-laptop
{{- end }}

If, after executing the template, the file contents are empty, the target file will be removed. This can be used to ensure that files are only present on certain machines. If you want an empty file to be created anyway, you will need to give it an empty_ prefix. See "Under the hood" below.

Keeping data private

chezmoi automatically detects when files and directories are private when adding them by inspecting their permissions. Private files and directories are stored in ~/.chezmoi as regular, public files with permissions 0644 and the name prefix private_. For example:

$ chezmoi add ~/.netrc

will create ~/.chezmoi/private_dot_netrc. Note that this file is still private because ~/.chezmoi is not group- or world- readable or executable. chezmoi checks that the permissions of ~/.chezmoi are 0700 on every run and will print a warning if they are not.

It is common that you need to store access tokens in config files, e.g. a Github access token. There are several ways to keep these tokens secure, and to prevent them leaving your machine.

Using templates

Typically, ~/.chezmoi.yaml is not checked in to version control and has permissions 0600. You can store tokens as template values in the data section. For example, mine has:

data:
  github:
    user: twpayne
    token: xxxxxxxx

My ~/.chezmoi/private_dot_gitconfig.tmpl then contains:

{{- if .github }}
[github]
    user = {{ .github.user }}
    token = {{ .github.token }}
{{- end }}

Note that any config files containing tokens in plain text should be private (mode 0600).

Using encrypted config files

chezmoi takes a -c flag specifying the file to read its configuration from. You can encrypt your configuration and then only decrypt it when needed:

$ gpg -d ~/.chezmoi.yaml.gpg | chezmoi -c /dev/stdin apply

Managing your ~/.chezmoi directory with version control

chezmoi has some helper commands to assist managing your source directory with version control. The default version control system is git but you can change this by setting sourceVCSCommand in your .chezmoi.yaml file, for example, if you want to use Mercurial:

sourceVCSCommand: hg

chezmoi source is then a shortcut to running sourceVCSCommand in your ~/.chezmoi directory. For example you can push the current branch with:

$ chezmoi source push

Extra arguments are passed along unchanged, although you'll need to use -- stop chezmoi from interpreting extra flags. For example:

$ chezmoi source pull -- --rebase

The source command accepts the usual -n and -v flags, so you can see exactly what it will run without executing it.

Under the hood

chezmoi stores the desired state of files and directories in ~/.chezmoi. This location can be overridden with the -s flag or by giving a value for sourceDir in ~/.chezmoi.yaml. Some state is encoded in the source names. chezmoi ignores all files and directories in the source directory that begin with a .. The following prefixes and suffixes are special.

Prefix Effect private_ prefix Remove all group and world permissions from the target file or directory. empty_ prefix Ensure the file exists, even if is empty. By default, empty files are removed. executable_ prefix Add executable permissions to the target file. dot_ prefix Rename the file or directory to use a leading dot, e.g. dot_foo becomes .foo. .tmpl suffix Treat the source file as a template.

Order is important, the order is private_, empty_, executable_, dot_, .tmpl.

Using chezmoi outside your home directory

chezmoi, by default, operates on your home directory, but this can be overridden with the --target command line flag or by specifying targetDir in your ~/.chezmoi.yaml. In theory, you could use chezmoi to manage any aspect of your filesystem. That said, although you can do this, you probably shouldn't. Existing configuration management tools like Puppet, Chef, Ansible, and Salt are much better suited to whole system configuration management.

chezmoi was inspired by Puppet, but created because Puppet is a slow overkill for managing your personal configuration files. The focus of chezmoi will always be personal home directory management. If your needs grow beyond that, switch to a whole system configuration management tool.

License

The MIT License (MIT)

Copyright (c) 2018 Tom Payne

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK