-
Notifications
You must be signed in to change notification settings - Fork 3
/
playbook.yaml
195 lines (178 loc) · 5.69 KB
/
playbook.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
---
# List of plays
-
# Hosts: where our play will run and options it will run with
hosts: localhost
connection: local
gather_facts: yes
tags: always
# Vars: variables that will apply to the play, on all targets
# Tasks: the list of tasks that will be executed within
# the play, this section can also be used for
# pre and post tasks
tasks:
# from https://superuser.com/questions/1395954/ansible-playbook-to-determine-os-release
- name: System details
debug: msg="{{ item }}"
with_items:
- "{{ ansible_distribution }}"
- "{{ ansible_distribution_version }}"
- "{{ ansible_distribution_major_version }}"
- name: Verify install_files is present
debug: msg="install_files/_README = {{ lookup('file', '/home/kasm-default-profile/install_files/_README') }}"
# Detect if we are running on a WSL2 environment
- name: Set wsl2_environment fact default to false
set_fact:
wsl2_environment: false
- name: Set wsl2_environment fact True
set_fact:
wsl2_environment: true
when: ansible_kernel is search("microsoft-standard-WSL2")
# fix for .gnupg/ permissions when building custom images
- name: Add fix for .gnupg/ permissions
lineinfile:
path: "/etc/bash.bashrc"
line: "chmod 700 ~/.gnupg/"
- name: Add custom prompt to /etc/skel/.profile
lineinfile:
path: "/etc/skel/.profile"
line: 'export PS1="\[\033[00;32m\][\w]\$\[\033[00m\] "'
# Handlers: the list of handlers that are executed as a notify
# key from a task
# Roles: list of roles to be imported into the play
roles:
- role: irixjp.role_example_hello
# Add additional plays here (remember the list entry -)
# Be sure to use the same hosts and connection entries above
# addtional plays
-
# install chrome
hosts: localhost
connection: local
gather_facts: yes
roles:
- role: webarchitect609.google_chrome
-
# install keychain and git
hosts: localhost
connection: local
gather_facts: yes
tags: install_git_keychain
vars:
git_version: "2.35.1"
git_version_to_install: "1:{{ git_version }}-0ppa1~ubuntu20.04.1"
keychain_version: "2.8.5"
keychain_version_to_install: "{{ keychain_version }}-1"
keychain_version_expected: "{{ keychain_version }}.."
tasks:
- name: Add git PPA
shell: add-apt-repository ppa:git-core/ppa
- name: Install git
apt:
name: "git={{ git_version_to_install }}"
- name: Install Keychain
apt:
name: "keychain={{ keychain_version_to_install }}"
update_cache: yes
- name: Get git version
shell: git version | sed 's/[[:alpha:]|(|[:space:]]//g'
register: installed_git_version
- name: Get keychain version
shell:
cmd: keychain -V 2> >(grep -i keychain) 2> >(sed 's/[[:alpha:]|(|[:space:]]//g') | fgrep '*' | sed 's/[*~://]//g'
executable: /bin/bash
register: installed_keychain_version
- name: Display git and keychain versions
debug:
msg: "git = {{ installed_git_version.stdout }} | keychain = {{ installed_keychain_version.stdout }}"
- name: Test git version
fail:
msg: "Git Version Error: Expected {{ git_version }} | Found {{ installed_git_version.stdout }}"
when: installed_git_version.stdout != git_version
- name: Test keychain version
fail:
msg: "Keychain Version Error: Expected {{ keychain_version_expected }} | Found {{ installed_keychain_version.stdout }}"
when: installed_keychain_version.stdout != keychain_version_expected
-
# install Python packages with pip
hosts: localhost
connection: local
gather_facts: yes
tasks:
- name: Update OS to point python to python3
apt:
name: python-is-python3
update_cache: yes
- name: Install python packages with pip
pip:
name:
- jupyterlab
- notebook
- voila
- pint
roles:
- role: geerlingguy.pip
-
# install sudo for the vs-code role below
hosts: localhost
connection: local
tasks:
- name: Install Sudo
apt:
name: sudo
update_cache: yes
- name: Preserve DONT_PROMPT_WSL_INSTALL in sudoers
lineinfile:
path: "/etc/sudoers"
line: "Defaults env_keep += \"DONT_PROMPT_WSL_INSTALL\""
when: wsl2_environment
-
# add dev user to give vs code somewhere to install extensions
hosts: localhost
connection: local
tasks:
- name: Add dev user
user:
name: dev
uid: 1001
-
# install the remainder of the tools
hosts: localhost
connection: local
environment:
DONT_PROMPT_WSL_INSTALL: 1
roles:
- role: gantsign.visual-studio-code
users:
- username: "dev"
visual_studio_code_extensions:
- ms-python.python
visual_studio_code_settings_overwrite: yes
visual_studio_code_settings: {
"extensions.ignoreRecommendations": true,
"update.mode": "none",
"extensions.autoUpdate": false,
"extensions.autoCheckUpdates": false,
"terminal.integrated.profiles.linux": {
"bash (login)": {
"path": "bash",
"args": ["-l"]
}
},
"terminal.integrated.defaultProfile.linux": "bash (login)"
}
-
# Copy VS Code changes to kasm-default-profile and lean up (remove) dev user now that vs code is installed
hosts: localhost
connection: local
tasks:
- name: Copy VS Code changes to kasm-default-profile
shell:
cmd: cp -r /home/dev/.config/Code/ /home/kasm-default-profile/.config/Code/ && cp -r /home/dev/.vscode/ /home/kasm-default-profile/.vscode/
- name: Remove dev user
user:
name: dev
state: absent
remove: yes
# Three dots indicate the end of a YAML document
...