Multi-user setup
This commit is contained in:
@@ -5,6 +5,10 @@ git_gpg_sign: true
|
|||||||
gpg_agent: true
|
gpg_agent: true
|
||||||
terminal_binary: urxvt256c
|
terminal_binary: urxvt256c
|
||||||
|
|
||||||
|
users:
|
||||||
|
- name: hannes
|
||||||
|
vt: 1
|
||||||
|
|
||||||
screen:
|
screen:
|
||||||
1: eDP-1
|
1: eDP-1
|
||||||
2: eDP-1
|
2: eDP-1
|
||||||
|
|||||||
@@ -5,6 +5,16 @@ git_gpg_sign: false
|
|||||||
gpg_agent: false
|
gpg_agent: false
|
||||||
terminal_binary: urxvt
|
terminal_binary: urxvt
|
||||||
|
|
||||||
|
users:
|
||||||
|
- name: hannes-work
|
||||||
|
group: hak
|
||||||
|
vt: 1
|
||||||
|
firefox_profiles:
|
||||||
|
- name: 3wmp9hdb.default-1565075150057
|
||||||
|
- name: hannes-private
|
||||||
|
group: tpp
|
||||||
|
vt: 2
|
||||||
|
|
||||||
screen:
|
screen:
|
||||||
1: DP-1-1
|
1: DP-1-1
|
||||||
2: DP-1-1
|
2: DP-1-1
|
||||||
|
|||||||
212
playbook.yml
212
playbook.yml
@@ -14,24 +14,6 @@
|
|||||||
tags:
|
tags:
|
||||||
- always
|
- always
|
||||||
|
|
||||||
- set_fact:
|
|
||||||
user: "{{ ansible_user_id }}"
|
|
||||||
tags:
|
|
||||||
- always
|
|
||||||
|
|
||||||
- name: configure sudoers
|
|
||||||
lineinfile:
|
|
||||||
path: /etc/sudoers
|
|
||||||
line: "{{ user }} ALL=(ALL) NOPASSWD:ALL"
|
|
||||||
regexp: "^{{ user }}\\s+"
|
|
||||||
become: true
|
|
||||||
|
|
||||||
- name: set shell
|
|
||||||
user:
|
|
||||||
name: "{{ user }}"
|
|
||||||
shell: /usr/bin/zsh
|
|
||||||
become: true
|
|
||||||
|
|
||||||
- name: install selinux specials on fedora
|
- name: install selinux specials on fedora
|
||||||
dnf:
|
dnf:
|
||||||
state: installed
|
state: installed
|
||||||
@@ -99,34 +81,6 @@
|
|||||||
- libvirtd
|
- libvirtd
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
- name: set groups for fedora
|
|
||||||
user:
|
|
||||||
name: "{{ user }}"
|
|
||||||
groups:
|
|
||||||
- libvirt
|
|
||||||
- wheel
|
|
||||||
- vboxusers
|
|
||||||
- wireshark
|
|
||||||
- docker
|
|
||||||
become: true
|
|
||||||
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'
|
|
||||||
|
|
||||||
- name: get systemd boot target
|
- name: get systemd boot target
|
||||||
command: systemctl get-default
|
command: systemctl get-default
|
||||||
register: systemd_target
|
register: systemd_target
|
||||||
@@ -154,162 +108,16 @@
|
|||||||
line: 'HandlePowerKey=suspend'
|
line: 'HandlePowerKey=suspend'
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
- name: create directory for getty autologin
|
- set_fact:
|
||||||
file:
|
users: "{{ machine.users }}"
|
||||||
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
|
|
||||||
|
|
||||||
- name: load dotfile list
|
|
||||||
include_vars:
|
|
||||||
file: dotfiles.yml
|
|
||||||
tags:
|
tags:
|
||||||
- dotfiles
|
- always
|
||||||
|
|
||||||
- name: get state of empty directories
|
- include_tasks: user.yml
|
||||||
stat:
|
|
||||||
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
|
|
||||||
|
|
||||||
- name: create empty directories for dotfiles
|
|
||||||
file:
|
|
||||||
state: directory
|
|
||||||
path: ~/{{ item.name }}
|
|
||||||
mode: "{{ item.mode | default('0755') }}"
|
|
||||||
with_items: "{{ empty_directories }}"
|
|
||||||
tags:
|
|
||||||
- dotfiles
|
|
||||||
|
|
||||||
- name: link this folder to ~/.dotfiles
|
|
||||||
file:
|
|
||||||
state: link
|
|
||||||
force: true
|
|
||||||
path: "{{ ansible_user_dir }}/.dotfiles"
|
|
||||||
src: "{{ playbook_dir }}"
|
|
||||||
tags:
|
|
||||||
- dotfiles
|
|
||||||
|
|
||||||
- name: link dotfiles
|
|
||||||
file:
|
|
||||||
state: link
|
|
||||||
force: true
|
|
||||||
path: "{{ ansible_user_dir }}/{{ item.to }}"
|
|
||||||
src: ~/.dotfiles/{{ item.from }}
|
|
||||||
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
|
|
||||||
|
|
||||||
- name: deploy dotfiles templates
|
|
||||||
template:
|
|
||||||
src: ~/.dotfiles/{{ item.from }}.j2
|
|
||||||
dest: "{{ ansible_user_dir }}/{{ item.to }}"
|
|
||||||
force: true
|
|
||||||
when: item.template|default(false)
|
|
||||||
with_items: "{{ dotfiles }}"
|
|
||||||
tags:
|
|
||||||
- dotfiles
|
|
||||||
|
|
||||||
- name: create directories
|
|
||||||
file:
|
|
||||||
state: directory
|
|
||||||
path: "{{ item }}"
|
|
||||||
with_items:
|
|
||||||
- ~/.var/lib
|
|
||||||
- ~/.var/log
|
|
||||||
- ~/.var/run
|
|
||||||
- ~/.usr/lib
|
|
||||||
|
|
||||||
- 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
|
|
||||||
tags:
|
|
||||||
- vim
|
|
||||||
|
|
||||||
- name: symlink vim-plug for neovim
|
|
||||||
file:
|
|
||||||
state: link
|
|
||||||
path: ~/.local/share/nvim/site/autoload/plug.vim
|
|
||||||
src: ~/.vim/autoload/plug.vim
|
|
||||||
force: true
|
|
||||||
tags:
|
|
||||||
- vim
|
|
||||||
|
|
||||||
- name: install vim plugins
|
|
||||||
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:
|
args:
|
||||||
creates: ~/.local/share/nvim/plugged/YouCompleteMe/third_party/ycmd/ycm_core.so
|
apply:
|
||||||
when: vim_plugins_stdout.stdout_lines|length != 0 or true
|
become: true
|
||||||
tags:
|
become_user: "{{ user.name }}"
|
||||||
- vim
|
with_items: "{{ users }}"
|
||||||
|
loop_control:
|
||||||
|
loop_var: user
|
||||||
|
|||||||
246
user.yml
Normal file
246
user.yml
Normal file
@@ -0,0 +1,246 @@
|
|||||||
|
- name: configure sudoers
|
||||||
|
lineinfile:
|
||||||
|
path: /etc/sudoers
|
||||||
|
line: "{{ user.name }} ALL=(ALL) NOPASSWD:ALL"
|
||||||
|
regexp: "^{{ user.name }}\\s+"
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
|
||||||
|
- name: set shell
|
||||||
|
user:
|
||||||
|
name: "{{ user.name }}"
|
||||||
|
shell: /usr/bin/zsh
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
|
||||||
|
- name: set groups for fedora
|
||||||
|
user:
|
||||||
|
name: "{{ user.name }}"
|
||||||
|
groups:
|
||||||
|
- libvirt
|
||||||
|
- wheel
|
||||||
|
- vboxusers
|
||||||
|
- wireshark
|
||||||
|
- docker
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
when: distro == 'fedora'
|
||||||
|
|
||||||
|
- name: set groups for ubuntu
|
||||||
|
user:
|
||||||
|
name: "{{ user.name }}"
|
||||||
|
groups:
|
||||||
|
- adm
|
||||||
|
- cdrom
|
||||||
|
- sudo
|
||||||
|
- dip
|
||||||
|
- plugdev
|
||||||
|
- lpadmin
|
||||||
|
- sambashare
|
||||||
|
- docker
|
||||||
|
- libvirt
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
when: distro == 'ubuntu'
|
||||||
|
|
||||||
|
- name: create directory for getty autologin
|
||||||
|
file:
|
||||||
|
state: directory
|
||||||
|
path: /etc/systemd/system/getty@tty{{ user.vt }}.service.d
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: '0755'
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
|
||||||
|
- name: enable getty autologin
|
||||||
|
copy:
|
||||||
|
dest: /etc/systemd/system/getty@tty{{ user.vt }}.service.d/override.conf
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: '0644'
|
||||||
|
content: |
|
||||||
|
[Service]
|
||||||
|
ExecStart=
|
||||||
|
ExecStart=-/sbin/agetty --autologin {{ user.name }} --noclear %I $TERM
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
|
||||||
|
- name: load dotfile list
|
||||||
|
include_vars:
|
||||||
|
file: dotfiles.yml
|
||||||
|
tags:
|
||||||
|
- dotfiles
|
||||||
|
|
||||||
|
- name: get state of empty directories
|
||||||
|
stat:
|
||||||
|
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
|
||||||
|
|
||||||
|
- name: create empty directories for dotfiles
|
||||||
|
file:
|
||||||
|
state: directory
|
||||||
|
path: ~/{{ item.name }}
|
||||||
|
mode: "{{ item.mode | default('0755') }}"
|
||||||
|
with_items: "{{ empty_directories }}"
|
||||||
|
tags:
|
||||||
|
- dotfiles
|
||||||
|
|
||||||
|
- name: link this folder to ~/.dotfiles
|
||||||
|
file:
|
||||||
|
state: link
|
||||||
|
force: true
|
||||||
|
owner: "{{ user.name }}"
|
||||||
|
group: "{{ user.group }}"
|
||||||
|
path: "/home/{{ user.name }}/.dotfiles"
|
||||||
|
src: "{{ playbook_dir }}"
|
||||||
|
tags:
|
||||||
|
- dotfiles
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
|
||||||
|
- name: link dotfiles
|
||||||
|
file:
|
||||||
|
state: link
|
||||||
|
force: true
|
||||||
|
owner: "{{ user.name }}"
|
||||||
|
group: "{{ user.group }}"
|
||||||
|
path: "/home/{{ user.name }}/{{ item.to }}"
|
||||||
|
src: /home/{{ user.name }}/.dotfiles/{{ item.from }}
|
||||||
|
when: not item.template|default(false)
|
||||||
|
with_items: "{{ dotfiles }}"
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
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
|
||||||
|
|
||||||
|
- name: deploy dotfiles templates
|
||||||
|
template:
|
||||||
|
src: ~/.dotfiles/{{ item.from }}.j2
|
||||||
|
dest: "/home/{{ user.name }}/{{ item.to }}"
|
||||||
|
owner: "{{ user.name }}"
|
||||||
|
group: "{{ user.group }}"
|
||||||
|
force: true
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
when: item.template|default(false)
|
||||||
|
with_items: "{{ dotfiles }}"
|
||||||
|
tags:
|
||||||
|
- dotfiles
|
||||||
|
|
||||||
|
- name: create directories
|
||||||
|
file:
|
||||||
|
state: directory
|
||||||
|
path: "{{ item }}"
|
||||||
|
with_items:
|
||||||
|
- ~/.var/lib
|
||||||
|
- ~/.var/log
|
||||||
|
- ~/.var/run
|
||||||
|
- ~/.usr/lib
|
||||||
|
|
||||||
|
- 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
|
||||||
|
tags:
|
||||||
|
- vim
|
||||||
|
|
||||||
|
- name: symlink vim-plug for neovim
|
||||||
|
file:
|
||||||
|
state: link
|
||||||
|
path: ~/.local/share/nvim/site/autoload/plug.vim
|
||||||
|
src: ~/.vim/autoload/plug.vim
|
||||||
|
force: true
|
||||||
|
tags:
|
||||||
|
- vim
|
||||||
|
|
||||||
|
- name: install vim plugins
|
||||||
|
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
|
||||||
|
|
||||||
|
- name: firefox - create chrome directory
|
||||||
|
file:
|
||||||
|
path: ~/.mozilla/firefox/{{ item.name }}/chrome/
|
||||||
|
state: directory
|
||||||
|
mode: '0755'
|
||||||
|
with_items: "{{ user.firefox_profiles }}"
|
||||||
|
when: user.firefox_profiles is defined
|
||||||
|
tags:
|
||||||
|
- firefox
|
||||||
|
|
||||||
|
- name: firefox - configure firefox custom css
|
||||||
|
copy:
|
||||||
|
dest: ~/.mozilla/firefox/{{ item.name }}/chrome/userChrome.css
|
||||||
|
content: |
|
||||||
|
#TabsToolbar {
|
||||||
|
visibility: collapse !important;
|
||||||
|
}
|
||||||
|
#titlebar {
|
||||||
|
visibility: collapse !important;
|
||||||
|
}
|
||||||
|
#sidebar-header {
|
||||||
|
visibility: collapse !important;
|
||||||
|
}
|
||||||
|
with_items: "{{ user.firefox_profiles }}"
|
||||||
|
when: user.firefox_profiles is defined
|
||||||
|
tags:
|
||||||
|
- firefox
|
||||||
@@ -47,7 +47,7 @@ umask 0022
|
|||||||
|
|
||||||
# exec startx breaks some logind fuckery, without exec it works
|
# exec startx breaks some logind fuckery, without exec it works
|
||||||
if [[ -z $DISPLAY ]] ; then
|
if [[ -z $DISPLAY ]] ; then
|
||||||
if (( $XDG_VTNR == 1 )) ; then
|
if (( $XDG_VTNR == {{ user.vt }} )) ; then
|
||||||
startx
|
startx
|
||||||
else
|
else
|
||||||
tmux new-session -A -s tmux-tty-$XDG_VTNR
|
tmux new-session -A -s tmux-tty-$XDG_VTNR
|
||||||
|
|||||||
Reference in New Issue
Block a user