diff options
| -rw-r--r-- | .config/fish/config.fish | 29 | ||||
| -rw-r--r-- | .config/fish/fishfile | 2 | ||||
| -rw-r--r-- | .config/i3status/config | 58 | ||||
| -rw-r--r-- | .config/radicale/config | 4 | ||||
| -rw-r--r-- | .config/sway/blue032 | 1 | ||||
| -rw-r--r-- | .config/sway/config | 69 | ||||
| -rw-r--r-- | .config/sway/defaults | 217 | ||||
| -rw-r--r-- | .config/sway/rock | 3 | ||||
| -rw-r--r-- | .config/systemd/user/radicale.service | 10 | ||||
| -rwxr-xr-x | .local/bin/kill-kube-ns | 48 | ||||
| -rw-r--r-- | .local/var/lib/radicale/README.md | 1 | ||||
| -rw-r--r-- | .profile | 44 | ||||
| -rw-r--r-- | .vimrc | 61 | ||||
| -rw-r--r-- | .zshrc | 49 |
14 files changed, 596 insertions, 0 deletions
diff --git a/.config/fish/config.fish b/.config/fish/config.fish new file mode 100644 index 0000000..1e54d8c --- /dev/null +++ b/.config/fish/config.fish @@ -0,0 +1,29 @@ +# https://reckoning.dev/fish-shell/ +set -g theme_powerline_fonts yes +set -g theme_nerd_fonts yes +set -g theme_display_git_stashed_verbose yes +set -g theme_display_git_master_branch yes +set -g theme_display_git_untracked yes +set -g theme_display_git_dirty yes +set -g theme_display_nvm yes +set -g theme_display_virtualenv yes +set -g theme_color_scheme zenburn + +fundle plugin 'edc/bass' +fundle plugin 'oh-my-fish/plugin-php' +fundle plugin 'danhper/fish-fastdir' +fundle plugin 'danhper/fish-theme-afowler' +fundle plugin 'oh-my-fish/theme-bobthefish' + +fundle init + +# set path. See https://github.com/fish-shell/fish-shell/issues/527 +set PATH ~/.cargo/bin $PATH +set PATH ~/.local/bin $PATH + +# Bootstrap fisher. See https://github.com/jorgebucaran/fisher +if not functions -q fisher + set -q XDG_CONFIG_HOME; or set XDG_CONFIG_HOME ~/.config + curl https://git.io/fisher --create-dirs -sLo $XDG_CONFIG_HOME/fish/functions/fisher.fish + fish -c fisher +end diff --git a/.config/fish/fishfile b/.config/fish/fishfile new file mode 100644 index 0000000..88abe6f --- /dev/null +++ b/.config/fish/fishfile @@ -0,0 +1,2 @@ +oh-my-fish/plugin-bang-bang +fishpkg/fish-prompt-mono diff --git a/.config/i3status/config b/.config/i3status/config new file mode 100644 index 0000000..36c8834 --- /dev/null +++ b/.config/i3status/config @@ -0,0 +1,58 @@ +# i3status configuration file. +# see "man i3status" for documentation. + +# It is important that this file is edited as UTF-8. +# The following line should contain a sharp s: +# ß +# If the above line is not correctly displayed, fix your editor first! + +general { + output_format = "i3bar" + colors = true + interval = 5 +} + +order += "ipv6" +order += "memory" +order += "disk /" +order += "wireless _first_" +#order += "ethernet _first_" +order += "battery 0" +order += "volume master" +order += "load" +order += "tztime local" +order += "tztime tehran" + +wireless _first_ { + format_up = "W: (%quality at %essid) %ip" + format_down = "W: down" +} + +ethernet _first_ { + # if you use %speed, i3status requires root privileges + format_up = "E: %ip (%speed)" + format_down = "E: down" +} + +battery 0 { + format = "%status %percentage %remaining %emptytime" + #path = "/sys/class/power_supply/rk-bat/uevent" + path = "/sys/class/power_supply/cw2015-battery/uevent" +} + +tztime local { + format = "%Y-%m-%d %H:%M:%S" +} + +tztime tehran { + format = "Teh:%H:%M" + timezone = "Asia/Tehran" +} + +load { + format = "%1min" +} + +disk "/" { + format = "%avail" +} diff --git a/.config/radicale/config b/.config/radicale/config new file mode 100644 index 0000000..454848d --- /dev/null +++ b/.config/radicale/config @@ -0,0 +1,4 @@ +[storage] +type = radicale_storage_decsync +filesystem_folder = ~/.local/var/lib/radicale/collections +decsync_dir = ~/.local/share/decsync diff --git a/.config/sway/blue032 b/.config/sway/blue032 new file mode 100644 index 0000000..812b029 --- /dev/null +++ b/.config/sway/blue032 @@ -0,0 +1 @@ +output eDP-1 pos 0 0 diff --git a/.config/sway/config b/.config/sway/config new file mode 100644 index 0000000..69c2727 --- /dev/null +++ b/.config/sway/config @@ -0,0 +1,69 @@ +include ./defaults + +### Variables +set $mod Mod4 +set $menu rofi -show run +#bemenu-run +set $term alacritty + +### Key Bindings +# I repeat them here to add `--to-code --no-warn` flag to make the bindings layout agnostic. +bindsym --to-code --no-warn { + $mod+$left focus left + $mod+$down focus down + $mod+$up focus up + $mod+$right focus right +} +bindsym --to-code --no-warn $mod+Return exec $term +bindsym --to-code --no-warn $mod+Shift+q kill +bindsym --to-code --no-warn $mod+d exec $menu +bindsym --to-code --no-warn $mod+Shift+c reload + +input * { + xkb_layout "de,ir" + xkb_options "lv3:caps_switch,grp:lctrl_lwin_toggle,shift:both_shiftlock" +} + +input type:touchpad { + tap disabled + natural_scroll enabled +} + +bar { + status_command i3status +} + +# Enable fzf-based floating app menu +#for_window [app_id="^launcher$"] floating enable, sticky enable, resize set 30 ppt 60 ppt, border pixel 10 +#set $menu exec $term --class=launcher -e sway-launcher-desktop +#bindsym --to-code --no-warn $mod+tab exec $menu + +# +# Multimedia keys - Courtesy of great Arch Linux wiki and its awesome users. +# +bindsym XF86AudioRaiseVolume exec pactl set-sink-volume @DEFAULT_SINK@ +5% +bindsym XF86AudioLowerVolume exec pactl set-sink-volume @DEFAULT_SINK@ -5% +bindsym XF86AudioMute exec pactl set-sink-mute @DEFAULT_SINK@ toggle +bindsym XF86AudioMicMute exec pactl set-source-mute @DEFAULT_SOURCE@ toggle +bindsym XF86MonBrightnessDown exec brightnessctl set 5%- +bindsym XF86MonBrightnessUp exec brightnessctl set +5% +bindsym XF86AudioPlay exec playerctl play-pause +bindsym XF86AudioNext exec playerctl next +bindsym XF86AudioPrev exec playerctl previous +bindsym XF86Search exec bemenu-run + +# +# Screen capture +# Thanks to Gentoo wiki at https://wiki.gentoo.org/wiki/Sway +# +set $ps1 Print +set $ps2 Control+Print +set $ps3 Alt+Print +set $ps4 Alt+Control+Print + +bindsym $ps1 exec grim - | wl-copy +bindsym $ps2 exec grim -g "$(slurp)" - | wl-copy +bindsym $ps3 exec grim $(xdg-user-dir PICTURES)/Screenshots/ps_$(date +"%Y%m%d%H%M%S").png +bindsym $ps4 exec grim -g "$(slurp)" $(xdg-user-dir PICTURES)/Screenshots/ps_$(date +"%Y%m%d%H%M%S").png + +include ~/.config/sway/`hostname` diff --git a/.config/sway/defaults b/.config/sway/defaults new file mode 100644 index 0000000..fa32210 --- /dev/null +++ b/.config/sway/defaults @@ -0,0 +1,217 @@ +# Default config for sway +# +# Copy this to ~/.config/sway/config and edit it to your liking. +# +# Read `man 5 sway` for a complete reference. + +### Variables +# +# Logo key. Use Mod1 for Alt. +set $mod Mod4 +# Home row direction keys, like vim +set $left h +set $down j +set $up k +set $right l +# Your preferred terminal emulator +set $term alacritty +# Your preferred application launcher +# Note: pass the final command to swaymsg so that the resulting window can be opened +# on the original workspace that the command was run on. +set $menu dmenu_path | dmenu | xargs swaymsg exec -- + +### Output configuration +# +# Default wallpaper (more resolutions are available in /usr/share/backgrounds/sway/) +output * bg /usr/share/backgrounds/sway/Sway_Wallpaper_Blue_1920x1080.png fill +# +# Example configuration: +# +# output HDMI-A-1 resolution 1920x1080 position 1920,0 +# +# You can get the names of your outputs by running: swaymsg -t get_outputs + +### Idle configuration +# +# Example configuration: +# +# exec swayidle -w \ +# timeout 300 'swaylock -f -c 000000' \ +# timeout 600 'swaymsg "output * dpms off"' resume 'swaymsg "output * dpms on"' \ +# before-sleep 'swaylock -f -c 000000' +# +# This will lock your screen after 300 seconds of inactivity, then turn off +# your displays after another 300 seconds, and turn your screens back on when +# resumed. It will also lock your screen before your computer goes to sleep. + +### Input configuration +# +# Example configuration: +# +# input "2:14:SynPS/2_Synaptics_TouchPad" { +# dwt enabled +# tap enabled +# natural_scroll enabled +# middle_emulation enabled +# } +# +# You can get the names of your inputs by running: swaymsg -t get_inputs +# Read `man 5 sway-input` for more information about this section. + +### Key bindings +# +# Basics: +# + # Start a terminal + bindsym --to-code $mod+Return exec $term + + # Kill focused window + bindsym --to-code $mod+Shift+q kill + + # Start your launcher + bindsym --to-code $mod+d exec $menu + + # Drag floating windows by holding down $mod and left mouse button. + # Resize them with right mouse button + $mod. + # Despite the name, also works for non-floating windows. + # Change normal to inverse to use left mouse button for resizing and right + # mouse button for dragging. + floating_modifier $mod normal + + # Reload the configuration file + bindsym --to-code $mod+Shift+c reload + + # Exit sway (logs you out of your Wayland session) + bindsym --to-code $mod+Shift+e exec swaynag -t warning -m 'You pressed the exit shortcut. Do you really want to exit sway? This will end your Wayland session.' -b 'Yes, exit sway' 'swaymsg exit' +# +# Moving around: +# + # Move your focus around + bindsym --to-code $mod+$left focus left + bindsym --to-code $mod+$down focus down + bindsym --to-code $mod+$up focus up + bindsym --to-code $mod+$right focus right + # Or use $mod+[up|down|left|right] + bindsym --to-code $mod+Left focus left + bindsym --to-code $mod+Down focus down + bindsym --to-code $mod+Up focus up + bindsym --to-code $mod+Right focus right + + # Move the focused window with the same, but add Shift + bindsym --to-code $mod+Shift+$left move left + bindsym --to-code $mod+Shift+$down move down + bindsym --to-code $mod+Shift+$up move up + bindsym --to-code $mod+Shift+$right move right + # Ditto, with arrow keys + bindsym --to-code $mod+Shift+Left move left + bindsym --to-code $mod+Shift+Down move down + bindsym --to-code $mod+Shift+Up move up + bindsym --to-code $mod+Shift+Right move right +# +# Workspaces: +# + # Switch to workspace + bindsym --to-code $mod+1 workspace number 1 + bindsym --to-code $mod+2 workspace number 2 + bindsym --to-code $mod+3 workspace number 3 + bindsym --to-code $mod+4 workspace number 4 + bindsym --to-code $mod+5 workspace number 5 + bindsym --to-code $mod+6 workspace number 6 + bindsym --to-code $mod+7 workspace number 7 + bindsym --to-code $mod+8 workspace number 8 + bindsym --to-code $mod+9 workspace number 9 + bindsym --to-code $mod+0 workspace number 10 + # Move focused container to workspace + bindsym --to-code $mod+Shift+1 move container to workspace number 1 + bindsym --to-code $mod+Shift+2 move container to workspace number 2 + bindsym --to-code $mod+Shift+3 move container to workspace number 3 + bindsym --to-code $mod+Shift+4 move container to workspace number 4 + bindsym --to-code $mod+Shift+5 move container to workspace number 5 + bindsym --to-code $mod+Shift+6 move container to workspace number 6 + bindsym --to-code $mod+Shift+7 move container to workspace number 7 + bindsym --to-code $mod+Shift+8 move container to workspace number 8 + bindsym --to-code $mod+Shift+9 move container to workspace number 9 + bindsym --to-code $mod+Shift+0 move container to workspace number 10 + # Note: workspaces can have any name you want, not just numbers. + # We just use 1-10 as the default. +# +# Layout stuff: +# + # You can "split" the current object of your focus with + # $mod+b or $mod+v, for horizontal and vertical splits + # respectively. + bindsym --to-code $mod+b splith + bindsym --to-code $mod+v splitv + + # Switch the current container between different layout styles + bindsym --to-code $mod+s layout stacking + bindsym --to-code $mod+w layout tabbed + bindsym --to-code $mod+e layout toggle split + + # Make the current focus fullscreen + bindsym --to-code $mod+f fullscreen + + # Toggle the current focus between tiling and floating mode + bindsym --to-code $mod+Shift+space floating toggle + + # Swap focus between the tiling area and the floating area + bindsym --to-code $mod+space focus mode_toggle + + # Move focus to the parent container + bindsym --to-code $mod+a focus parent +# +# Scratchpad: +# + # Sway has a "scratchpad", which is a bag of holding for windows. + # You can send windows there and get them back later. + + # Move the currently focused window to the scratchpad + bindsym --to-code $mod+Shift+minus move scratchpad + + # Show the next scratchpad window or hide the focused scratchpad window. + # If there are multiple scratchpad windows, this command cycles through them. + bindsym --to-code $mod+minus scratchpad show +# +# Resizing containers: +# +mode "resize" { + # left will shrink the containers width + # right will grow the containers width + # up will shrink the containers height + # down will grow the containers height + bindsym --to-code $left resize shrink width 10px + bindsym --to-code $down resize grow height 10px + bindsym --to-code $up resize shrink height 10px + bindsym --to-code $right resize grow width 10px + + # Ditto, with arrow keys + bindsym --to-code Left resize shrink width 10px + bindsym --to-code Down resize grow height 10px + bindsym --to-code Up resize shrink height 10px + bindsym --to-code Right resize grow width 10px + + # Return to default mode + bindsym --to-code Return mode "default" + bindsym --to-code Escape mode "default" +} +bindsym --to-code $mod+r mode "resize" + +# +# Status Bar: +# +# Read `man 5 sway-bar` for more information about this section. +bar { + position top + + # When the status_command prints a new line to stdout, swaybar updates. + # The default just shows the current date and time. + status_command while date +'%Y-%m-%d %l:%M:%S %p'; do sleep 1; done + + colors { + statusline #ffffff + background #323232 + inactive_workspace #32323200 #32323200 #5c5c5c + } +} + +include /etc/sway/config.d/* diff --git a/.config/sway/rock b/.config/sway/rock new file mode 100644 index 0000000..27956d7 --- /dev/null +++ b/.config/sway/rock @@ -0,0 +1,3 @@ +set $menu bemenu-run +set $term termite + diff --git a/.config/systemd/user/radicale.service b/.config/systemd/user/radicale.service new file mode 100644 index 0000000..92efe26 --- /dev/null +++ b/.config/systemd/user/radicale.service @@ -0,0 +1,10 @@ +# See https://radicale.org/2.1.html#documentation/basic-setup/running-as-a-service/linux-with-systemd-as-a-user +[Unit] +Description=A simple CalDAV (calendar) and CardDAV (contact) server + +[Service] +ExecStart=/usr/bin/env python3 -m radicale +Restart=on-failure + +[Install] +WantedBy=default.target diff --git a/.local/bin/kill-kube-ns b/.local/bin/kill-kube-ns new file mode 100755 index 0000000..6fc9cc0 --- /dev/null +++ b/.local/bin/kill-kube-ns @@ -0,0 +1,48 @@ +#!/bin/bash + +############################################################################### +# Copyright (c) 2018 Red Hat Inc +# +# See the NOTICE file(s) distributed with this work for additional +# information regarding copyright ownership. +# +# This program and the accompanying materials are made available under the +# terms of the Eclipse Public License 2.0 which is available at +# http://www.eclipse.org/legal/epl-2.0 +# +# SPDX-License-Identifier: EPL-2.0 +############################################################################### + +set -eo pipefail + +die() { echo "$*" 1>&2 ; exit 1; } + +need() { + which "$1" &>/dev/null || die "Binary '$1' is missing but required" +} + +# checking pre-reqs + +need "jq" +need "curl" +need "kubectl" + +PROJECT="$1" +shift + +test -n "$PROJECT" || die "Missing arguments: kill-ns <namespace>" + +kubectl proxy &>/dev/null & +PROXY_PID=$! +killproxy () { + kill $PROXY_PID +} +trap killproxy EXIT + +sleep 1 # give the proxy a second + +kubectl get namespace "$PROJECT" -o json | jq 'del(.spec.finalizers[] | select("kubernetes"))' | curl -s -k -H "Content-Type: application/json" -X PUT -o /dev/null --data-binary @- http://localhost:8001/api/v1/namespaces/$PROJECT/finalize && echo "Killed namespace: $PROJECT" + +# proxy will get killed by the trap + + diff --git a/.local/var/lib/radicale/README.md b/.local/var/lib/radicale/README.md new file mode 100644 index 0000000..3ff9441 --- /dev/null +++ b/.local/var/lib/radicale/README.md @@ -0,0 +1 @@ +This is a place holder to be able to add this directory to git. diff --git a/.profile b/.profile new file mode 100644 index 0000000..38c74f0 --- /dev/null +++ b/.profile @@ -0,0 +1,44 @@ +# Generic +export LANG=en_US.UTF-8 +export EDITOR=vim +export TIMER_FORMAT='%d' +export TIMER_PRECISION=2 + +# Main shadow bin directory +export PATH=$HOME/.local/bin:$PATH + +# Other bin directories +export PATH=$HOME/.local/bin/`hostname`:$PATH +export PATH=$HOME/.cargo/bin:$PATH +export PATH=$HOME/.yarn/bin:$PATH + +# Go +export GOPATH="$HOME/.go" +export PATH=$GOPATH/bin:$PATH + +export ANDROID_SDK_ROOT=$HOME/Android/Sdk + +# Building +export MAKEFLAGS=-j`lscpu | grep '^CPU(s):' | awk -F' ' '{ print $2 }'` +export CFLAGS="-O2 -pipe -march=native" +export CXXFLAGS="${CFLAGS}" + +# Sway compatiblity +if [ "$XDG_SESSION_DESKTOP" = "sway" ] ; then + # https://github.com/swaywm/sway/issues/595 + export _JAVA_AWT_WM_NONREPARENTING=1 +fi + +# 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" + +# ssh +# export SSH_KEY_PATH="~/.ssh/rsa_id" + @@ -0,0 +1,61 @@ +set nocompatible " required +filetype off " required + +" set the runtime path to include Vundle and initialize +set rtp+=~/.vim/bundle/Vundle.vim +call vundle#begin() + +" alternatively, pass a path where Vundle should install plugins +"call vundle#begin('~/some/path/here') + +" let Vundle manage Vundle, required +Plugin 'gmarik/Vundle.vim' + +" add all your plugins here (note older versions of Vundle +" used Bundle instead of Plugin) + +Plugin 'vim-syntastic/syntastic' +Plugin 'vim-airline/vim-airline' +Plugin 'vim-airline/vim-airline-themes' +Plugin 'nvie/vim-flake8' +Plugin 'scrooloose/nerdtree' +Plugin 'kien/ctrlp.vim' +Plugin 'rust-lang/rust.vim' +Plugin 'racer-rust/vim-racer' +Plugin 'ConradIrwin/vim-bracketed-paste' +"Bundle 'Valloric/YouCompleteMe' +Plugin 'junegunn/fzf' +" Save the buffer whenever text is changed. +" https://stackoverflow.com/a/55761306 +" autocmd TextChanged,TextChangedI <buffer> silent write + + +" All of your Plugins must be added before the following line +call vundle#end() " required +filetype plugin indent on " required + +let python_highlight_all=1 +let g:airline_theme='wombat' +set encoding=utf-8 +set mouse-=a +syntax on + +"split navigations +nnoremap <C-J> <C-W><C-J> +nnoremap <C-K> <C-W><C-K> +nnoremap <C-L> <C-W><C-L> +nnoremap <C-H> <C-W><C-H> + +au BufNewFile,BufRead *.py + \ set tabstop=4 | + \ set softtabstop=4 | + \ set shiftwidth=4 | + \ set textwidth=79 | + \ set expandtab | + \ set autoindent | + \ set fileformat=unix + +"au BufRead,BufNewFile *.py,*.pyw,*.c,*.h match BadWhitespace /\s\+$/ +let NERDTreeIgnore=['\.pyc$', '\~$'] "ignore files in NERDTree +map <C-n> :NERDTreeToggle<CR> + @@ -0,0 +1,49 @@ +# Path to your oh-my-zsh installation. +if [ ! -d "/usr/share/oh-my-zsh" ]; then + export ZSH=$HOME/.oh-my-zsh +else + export ZSH="/usr/share/oh-my-zsh" +fi + +# simple, frisk, mrtazz, lambda, maran, robbyrussel, random +ZSH_THEME=simple + +# Uncomment the following line to use case-sensitive completion. +CASE_SENSITIVE="false" + +# HYPHEN_INSENSITIVE="true" +DISABLE_AUTO_UPDATE="true" + +# Standard plugins can be found in ~/.oh-my-zsh/plugins/* +# Custom plugins may be added to ~/.oh-my-zsh/custom/plugins/ +plugins=(git autojump history-substring-search)# timer gem rust cargo) + +# Activate oh-my-zsh +source $ZSH/oh-my-zsh.sh + +_direnv_hook() { + eval "$("/usr/bin/direnv" export zsh)"; +} +typeset -ag precmd_functions; +if [[ -z ${precmd_functions[(r)_direnv_hook]} ]]; then + precmd_functions+=_direnv_hook; +fi + +# nvm settings (good) +#export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")" +#[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm + +if [[ -a `which kubectl` ]]; then + source <(kubectl completion zsh 2> /dev/null); +fi + +# For X.org +#setxkbmap \ +# -layout de,ir \ +# -variant nodeadkeys,pes_keypad \ +# -option '' \ +# -option 'grp:alt_shift_toggle' \ +# -option 'shift:both_shiftlock' \ +# -option 'lv3:caps_switch' \ +# -option 'terminate:ctrl_alt_bkspc' \ +# -option 'eurosign:e' |
