Files
dotfiles/playbook.yml

307 lines
7.3 KiB
YAML
Raw Normal View History

2018-02-05 20:09:05 +01:00
- hosts: localhost
connection: local
become: false
tasks:
2018-08-17 19:44:31 +02:00
- name: read machine-specific variables
include_vars:
file: _machines/{{ ansible_hostname }}.yml
name: machine
tags:
- always
2018-02-08 21:45:02 +01:00
- set_fact:
distro: "{{ ansible_distribution|lower }}"
2018-08-17 19:44:31 +02:00
tags:
- always
2018-02-08 21:45:02 +01:00
- set_fact:
user: "{{ ansible_user_id }}"
2018-08-17 19:44:31 +02:00
tags:
- always
2018-02-05 20:09:05 +01:00
- name: configure sudoers
lineinfile:
path: /etc/sudoers
line: "{{ user }} ALL=(ALL) NOPASSWD:ALL"
regexp: "^{{ user }}\\s+"
2018-02-05 20:09:05 +01:00
become: true
- name: set shell
user:
name: "{{ user }}"
2018-02-05 20:09:05 +01:00
shell: /usr/bin/zsh
become: true
2018-02-11 12:03:54 +01:00
- name: install selinux specials on fedora
2019-04-14 11:54:29 +02:00
dnf:
2018-02-11 12:03:54 +01:00
state: installed
2019-04-14 11:54:29 +02:00
name:
- python2-libselinux
- policycoreutils-python
2018-02-11 12:03:54 +01:00
become: true
when: distro == 'fedora'
2018-02-05 20:09:05 +01:00
- name: load package list
include_vars:
file: packages.yml
2018-02-08 21:45:19 +01:00
- name: enable neovim ppa
apt_repository:
repo: 'ppa:neovim-ppa/stable'
update_cache: true
become: true
when: distro == 'ubuntu'
2018-02-05 20:09:05 +01:00
- set_fact:
defined_packages: "{{ packages|json_query('keys(list)') }}"
- set_fact:
distro_packages: "{{ packages|json_query('list.*.%s'|format(distro)) }}"
- name: check list
assert:
that: "defined_packages|length == distro_packages|length"
- name: install packages
package:
name: "{{ packages|json_query(query) }}"
state: installed
become: true
vars:
query: "{{ 'list.*.%s[]'|format(distro) }}"
2018-02-09 17:56:43 +01:00
- name: disable services
service:
state: stopped
enabled: false
name: "{{ item }}"
2018-12-28 18:19:00 +01:00
with_items:
- ssh
2018-02-09 17:56:43 +01:00
become: true
- name: enable services
service:
state: started
enabled: true
name: "{{ item }}"
with_items:
- NetworkManager
2018-12-28 18:19:00 +01:00
- docker
- libvirtd
2018-02-09 17:56:43 +01:00
become: true
2018-08-17 19:00:31 +02:00
- name: set groups for fedora
2018-08-12 14:31:14 +02:00
user:
name: "{{ user }}"
groups:
- libvirt
- wheel
- vboxusers
- wireshark
- docker
become: true
2018-08-17 19:00:31 +02:00
when: distro == 'fedora'
- name: set groups for ubuntu
user:
name: "{{ user }}"
groups:
- adm
- cdrom
- sudo
- dip
- plugdev
- lpadmin
- sambashare
- docker
- libvirt
become: true
when: distro == 'ubuntu'
2018-08-12 14:31:14 +02:00
2018-02-09 17:56:43 +01:00
- name: get systemd boot target
command: systemctl get-default
register: systemd_target
changed_when: false
- set_fact:
default_target: multi-user.target
- name: set systemd boot target
command: systemctl set-default {{ default_target }}
when: systemd_target.stdout != default_target
become: true
- name: handle lid switch
lineinfile:
path: /etc/systemd/logind.conf
regexp: '^HandleLidSwitch='
line: 'HandleLidSwitch=ignore'
become: true
- name: handle power key
lineinfile:
path: /etc/systemd/logind.conf
regexp: '^HandlePowerKey='
line: 'HandlePowerKey=suspend'
become: true
- name: create directory for getty autologin
file:
state: directory
path: /etc/systemd/system/getty@tty1.service.d
owner: root
group: root
mode: '0755'
become: true
- name: enable getty autologin
copy:
dest: /etc/systemd/system/getty@tty1.service.d/override.conf
owner: root
group: root
mode: '0644'
content: |
[Service]
ExecStart=
ExecStart=-/sbin/agetty --autologin {{ user }} --noclear %I $TERM
become: true
2018-02-11 12:03:40 +01:00
- name: load dotfile list
include_vars:
file: dotfiles.yml
2018-08-17 19:44:31 +02:00
tags:
- dotfiles
- name: get state of empty directories
stat:
2019-04-14 11:55:01 +02:00
path: ~/{{ item.name }}
register: empty_dir_stat
with_items: "{{ empty_directories }}"
tags:
- dotfiles
- name: remove sysmlinks
file:
path: "{{ item.stat.path }}"
state: absent
when: item.stat.exists and item.stat.islnk
with_items: "{{ empty_dir_stat.results }}"
tags:
- dotfiles
2018-08-17 19:44:31 +02:00
- name: create empty directories for dotfiles
file:
state: directory
2019-04-14 11:55:01 +02:00
path: ~/{{ item.name }}
mode: "{{ item.mode | default('0755') }}"
2018-08-17 19:44:31 +02:00
with_items: "{{ empty_directories }}"
tags:
- dotfiles
2018-02-11 12:03:40 +01:00
- name: link this folder to ~/.dotfiles
file:
state: link
force: true
path: "{{ ansible_user_dir }}/.dotfiles"
src: "{{ playbook_dir }}"
2018-08-17 19:44:31 +02:00
tags:
- dotfiles
2018-02-11 12:03:40 +01:00
- name: link dotfiles
file:
state: link
force: true
path: "{{ ansible_user_dir }}/{{ item.to }}"
src: ~/.dotfiles/{{ item.from }}
2018-08-17 19:44:31 +02:00
when: not item.template|default(false)
with_items: "{{ dotfiles }}"
tags:
- dotfiles
- name: get state of template targets
stat:
path: ~/{{ item.to }}
register: template_stat
when: item.template|default(false)
with_items: "{{ dotfiles }}"
tags:
- dotfiles
- name: remove invalid template target (directory or symlink)
file:
path: "{{ item.stat.path }}"
state: absent
when:
- not item.skipped is defined or not item.skipped
- item.stat.exists
- not item.stat.isreg
with_items: "{{ template_stat.results }}"
tags:
- dotfiles
2018-08-17 19:44:31 +02:00
- name: deploy dotfiles templates
template:
src: ~/.dotfiles/{{ item.from }}.j2
dest: "{{ ansible_user_dir }}/{{ item.to }}"
force: true
when: item.template|default(false)
2018-02-11 12:03:40 +01:00
with_items: "{{ dotfiles }}"
2018-08-17 19:44:31 +02:00
tags:
- dotfiles
2018-02-10 11:59:33 +01:00
- name: create directories
file:
state: directory
path: "{{ item }}"
with_items:
- ~/.var/lib
- ~/.var/log
- ~/.var/run
- ~/.usr/lib
2018-02-11 12:04:11 +01:00
- name: create intermediate directories for vim-plug
file:
path: "{{ item }}"
state: directory
with_items:
- ~/.local/
- ~/.local/share/
- ~/.local/share/nvim/
- ~/.local/share/nvim/site/
- ~/.local/share/nvim/site/autoload/
- ~/.vim/
- ~/.vim/autoload
- name: install vim-plug
get_url:
dest: ~/.vim/autoload/plug.vim
url: https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
2018-08-17 21:16:54 +02:00
tags:
- vim
2018-02-11 12:04:11 +01:00
- name: symlink vim-plug for neovim
file:
state: link
path: ~/.local/share/nvim/site/autoload/plug.vim
src: ~/.vim/autoload/plug.vim
force: true
2018-08-17 21:16:54 +02:00
tags:
- vim
2018-02-11 12:04:11 +01:00
- name: install vim plugins
2018-08-17 21:16:54 +02:00
command: /usr/bin/nvim -f -E -s -c "source ~/.vimrc" +PlugInstall +qall
register: vim_plugins_stdout
changed_when: vim_plugins_stdout.stdout_lines|length != 0
tags:
- vim
- name: compile youcompleteme
shell: |
cd ~/.local/share/nvim/plugged/YouCompleteMe/
./install.py --go-completer
args:
creates: ~/.local/share/nvim/plugged/YouCompleteMe/third_party/ycmd/ycm_core.so
when: vim_plugins_stdout.stdout_lines|length != 0 or true
tags:
- vim