Use global dotfiles directory
This commit is contained in:
16
playbook.yml
16
playbook.yml
@@ -108,6 +108,22 @@
|
|||||||
line: 'HandlePowerKey=suspend'
|
line: 'HandlePowerKey=suspend'
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
|
- name: create dotfiles group
|
||||||
|
group:
|
||||||
|
name: dotfiles
|
||||||
|
state: present
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
|
||||||
|
- name: create dotfiles directory
|
||||||
|
file:
|
||||||
|
state: directory
|
||||||
|
path: /var/lib/dotfiles
|
||||||
|
owner: nobody
|
||||||
|
group: dotfiles
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
|
||||||
- set_fact:
|
- set_fact:
|
||||||
users: "{{ machine.users }}"
|
users: "{{ machine.users }}"
|
||||||
tags:
|
tags:
|
||||||
|
|||||||
72
user.yml
72
user.yml
@@ -13,23 +13,8 @@
|
|||||||
become: true
|
become: true
|
||||||
become_user: root
|
become_user: root
|
||||||
|
|
||||||
- name: set groups for fedora
|
- set_fact:
|
||||||
user:
|
user_groups:
|
||||||
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
|
- adm
|
||||||
- cdrom
|
- cdrom
|
||||||
- sudo
|
- sudo
|
||||||
@@ -39,9 +24,30 @@
|
|||||||
- sambashare
|
- sambashare
|
||||||
- docker
|
- docker
|
||||||
- libvirt
|
- libvirt
|
||||||
|
when: distro == 'ubuntu'
|
||||||
|
|
||||||
|
- set_fact:
|
||||||
|
user_groups:
|
||||||
|
- libvirt
|
||||||
|
- wheel
|
||||||
|
- vboxusers
|
||||||
|
- wireshark
|
||||||
|
- docker
|
||||||
|
when: distro == 'fedora'
|
||||||
|
|
||||||
|
- name: create user group
|
||||||
|
group:
|
||||||
|
name: "{{ user.name }}"
|
||||||
|
state: present
|
||||||
|
become: true
|
||||||
|
become_user: root
|
||||||
|
|
||||||
|
- name: set groups
|
||||||
|
user:
|
||||||
|
name: "{{ user.name }}"
|
||||||
|
groups: "{{ [user.name, 'dotfiles'] + user_groups }}"
|
||||||
become: true
|
become: true
|
||||||
become_user: root
|
become_user: root
|
||||||
when: distro == 'ubuntu'
|
|
||||||
|
|
||||||
- name: create directory for getty autologin
|
- name: create directory for getty autologin
|
||||||
file:
|
file:
|
||||||
@@ -102,6 +108,7 @@
|
|||||||
file:
|
file:
|
||||||
state: link
|
state: link
|
||||||
force: true
|
force: true
|
||||||
|
follow: false
|
||||||
owner: "{{ user.name }}"
|
owner: "{{ user.name }}"
|
||||||
group: "{{ user.group }}"
|
group: "{{ user.group }}"
|
||||||
path: "/home/{{ user.name }}/.dotfiles"
|
path: "/home/{{ user.name }}/.dotfiles"
|
||||||
@@ -111,14 +118,37 @@
|
|||||||
become: true
|
become: true
|
||||||
become_user: root
|
become_user: root
|
||||||
|
|
||||||
|
- name: get state of copy targets
|
||||||
|
stat:
|
||||||
|
path: ~/{{ item.to }}
|
||||||
|
register: copy_stat
|
||||||
|
when: not item.template|default(false)
|
||||||
|
with_items: "{{ dotfiles }}"
|
||||||
|
tags:
|
||||||
|
- dotfiles
|
||||||
|
|
||||||
|
- name: remove invalid copy target (directories)
|
||||||
|
file:
|
||||||
|
path: "{{ item.stat.path }}"
|
||||||
|
state: absent
|
||||||
|
when:
|
||||||
|
- not item.skipped is defined or not item.skipped
|
||||||
|
- item.stat.exists
|
||||||
|
- item.stat.isdir
|
||||||
|
with_items: "{{ copy_stat.results }}"
|
||||||
|
tags:
|
||||||
|
- dotfiles
|
||||||
|
|
||||||
- name: link dotfiles
|
- name: link dotfiles
|
||||||
file:
|
file:
|
||||||
state: link
|
state: link
|
||||||
force: true
|
force: true
|
||||||
|
follow: false
|
||||||
|
path: "/home/{{ user.name }}/{{ item.to }}"
|
||||||
|
src: /var/lib/dotfiles/{{ item.from }}
|
||||||
owner: "{{ user.name }}"
|
owner: "{{ user.name }}"
|
||||||
group: "{{ user.group }}"
|
group: "{{ user.group }}"
|
||||||
path: "/home/{{ user.name }}/{{ item.to }}"
|
mode: "{{ item.mode | default('0644') }}"
|
||||||
src: /home/{{ user.name }}/.dotfiles/{{ item.from }}
|
|
||||||
when: not item.template|default(false)
|
when: not item.template|default(false)
|
||||||
with_items: "{{ dotfiles }}"
|
with_items: "{{ dotfiles }}"
|
||||||
become: true
|
become: true
|
||||||
@@ -149,7 +179,7 @@
|
|||||||
|
|
||||||
- name: deploy dotfiles templates
|
- name: deploy dotfiles templates
|
||||||
template:
|
template:
|
||||||
src: ~/.dotfiles/{{ item.from }}.j2
|
src: /home/{{ user.name }}/.dotfiles/{{ item.from }}.j2
|
||||||
dest: "/home/{{ user.name }}/{{ item.to }}"
|
dest: "/home/{{ user.name }}/{{ item.to }}"
|
||||||
owner: "{{ user.name }}"
|
owner: "{{ user.name }}"
|
||||||
group: "{{ user.group }}"
|
group: "{{ user.group }}"
|
||||||
|
|||||||
Reference in New Issue
Block a user