From 8856ecd9ff98745c5f8beb1057a09dd89c49c8f0 Mon Sep 17 00:00:00 2001 From: Leo Maroni Date: Sun, 29 Mar 2020 23:25:17 +0200 Subject: [PATCH] Initial commit --- tasks/main.yml | 51 +++++++++++++++++++++++ templates/zshrc.j2 | 101 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 152 insertions(+) create mode 100644 tasks/main.yml create mode 100644 templates/zshrc.j2 diff --git a/tasks/main.yml b/tasks/main.yml new file mode 100644 index 0000000..0e615fc --- /dev/null +++ b/tasks/main.yml @@ -0,0 +1,51 @@ +- name: install dependencies + become: yes + package: + name: + - git + - zsh + state: present + +- name: clone oh-my-zsh for users + git: + repo: 'https://github.com/robbyrussell/oh-my-zsh.git' + dest: '~{{ user.username }}/.oh-my.zsh' + clone: yes + depth: 1 + become: yes + become_user: '{{ user.username }}' + when: user.oh_my_zsh is defined + with_items: "{{ users }}" + loop_control: + loop_var: user + +- name: set permissions of oh-my-zsh for users + file: + path: '~{{ user.username }}/.oh-my-zsh' + mode: 'go-w' + recurse: yes + when: user.oh_my_zsh is defined + with_items: "{{ users }}" + loop_control: + loop_var: user + +- name: set default shell for users + user: + name: '{{ user.username }}' + shell: /bin/zsh + when: user.oh_my_zsh is defined + with_items: "{{ users }}" + loop_control: + loop_var: user + +- name: write .zshrc for users + template: + src: zshrc.j2 + dest: '~{{ user.username }}/.zshrc' + backup: yes + mode: 'u=rw,go=r' + become_user: '{{ user.username }}' + when: user.oh_my_zsh is defined + with_items: "{{ users }}" + loop_control: + loop_var: user \ No newline at end of file diff --git a/templates/zshrc.j2 b/templates/zshrc.j2 new file mode 100644 index 0000000..179eb3d --- /dev/null +++ b/templates/zshrc.j2 @@ -0,0 +1,101 @@ +{{ ansible_managed | comment }} + +# If you come from bash you might have to change your $PATH. +# export PATH=$HOME/bin:/usr/local/bin:$PATH + +# Path to your oh-my-zsh installation. +export ZSH=$HOME/.oh-my-zsh + +# Set name of the theme to load --- if set to "random", it will +# load a random theme each time oh-my-zsh is loaded, in which case, +# to know which specific one was loaded, run: echo $RANDOM_THEME +# See https://github.com/robbyrussell/oh-my-zsh/wiki/Themes +ZSH_THEME="{{ user.oh_my_zsh.theme }}" + +# Set list of themes to pick from when loading at random +# Setting this variable when ZSH_THEME=random will cause zsh to load +# a theme from this variable instead of looking in ~/.oh-my-zsh/themes/ +# If set to an empty array, this variable will have no effect. +# ZSH_THEME_RANDOM_CANDIDATES=( "robbyrussell" "agnoster" ) + +# Uncomment the following line to use case-sensitive completion. +# CASE_SENSITIVE="true" + +# Uncomment the following line to use hyphen-insensitive completion. +# Case-sensitive completion must be off. _ and - will be interchangeable. +# HYPHEN_INSENSITIVE="true" + +# Uncomment the following line to disable bi-weekly auto-update checks. +DISABLE_AUTO_UPDATE="true" + +# Uncomment the following line to automatically update without prompting. +# DISABLE_UPDATE_PROMPT="true" + +# Uncomment the following line to change how often to auto-update (in days). +# export UPDATE_ZSH_DAYS=13 + +# Uncomment the following line if pasting URLs and other text is messed up. +# DISABLE_MAGIC_FUNCTIONS=true + +# Uncomment the following line to disable colors in ls. +# DISABLE_LS_COLORS="true" + +# Uncomment the following line to disable auto-setting terminal title. +# DISABLE_AUTO_TITLE="true" + +# Uncomment the following line to enable command auto-correction. +# ENABLE_CORRECTION="true" + +# Uncomment the following line to display red dots whilst waiting for completion. +# COMPLETION_WAITING_DOTS="true" + +# Uncomment the following line if you want to disable marking untracked files +# under VCS as dirty. This makes repository status check for large repositories +# much, much faster. +# DISABLE_UNTRACKED_FILES_DIRTY="true" + +# Uncomment the following line if you want to change the command execution time +# stamp shown in the history command output. +# You can set one of the optional three formats: +# "mm/dd/yyyy"|"dd.mm.yyyy"|"yyyy-mm-dd" +# or set a custom format using the strftime function format specifications, +# see 'man strftime' for details. +# HIST_STAMPS="mm/dd/yyyy" + +# Would you like to use another custom folder than $ZSH/custom? +# ZSH_CUSTOM=/path/to/new-custom-folder + +# Which plugins would you like to load? +# Standard plugins can be found in ~/.oh-my-zsh/plugins/* +# Custom plugins may be added to ~/.oh-my-zsh/custom/plugins/ +# Example format: plugins=(rails git textmate ruby lighthouse) +# Add wisely, as too many plugins slow down shell startup. +plugins=({{ user.oh_my_zsh.plugins | default('') | join(' ') }}) + +source $ZSH/oh-my-zsh.sh + +# User configuration + +# export MANPATH="/usr/local/man:$MANPATH" + +# You may need to manually set your language environment +# export LANG=en_US.UTF-8 + +# Preferred editor for local and remote sessions +# if [[ -n $SSH_CONNECTION ]]; then +# export EDITOR='vim' +# else +# export EDITOR='mvim' +# fi + +# Compilation flags +# export ARCHFLAGS="-arch x86_64" + +# Set personal aliases, overriding those provided by oh-my-zsh libs, +# plugins, and themes. Aliases can be placed here, though oh-my-zsh +# users are encouraged to define aliases within the ZSH_CUSTOM folder. +# For a full list of active aliases, run `alias`. +# +# Example aliases +# alias zshconfig="mate ~/.zshrc" +# alias ohmyzsh="mate ~/.oh-my-zsh"