mirror of
https://github.com/eoli3n/dotfiles
synced 2024-11-22 23:12:32 +01:00
109 lines
2.8 KiB
Markdown
109 lines
2.8 KiB
Markdown
# Sway Acid Dark
|
|
|
|
[![Build Status](https://travis-ci.org/eoli3n/dotfiles.svg?branch=master)](https://travis-ci.org/eoli3n/dotfiles)
|
|
|
|
**Sway fish pure waybar neovim**
|
|
|
|
![alt tag](https://github.com/eoli3n/dotfiles/blob/master/screenshots/sway.png)
|
|
|
|
**Tiny irc client**
|
|
|
|
![alt tag](https://github.com/eoli3n/dotfiles/blob/master/screenshots/irc.png)
|
|
|
|
**Firefox/Tabliss Wofi**
|
|
|
|
![alt tag](https://github.com/eoli3n/dotfiles/blob/master/screenshots/ff.png)
|
|
|
|
**Connman/Thunar GTK Theme**
|
|
|
|
![alt tag](https://github.com/eoli3n/dotfiles/blob/master/screenshots/gtk.png)
|
|
|
|
### Why Ansible ?
|
|
|
|
- Modularity: [Roles](https://docs.ansible.com/ansible/latest/user_guide/playbooks_reuse_roles.html) as modules.
|
|
- Factorization: It uses [jinja2](https://docs.ansible.com/ansible-container/container_yml/template.html) templating engine.
|
|
- Simplicity: No agent, only SSH, available via pip.
|
|
- Flexibility: Push your dotfiles from/to any hosts.
|
|
- Toolbox: Dry-run mode, diff mode, secrets encryption, tags...
|
|
|
|
### How to
|
|
|
|
**Use carefully**, backup your home before using !
|
|
You should use ``--check`` and ``--diff`` to dryrun first.
|
|
|
|
Check details in ``roles/*/README.md``.
|
|
|
|
This project only manages dotfiles.
|
|
To install required packages, use [arch-config](https://github.com/eoli3n/arch-config/blob/master/ansible/roles/desktop/tasks/main.yml), [void-config](https://github.com/eoli3n/void-config/blob/master/ansible/roles/desktop/tasks/main.yml) or [nix-config](https://github.com/eoli3n/nix-config/tree/master/modules/includes/).
|
|
|
|
##### 1. Fork Me!
|
|
|
|
##### 2. Clone your repo
|
|
|
|
```
|
|
git clone https://github.com/*/dotfiles
|
|
```
|
|
|
|
Then, configure desktop environment in [group_vars/all.yml](group_vars/all.yml).
|
|
|
|
##### 3. Configure inventory
|
|
|
|
Create inventory file from template.
|
|
|
|
```
|
|
cd dotfiles
|
|
cp hosts.template hosts
|
|
```
|
|
|
|
Add your hostnames in section:
|
|
- ***cli***: only cli dotfiles
|
|
- ***desktop***: cli dotfiles + desktop environment
|
|
Define which user will get configurations with *ansible_user* var.
|
|
|
|
###### a. localhost run
|
|
|
|
```
|
|
[cli]
|
|
[desktop]
|
|
localhost ansible_connection=local
|
|
```
|
|
|
|
###### b. multiple hosts run
|
|
|
|
Note: *desktop* hosts **can't use root**.
|
|
|
|
```
|
|
[cli]
|
|
server1 ansible_user=root
|
|
[desktop]
|
|
host1 ansible_user=user
|
|
host2 ansible_user=user2
|
|
```
|
|
|
|
##### 4. Configure SSH
|
|
|
|
Push your SSH public key on all your ``users@hosts``
|
|
```
|
|
ssh-copy-id -i path/to/ssh/key.pub user@host
|
|
```
|
|
|
|
##### 5. (Dry)Run
|
|
|
|
```
|
|
ansible-playbook install.yml -CD
|
|
ansible-playbook install.yml
|
|
```
|
|
|
|
For *desktop* hosts, if ``ansible_user`` is sudoer, to install cli tools for *root*, use:
|
|
|
|
```
|
|
ansible-playbook install.yml -l host1 -b -K
|
|
```
|
|
|
|
-----
|
|
|
|
##### Previously
|
|
|
|
* [i3-gaps Dark Solarized](https://github.com/eoli3n/dotfiles/tree/zsh-agnoster-solarized)
|
|
* [i3-gaps Acid Dark](https://github.com/eoli3n/dotfiles/tree/i3-gaps-acid-dark)
|