Compare commits

..

No commits in common. "de2043de66c9e26bc0e8e5e7a6d63aa05d0583c3" and "e8054149ceb21d4bbe2fb238186d05c589e33983" have entirely different histories.

19 changed files with 633 additions and 931 deletions

View File

@ -1,46 +1,3 @@
*foreground: gray90 Xft.dpi: 180
*background: black Xft.autohint: 1
Xft.antialias: 1
! XTerm
! /usr/share/X11/app-defaults/XTerm{,-color}
! FIXME *XTerm*font: 9x15
*XTerm*saveLines: 10000
*XTerm*HiForeColor: white
*XTerm*HiBackColor: #c06077
! FIMXE xterm*font: *-fixed-*-*-*-18-*
! from https://ubuntuplace.info/questions/819/comment-changer-la-taille-de-police-par-defaut-de-xterm
! change size with <ctrl>+<+> and <ctrl>+<->
!FIXME *XTerm*VT100.translations: #override \n\
! Ctrl <Key> minus: smaller-vt-font() \n\
! Ctrl <Key> plus: larger-vt-font()
! from https://wiki.archlinux.org/index.php/Color_output_in_console#Terminal_emulators
! Black + DarkGrey
*color0: #000000
*color8: #555753
! ! DarkRed + Red
*color1: #ff6565
*color9: #ff8d8d
! ! DarkGreen + Green
*color2: #93d44f
*color10: #c8e7a8
! ! DarkYellow + Yellow
*color3: #eab93d
*color11: #ffc123
! ! DarkBlue + Blue
*color4: #204a87
*color12: #3465a4
! ! DarkMagenta + Magenta
*color5: #ce5c00
*color13: #f57900
! !DarkCyan + Cyan (both not tango)
*color6: #89b6e2
*color14: #46a4ff
! ! LightGrey + White
*color7: #cccccc
*color15: #ffffff

View File

@ -1,81 +1,51 @@
# .bash_aliases # .bash_aliases
# (c) pcht 199x - 2019 # (c) pcht 199x - 2019
alias ls='ls --color' alias ls='ls -F --color'
alias l='ls -lh' alias l='ls -lh'
alias la='ls -Alh'
alias lt='ls -lrt'
alias d='ls -al | egrep ^d' alias d='ls -al | egrep ^d'
alias dl='ls -al | grep -E "^[d|l]"' alias dl='ls -al | egrep "^[d|l]"'
alias ll='ls -al | grep -E ^l' alias ll='ls -alh'
alias h=history alias h=history
alias td='todo -c --force-colour --filter -done,+children | less -r' alias td='todo -c --force-colour --filter -done,+children | less -r'
alias tdall='todo --force-colour -A|less -r' alias tdall='todo --force-colour -A|less -r'
alias o=xdg-open
alias pp='python -mjson.tool' alias pp='python -mjson.tool'
alias cd='cd -P' alias cd='cd -P'
alias x='chmod +x' alias tm=tmux
alias nx='chmod -x' alias tma='tmux attach'
alias m=make alias tmn='tmux new'
# setfont
alias f32='setfont /usr/share/kbd/consolefonts/latarcyrheb-sun32.psfu.gz'
# clavier
alias us='setxkbmap -layout us,us -variant ,intl -option grp:rctrl_rshift_toggle'
# raccourcis # raccourcis
alias vmc='vim ~/.mailcap' alias vmc='vim ~/.mailcap'
# ldap
alias lds=ldapsearch_dalembert
# bash # bash
alias sa='source ~/.bash_aliases' alias sa='source ~/.bash_aliases'
alias va='vim ~/.bash_aliases' alias va='vim ~/.bash_aliases'
alias sb='source ~/.bashrc'
alias vb='vim ~/.bashrc' alias vb='vim ~/.bashrc'
# dirs # dirs
alias cb='cd ~/bin' alias cb='cd ~/bin'
alias cdoc='cd ~/docs-braque' alias cdoc='cd ~/docs/docs-braque'
alias cdot='cd ~/dotfiles' alias cdot='cd ~/dotfiles'
alias csrc='cd ~/src' alias csrc='cd ~/src'
alias csuck='cd ~/src/suckless/' alias csuck='cd ~/src/suckless/'
alias cmpv='cd ~/.config/mpv' alias cdev='cd ~/devel'
alias cserv='cd ~/services'
# symblinks
# find all symblink what link to $1
alias revln='find . -xdev -type l -exec echo -n "{} -> " \; -exec readlink {} \; 2>/dev/null | grep'
# run-mailcap
# alias see=run-mailcap
# alias seed='run-mailcap --norun --debug'
alias edit='run-mailcap --action=edit'
alias lf='/bin/ls -rt1|tail -1'
alias slf='run-mailcap "$(/bin/ls -rt1|tail -1)"'
alias vlf='edit "$(/usr/bin/ls -rt1|tail -1)"'
# vim
alias vr='vim ~/.vimrc'
alias vi=vim
# irssi # irssi
alias irssi='TERM=tmux irssi'
alias vic='vim ~/.irssi/config' alias vic='vim ~/.irssi/config'
# mutt # mutt
alias cm='cd ~/.mutt' alias cm='cd ~/.mutt'
alias vm='vim ~/.mutt/muttrc' alias vm='vim ~/.mutt/muttrc'
alias vma='vim ~/.mutt/muttrc-alias' alias vma='vim ~/.mutt/alias'
alias ou='offlineimap -a upmc'
alias og='offlineimap -a gmail'
# w3m # w3m
alias cw='cd ~/.w3m'
alias vw='vim ~/.w3m/config' alias vw='vim ~/.w3m/config'
alias wb='w3m -B'
# fzf
alias vf='vim $(fzf --preview="head -$LINES {}")'
alias of='xdg-open "$(fzf --preview="head -$LINES {}")"'
#newsboat #newsboat
alias nb=newsboat alias nb=newsboat
@ -84,73 +54,8 @@ alias vnbu='vim ~/.newsboat/urls'
alias vnbc='vim ~/.newsboat/config' alias vnbc='vim ~/.newsboat/config'
#gcalcli #gcalcli
# alias gcm='gcalcli --calendar Weather agenda' alias gcm='gcalcli --calendar Weather agenda'
# alias gca='gcalcli agenda --military' alias gca='gcalcli agenda --military'
# alias gcall='gcalcli --calendar travail --calendar ecoles --calendar agenda --calendar CGT calw --military' alias gcall='gcalcli --calendar travail --calendar ecoles --calendar agenda --calendar CGT calw --military'
# mpv
alias vmpv='vim ~/.config/mpv/mpv.conf'
alias vmpvi='vim ~/.config/mpv/input.conf'
# systemctl user
alias sd='sudo systemctl'
alias sdu='systemctl --user'
# kubectl
alias k=kubectl
alias ka='kubectl api-resources'
alias kaf='kubectl apply -f'
alias kg='kubectl get'
alias kgn='kubectl get no'
alias kgp='kubectl get po'
alias kgd='kubectl get deploy'
alias kgs='kubectl get svc'
alias v=vagrant
alias vu='vagrant up'
alias vd='vagrant destroy'
# ssh
alias leger='ssh leger'
alias vs='vim ~/.ssh/config'
# alias chagall='ssh root@chagall'
# alias dhcpd='ssh root@dhcpd'
# alias heyward='ssh root@heyward'
# alias heywood='ssh root@heywood'
# alias manet='ssh root@manet'
# alias modemeca='ssh root@modemeca'
# alias poisson='ssh root@poisson'
# alias saturne='ssh root@saturne'
# alias uranus='ssh root@uranus'
# alias vauban='ssh root@vauban'
# alias americo='ssh root@americo'
# alias ivo='ssh root@ivo'
# alias mabe='ssh root@chagall'
# alias proxy='ssh root@proxy'
# tools
alias ccze='ccze -A'
alias youtube-dl=yt-dlp
# starship.rs
alias vss='vi ~/.config/starship.toml'
# go
alias gt="go test | _gotestcolored"
alias gtv="go test -v | _gotestcolored"
# go buffalo
# alias bt='buffalo test | _gotestcolored'
# alias btv='buffalo test -v | _gotestcolored | less'
# force no caching in test with -count=1
alias bt="go test -p 1 -tags test subscribe subscribe/actions subscribe/grifts subscribe/mailers"
alias btv='bt -v | _gotestcolored | less '
alias pm='sudo pacman'
# end .bash_aliases # end .bash_aliases

View File

@ -1,72 +1,24 @@
echo ">> .bash_profile" echo ">> .bash_profile"
# PATH must be in .bash_profile
# but I put all in .bashrc
## rust cargo ## rust cargo
# test -d $HOME/.cargo/bin && PATH="$HOME/.cargo/bin:$PATH" test -d HOME/.cargo/bin && PATH="$HOME/.cargo/bin:$PATH"
## nodejs ## nodejs
# test -d $HOME/.local_node/bin && PATH="$HOME/.local_node/bin:$PATH" test -d ~/.local_node/bin && PATH="$HOME/.local_node/bin:$PATH"
# # golang env # golang env
# export PATH=$PATH:$HOME/go/bin export GOPATH=/home/patrick/devel/golang
# export GOPATH=/home/patrick/devel/golang PATH="$GOPATH/bin:$PATH" ## bin installed from `go install`
# PATH="$GOPATH/bin:$PATH" ## bin installed from `go install` PATH="/home/patrick/src/golang/go/bin:$PATH" ## install from binaries
# PATH="/home/patrick/src/golang/go/bin:$PATH" ## install from binaries
# rvm # rvm
#[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm" # Load RVM into a shell session *as a function* #[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm" # Load RVM into a shell session *as a function*
# nix # nix
# if [ -e /home/patrick/.nix-profile/etc/profile.d/nix.sh ]; then . /home/patrick/.nix-profile/etc/profile.d/nix.sh; fi # added by Nix installer if [ -e /home/patrick/.nix-profile/etc/profile.d/nix.sh ]; then . /home/patrick/.nix-profile/etc/profile.d/nix.sh; fi # added by Nix installer
# ssh agent test -s $HOME/.bashrc && source $HOME/.bashrc
# use one agent for all connection
# https://unix.stackexchange.com/questions/132065/how-do-i-get-ssh-agent-to-work-in-all-terminals
# FIXME: interfer w/ ssh -A
# echo " .bash_profile: play with ssh-agent" export PATH=".:$HOME/bin:$HOME/.local/bin:$PATH"
# if test "x$SSH_AUTH_SOCK" = x
# then
# echo "SSH_AUTH_SOCK no set"
# export SSH_AUTH_SOCK=~/.ssh/ssh_auth_sock
#
# export SSH_AUTH_SOCK=~/.ssh/ssh-agent.$HOSTNAME.~/.ssh/ssh_auth_sock
# ssh-add -l 2>/dev/null >/dev/null
# err=$?
# if [ $err -ge 2 ]; then
# echo " .bash_profile ssh-add with error: $err"
# test -f "$SSH_AUTH_SOCK" && rm -f "$SSH_AUTH_SOCK"
# ssh-agent -a "$SSH_AUTH_SOCK" >/dev/null
# fi
# unset err
# else
# echo "SSH_AUTH_SOCK already set !!"
# echo "SSH_AUTH_SOCK=$SSH_AUTH_SOCK"
# fi
# test ssh-agent
# echo " .bash_profile: play with ssh-agent"
# export SSH_AUTH_SOCK=~/.ssh/ssh-agent.$HOSTNAME.sock
# ssh-add -l 2>/dev/null >/dev/null
# err=$?
# if [ $err -ge 2 ]; then
# echo " .bash_profile ssh-add with error: $err"
# test -f "$SSH_AUTH_SOCK" && rm -f "$SSH_AUTH_SOCK"
# ssh-agent -a "$SSH_AUTH_SOCK" >/dev/null
# else
# echo " all ok"
# fi
# unset err
# enable PATH in system-user context
#systemctl --user import-environment PATH
# test -f "$HOME/.bash_aliases" && source "$HOME/.bash_aliases"
# no .bashrc here
test -e "$HOME/.bashrc" && source "$HOME/.bashrc"
echo "<< .bash_profile" echo "<< .bash_profile"

View File

@ -84,12 +84,8 @@ function prompt_func() {
#The lowercase w is the full current working directory #The lowercase w is the full current working directory
# prompt="${TITLEBAR}${BLUE}[${RED}\w${GREEN}$(_my_parse_git_branch)${BLUE}]${COLOR_NONE}" # prompt="${TITLEBAR}${BLUE}[${RED}\w${GREEN}$(_my_parse_git_branch)${BLUE}]${COLOR_NONE}"
# newgrp terraform
local psnewgrp=''
test "`id -ng`" != "`id -nu`" && psnewgrp="${LIGHT_GREEN}(`id -ng`)"
# [user$host] # [user$host]
prompt="${prompt}${COLOR_NONE}[${YELLOW}\u${psnewgrp}${COLOR_NONE}@${WHITE}\h${COLOR_NONE}]" prompt="${prompt}${COLOR_NONE}[${YELLOW}\u${COLOR_NONE}@${WHITE}\h${COLOR_NONE}]"
# python virtualenv # python virtualenv
test -n "$VIRTUAL_ENV" && prompt="${prompt} (env:${BLUE}$(basename $VIRTUAL_ENV)${COLOR_NONE})" test -n "$VIRTUAL_ENV" && prompt="${prompt} (env:${BLUE}$(basename $VIRTUAL_ENV)${COLOR_NONE})"
@ -115,6 +111,13 @@ function prompt_func() {
# prompt="${prompt} \w" # prompt="${prompt} \w"
prompt="${prompt} $(short_path "$PWD")" prompt="${prompt} $(short_path "$PWD")"
# if test $previous_return_value -eq 0
# then
# PS1="${prompt} ${GREEN}\$${COLOR_NONE} "
# else
# PS1="${prompt} ${RED}(err=${previous_return_value}) \$${COLOR_NONE} "
# fi
# test right align FIXME # test right align FIXME
# PS1=$(printf "%${COLUMNS}s \r%s" "${prompt}" "${GREEN}\$${COLOR_NONE} ") # PS1=$(printf "%${COLUMNS}s \r%s" "${prompt}" "${GREEN}\$${COLOR_NONE} ")

535
.bashrc
View File

@ -1,14 +1,15 @@
#!/bin/bash
# shellcheck disable=SC1090
# .bashrc bash start script # .bashrc bash start script
# (c) Pcht 2007-2020 # (c) Pcht 2007-2018
# may work on multiple hosts with different OS (Debian, Arch)
#
# If not running interactively, don't do anything # If not running interactively, don't do anything
[ -z "$PS1" ] && return [ -z "$PS1" ] && return
echo ">> .bashrc" echo ">> .bashrc"
export LANG=en_US.UTF-8 # autocheck local mail
export MAIL=/var/mail/$USER
export MAILCHECK=30
export LANG=fr_FR.UTF-8
# history : don't put duplicate lines in the history. Ignore line begin with space # history : don't put duplicate lines in the history. Ignore line begin with space
export HISTCONTROL=ignoredups:ignorespace export HISTCONTROL=ignoredups:ignorespace
@ -29,524 +30,86 @@ shopt -s autocd
# make less more friendly for non-text input files, see lesspipe(1) # make less more friendly for non-text input files, see lesspipe(1)
[ -x /usr/bin/lesspipe ] && eval "$(lesspipe)" [ -x /usr/bin/lesspipe ] && eval "$(lesspipe)"
# LESS options # from http://thesmithfam.org/blog/2009/01/06/best-bash-prompt-ever/#comments
export LESS="-FRX" # color change with $? result
BLACK="\[\033[0;30m\]"
DARK_GRAY="\[\033[1;30m\]"
LIGHT_GRAY="\[\033[0;37m\]"
BLUE="\[\033[0;34m\]"
LIGHT_BLUE="\[\033[1;34m\]"
GREEN="\[\033[0;32m\]"
LIGHT_GREEN="\[\033[1;32m\]"
CYAN="\[\033[0;36m\]"
LIGHT_CYAN="\[\033[1;36m\]"
RED="\[\033[0;31m\]"
LIGHT_RED="\[\033[1;31m\]"
PURPLE="\[\033[0;35m\]"
LIGHT_PURPLE="\[\033[1;35m\]"
BROWN="\[\033[0;33m\]"
YELLOW="\[\033[1;33m\]"
WHITE="\[\033[1;37m\]"
DEFAULT_COLOR="\[\033[00m\]"
# very basic prompt -- more in .bash_prompt # very basic prompt -- more in .bash_prompt
PROMPT_COMMAND='PS1="[\u@\h] -- \w "; echo -ne "\033]0;${USER}@${HOSTNAME}: ${PWD/$HOME/~}\007"' PROMPT_COMMAND='PS1="[\u@\h] -- \w "; echo -ne "\033]0;${USER}@${HOSTNAME}: ${PWD/$HOME/~}\007"'
# I love google-chrome :) # I love google-chrome :)
# export BROWSER=google-chrome # export BROWSER=google-chrome
# FIXME just do it once
# xdg-settings set default-web-browser google-chrome.desktop
# but w3m is lighter # but w3m is lighter
export BROWSER=w3m export BROWSER=w3m
# ... and vim is the Best # ... and vim
export EDITOR=vim export EDITOR=vim
# very min bash aliases # very min bash aliases
alias ls='ls -F --color' alias ls='ls -F --color'
alias l='ls -l' alias l='ls -l'
alias ll='ls -al' alias ll='ls -al'
alias wa='ssh warhol'
# ### dotfiles stuff
# bash stuff test -f ~/dotfiles/.bash_aliases && source ~/dotfiles/.bash_aliases
# test -f ~/dotfiles/.bash_prompt && source ~/dotfiles/.bash_prompt
test -f ~/.bash_aliases && source ~/.bash_aliases
test -f ~/.bash_prompt && source ~/.bash_prompt
# shellcheck disable=SC2046
test -f ~/.dircolors && eval $(dircolors ~/.dircolors)
test -d ~/dotfiles/bash_completion && { test -d ~/dotfiles/bash_completion && {
for f in ~/dotfiles/bash_completion/*.bash; for f in ~/dotfiles/bash_completion/*.bash;
do do source $f;
# echo "BASH completion $f"
source "$f"
done; done;
} }
# To create the file: dircolors -p
# startship test -f ~/dotfiles/.dircolors && eval "`dircolors ~/dotfiles/.dircolors`"
# https://starship.rs/
type -t starship >/dev/null && {
eval "$(starship init bash)"
eval "$(starship completions bash)"
}
#==-- archlinux --==#
# command not find
# shellcheck disable=SC1091
test -f /usr/share/doc/pkgfile/command-not-found.bash && source /usr/share/doc/pkgfile/command-not-found.bash
### .local stuffs ### .local stuffs
# manpath # manpath
export MANPATH=$HOME/.local/share/man: export MANPATH=$HOME/.local/share/man:
# path for updatedn / locate
# export LOCATE_PATH=$HOME/.local/share/locate
# test -d "$LOCATE_PATH" || mkdir -p "$LOCATE_PATH"
# added by Nix installer # added by Nix installer
# od it in .bash_profile if [ -e /home/patrick/.nix-profile/etc/profile.d/nix.sh ]; then . /home/patrick/.nix-profile/etc/profile.d/nix.sh; fi # od it in .bash_profile if [ -e /home/patrick/.nix-profile/etc/profile.d/nix.sh ]; then . /home/patrick/.nix-profile/etc/profile.d/nix.sh; fi
# tmux dirty hack : TERM and SSH_AGENT_PID # autolaunch tmux
test -n "$TMUX" && export TERM="xterm-256color" # https://wiki.archlinux.org/index.php/Tmux#Bash
# test $- != *i* && return
# test -z "$TMUX" -a "$TERM" == "st-256color" && {
# test -n "$(tmux ls 2>/dev/null)" && exec tmux attach || exec tmux
# }
# use gpg-agent for gpg # use gpg-agent for gpg
# from gpg-agent(1) # from gpg-agent(1)
# if [ -f "~/.gnupg/.gpg-agent-info" ]; then if [ -f "~/.gnupg/.gpg-agent-info" ]; then
# . "~/.gnupg/.gpg-agent-info" . "~/.gnupg/.gpg-agent-info"
# export GPG_AGENT_INFO export GPG_AGENT_INFO
# # export SSH_AUTH_SOCK # export SSH_AUTH_SOCK
# fi fi
# GPG_TTY=$(tty) GPG_TTY=$(tty)
# export GPG_TTY export GPG_TTY
# fuzzyFinder FIXME bloque la completion # fuzzyFinder FIXME bloque la completion
[ -f ~/.fzf.bash ] && source ~/.fzf.bash # [ -f ~/.fzf.bash ] && source ~/.fzf.bash
### tuir / fork of rtv : reddit terminal Viewer ### tuir / fork of rtv : reddit terminal Viewer
export TUIR_BROWSER=urlportal.sh export TUIR_BROWSER=urlportal.sh
export TUIR_URLVIEWER=urlview export TUIR_URLVIEWER=urlview
# XDG # PATH
export XDG_MUSIC_DIR=~/perso/Musique/ export PATH=$PATH:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
### PATH ##################################################
# see ~/devel/dotfiles/bashrc_func
# _append_path [ -r ] <path> <dir>
# return
# 0: ok
# 1: error
# ?: dir already in path
function _append_path() {
local append_infront=0
if test "$1" = '-r'
then
append_infront=1
shift
fi
local path="$1"
local str="$2"
test -n "$str" || { echo "$path"; return 0; }
test -z "$path" &&
{
echo "$str"
return 0
}
if echo "$path" | grep -q "$str"
then
echo "$path"
else
if test $append_infront = 1
then
echo "$str:$path"
else
echo "$path:$str"
fi
fi
return 0
}
# _prepend_path <path> <dir>
function _prepend_path() { _append_path -r "$1" "$2"; }
### rust
test -d "$HOME/.cargo/bin" && PATH=$(_prepend_path "$PATH" "$HOME/.cargo/bin")
### nodejs
test -d "$HOME/download/nodejs/latest/bin" && PATH=$(_prepend_path "$PATH" "$HOME/download/nodejs/latest/bin")
test -d "$HOME/src/node/current/bin" && PATH=$(_prepend_path "$PATH" "$HOME/src/node/current/bin")
### npm in user mode
# test -d "${HOME}/.npm-packages" || mkdir "${HOME}/.npm-packages"
# export NPM_PACKAGES="${HOME}/.npm-packages"
# PATH=$(_prepend_path "$PATH" "$NPM_PACKAGES/bin")
# MANPATH=$(_append_path "$MANPATH" "$NPM_PACKAGES/share/man")
### yarn
test -d "$HOME/src/yarn/latest/bin" && PATH=$(_prepend_path "$PATH" "$HOME/src/yarn/latest/bin")
### golang - default is $HOME/go/bin
export GOPATH="$HOME/go"
test -d "$HOME"/go/bin && PATH=$(_prepend_path "$PATH" "$HOME/go/bin")
# host specific bash
test -r "$HOME/.bashrc-${HOSTNAME}" && source "$HOME/.bashrc-${HOSTNAME}"
# and in front, my scripts
PATH=$(_prepend_path "$PATH" ".:$HOME/bin:$HOME/.local/bin")
# ruby gem PATH
PATH=$(_append_path "$PATH" /home/patrick/.gem/ruby/3.0.0/bin)
# dont modify PATH below
export PATH
# TERM
# echo " TERM=$TERM ($(tput colors) colors)"
# echo " DISPLAY=$DISPLAY"
#
# SSH
#
# ssh-add
# from https://www.revsys.com/tidbits/ssh_auth_sock-tmux-and-you/
function _check_ssh_agent() {
ssh-add -l
}
# function set_ssh_agent() {
# declare -g SSH_AUTH_SOCK
# echo "-> play with ssh-add"
# local SAS=${SSH_AUTH_SOCK}
# echo " export SSH_AUTH_SOCK=$SAS"
# export SSH_AUTH_SOCK=$SAS
# if _check_ssh_agent
# then
# echo " ssh-agent OK : set SSH_AUTH_SOCK"
# SSH_AUTH_SOCK=${HOME}/.ssh/ssh_auth_sock
# fi
# if ! _check_ssh_agent
# then
# echo " ssh-agent KO : link to $SAS"
# ln -sf "${SAS}" "$HOME"/.ssh/ssh_auth_sock
# fi
# }
# set_ssh_agent
# find le last ssh-agent and export as SSH_AUTH_SOCK
# /!\ Dont launch at login
function _ssh_agent2 () {
local pid f
pid=$(pgrep --newest ssh-[a]gent)
test $? = 0 || { echo " Cant find process ssh-[a]gent";return 1; }
# echo "[D] pid=$pid"
f=$(sudo lsof -F n -p "$pid" -a -U | grep ^n | head -1)
test $? = 0 || { echo "Cant find lsof ssh-agent [pid=$pid]";return 1; }
# echo "[D] lsof=$f"
f=${f:1}
f=$(awk '{print $1}' <<<"$f")
# echo "[D] lsof|awk =$f"
# f=$(sudo lsof -p "$pid" | grep 'unix.*type=STREAM' | awk '{print $9}')
test -S "$f" || { echo "Cant find unix socket $f of ssh-agent [pid=$pid]"; return 1; }
export SSH_AUTH_SOCK="$f"
# echo " (new) export SSH_AUTH_SOCK=$SSH_AUTH_SOCK"
}
function u () {
local o="$SSH_AUTH_SOCK"
echo " export SSH_AUTH_SOCK=$SSH_AUTH_SOCK"
_ssh_agent2
test "$o" = "$SSH_AUTH_SOCK" || echo " (new) export SSH_AUTH_SOCK=$SSH_AUTH_SOCK"
}
#
# SSH_ASKPASS
#
# if test -f /usr/lib/ssh/x11-ssh-askpass
# then
# export SSH_ASKPASS=/usr/lib/ssh/x11-ssh-askpass
# echo "-> play with SSH_ASKPASS"
# elif test -f /usr/lib/openssh/x11-ssh-askpass
# then
# export SSH_ASKPASS=/usr/lib/openssh/x11-ssh-askpass
# echo "-> play with SSH_ASKPASS"
# fi
# mkcd
function mkcd {
test "x$1" = x && return 1
if test -d "$1"
then
echo "dir '$1' already exists"
cd "$1" || { echo "Cant cd to $1"; return 1; }
elif test -f "$1"
then
echo "file '$1' already exists"
else
mkdir -p "$1"
cd "$1" || { echo "Cant cd to $1"; return 1; }
fi
}
function mkdev () {
test -n "$1" || { echo Missing argument; return 1; }
test -f "$HOME/devel/$1" && { echo "file $HOME/devel/$1 already exists"; return 1; }
test -d "$HOME/devel/$1" || mkdir "$HOME/devel/$1"
cd "$HOME/devel/$1" || { echo "Cant cd to $HOME/devel/$1"; return 1; }
}
function cdev () {
cd "$HOME/devel/$1" || { echo "Cant cd to $HOME/devel/$1"; return 1; }
}
function clean_comment () {
local opts
test "$1" -eq "-i" && { opts='-i';shift; }
test -n "$1" || { echo Missing argument; return 1; }
sed $opts '/^#/d;s/#.*$//;/^ *$/d' "$1"
}
function faint () {
# echo as faint
test -n "$1" || return 0
echo -e "\e[2m$*\e[m"
}
#
# openssl
#
# https://www.sslshopper.com/article-most-common-openssl-commands.html
# chech all cert/key/csr
function openssl_check_all {
local file="$1"
test -n "${file}" || { echo "Usage: $(basename "$0") <template_file>"; return 1; }
test -f "${file}.csr" && openssl_check_csr "${file}.csr"
test -f "${file}.cert" && openssl_check_cert "${file}.cert"
test -f "${file}.cer" && openssl_check_cert "${file}.cer"
test -f "${file}.crt" && openssl_check_cert "${file}.crt"
test -f "${file}.pem" && openssl_check_cert "${file}.pem"
test -f "${file}.key" && openssl_check_key "${file}.key"
local file2;file2=$(sed 's/\./_/g' <<<"$file")
test "$file" = "$file2" && return 0
file="$file2"
test -f "${file}.csr" && openssl_check_csr "${file}.csr"
test -f "${file}.cert" && openssl_check_cert "${file}.cert"
test -f "${file}.cer" && openssl_check_cert "${file}.cer"
test -f "${file}.crt" && openssl_check_cert "${file}.crt"
test -f "${file}.pem" && openssl_check_cert "${file}.pem"
test -f "${file}.key" && openssl_check_key "${file}.key"
}
# check Certificate Signing Request file
function openssl_check_csr {
test -f "$1" || { echo "Usage: $(basename "$0") <csr_file>"; return 1; }
faint "# openssl req -noout -text -verify -in $1"
openssl req -noout -text -verify -in "$1" | grep Subject:
faint "# openssl req -noout -modulus -in $1 | openssl md5 "
openssl req -noout -modulus -in "$1" | openssl md5
}
# check certificate file
function openssl_check_cert {
test -f "$1" || { echo "Usage: $(basename "$0") <cert_file>"; return 1; }
faint "# openssl x509 -noout -dates -in $1"
openssl x509 -noout -dates -in "$1"
faint "# openssl x509 -noout -modulus -in $1 | openssl md5"
openssl x509 -noout -modulus -in "$1" | openssl md5
}
# check private key file
function openssl_check_key {
test -f "$1" || { echo "Usage: $(basename "$0") <privatekey_file>"; return 1; }
faint "# openssl rsa -modulus -noout -in $1 | openssl md5"
openssl rsa -modulus -noout -in "$1" | openssl md5
}
# check https site
function openssl_check_https {
test -n "$1" || { echo "Usage: $(basename "$0") mon.site.example.com"; return 1; }
faint "# openssl s_client -servername $1 -connect $1:443 "
openssl s_client -servername "$1" -connect "$1:443" < /dev/null
}
# check ssl/tls site
function openssl_check_protocol {
test -n "$1" || { echo "Usage: $(basename "$0") mon.site.example.com"; return 1; }
faint "# openssl s_client -servername $1 -connect $1 | egrep 'Protocol|Cipher'"
openssl s_client -servername "$1" -connect "$1" <> /dev/null | egrep 'Protocol|Cipher'
}
# check certificat file dates
function openssl_check_cert_validity {
test -n "$1" || { echo "Usage: $(basename "$0") mon.site.example.com:443"; return 1; }
faint "# openssl s_client -servername ${1%:*} -connect '$1' < /dev/null 2>/dev/null | openssl x509 -noout -dates"
openssl s_client -servername "${1%:*}" -connect "$1" < /dev/null 2>/dev/null | openssl x509 -noout -dates
#
# validation de OCSP
# see https://github.com/yasharne/OCSP_Checker/blob/master/ocsp_checker.sh
# see https://raymii.org/s/articles/OpenSSL_manually_verify_a_certificate_against_a_CRL.html
# https://medium.com/@yasharne/how-to-check-if-a-certificate-is-revoked-using-a-bash-script-393f14ee7cd5
local ocsp;ocsp="$(openssl s_client -servername "${1%:*}" -connect "$1" < /dev/null 2>/dev/null | openssl x509 -noout -ocsp_uri)"
# le certificat
local dest_cert;dest_cert=$(mktemp)
(openssl s_client -connect "$1" < /dev/null 2>&1 | sed -n '/-----BEGIN/,/-----END/p') > "$dest_cert"
# la chaine de certificat
local chain_cert;chain_cert=$(mktemp)
# openssl s_client -showcerts -connect $1 < /dev/null 2>&1 | sed -n '/-----BEGIN/,/-----END/p' | sed -E '/^---/d' > $chain_cert
openssl s_client -showcerts -connect "$1" < /dev/null 2>&1 | sed -n '/-----BEGIN/,/-----END/p' > "$chain_cert"
# la chaine sans le certificat
local onlychain_cert;onlychain_cert=$(mktemp)
awk 'NR==FNR{a[$0]--;next} (++a[$0] > 0)' "$dest_cert" "$chain_cert" > "$onlychain_cert"
# local grep_cert=$(mktemp)
# sed -e '/^---/d' "$dest_cert" > $grep_cert
# grep -Fvxf "$grep_cert" "$chain_cert" | sed -e '1s/^/-----BEGIN CERTIFICATE-----\n/' -e "\$a-----END CERTIFICATE-----"> $onlychain_cert
# faint "dest_cert = $dest_cert chain_cert = $chain_cert onlychain_cert = $onlychain_cert"
faint "# openssl ocsp -issuer $onlychain_cert -cert $dest_cert -text -url $ocsp"
openssl ocsp -issuer "$onlychain_cert" -cert "$dest_cert" -url "$ocsp" -text 2>/dev/null | grep "$dest_cert" 2>/dev/null | awk -F " " '{print $2}'
}
function curl_check_https {
test -n "$1" || { echo "Usage: $(basename "$0") mon.site.example.com"; return 1; }
faint "# curl -vIk https://$1"
test -n "$1" && curl -vIk https://"$1"
}
# fzf functions
function vf {
if test -n "$1"
then
edit "$(fzf --preview="cat {}" -q "$1")"
else
edit "$(fzf --preview="cat {}")"
fi
}
function vfb {
pushd ~/bin > /dev/null
if test -n "$1"
then
edit "$(fzf --multi --preview="cat {}" -q "$1")"
else
edit "$(fzf --multi --preview="cat {}" )"
fi
popd > /dev/null
}
function of {
if test -n "$1"
then
see "$(fzf --preview="cat {}" -q "$1")"
else
see "$(fzf --preview="cat {}")"
fi
}
function odoc {
pushd ~/docs > /dev/null
if test -n "$1"
then
see "$(fzf --preview="cat {}" -q "$1")"
else
see "$(fzf --preview="cat {}")"
fi
popd > /dev/null
}
# Lorem ipsum
function lorem_ipsum {
cat <<EOT
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero pharetra tempor. Cras vestibulum bibendum augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum. Maecenas adipiscing ante non diam sodales hendrerit.
Ut velit mauris, egestas sed, gravida nec, ornare ut, mi. Aenean ut orci vel massa suscipit pulvinar. Nulla sollicitudin. Fusce varius, ligula non tempus aliquam, nunc turpis ullamcorper nibh, in tempus sapien eros vitae ligula. Pellentesque rhoncus nunc et augue. Integer id felis. Curabitur aliquet pellentesque diam. Integer quis metus vitae elit lobortis egestas. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Morbi vel erat non mauris convallis vehicula. Nulla et sapien. Integer tortor tellus, aliquam faucibus, convallis id, congue eu, quam. Mauris ullamcorper felis vitae erat. Proin feugiat, augue non elementum posuere, metus purus iaculis lectus, et tristique ligula justo vitae magna.
Aliquam convallis sollicitudin purus. Praesent aliquam, enim at fermentum mollis, ligula massa adipiscing nisl, ac euismod nibh nisl eu lectus. Fusce vulputate sem at sapien. Vivamus leo. Aliquam euismod libero eu enim. Nulla nec felis sed leo placerat imperdiet. Aenean suscipit nulla in justo. Suspendisse cursus rutrum augue. Nulla tincidunt tincidunt mi. Curabitur iaculis, lorem vel rhoncus faucibus, felis magna fermentum augue, et ultricies lacus lorem varius purus. Curabitur eu amet
EOT
}
# video
function videoprobe {
test -f "$1" || return 127
ffprobe "$1" 2>&1 | egrep 'Stream|Duration'
}
function videomakefilm {
# from https://trac.ffmpeg.org/wiki/Encode/H.264
# video = h264 crf=$crf
# audio acc 128k
test -f "$1" || return 127
test -z "$2" && return 127
local crf=25
# video size https://ffmpeg.org/ffmpeg-utils.html#Video-size
# ntsc 720x480
# pal 720x576
# hd720 1280x720
# hd1080 2048x1080
# 4k 4096x2160
local vsize=pal # = 720x576
# video rate https://ffmpeg.org/ffmpeg-utils.html#Video-rate
# ntsc 30000/1001
# pal 25/1
# film 24/1
# local vrate=film # = 24 fps
echo ffmpeg -i "$1" -c:v libx264 -preset slow -tune film -crf $crf -c:a aac -b:a 128k -s $vsize "$2"
ffmpeg -i "$1" -c:v libx264 -preset slow -tune film -crf $crf -c:a aac -b:a 128k -s $vsize "$2"
}
function lastfile () {
if test "$1" = '-l'
then /bin/ls -1ltr | /usr/bin/tail -1
else /bin/ls -1tr | /usr/bin/tail -1
fi
}
function newpasswd() {
date +%s | sha256sum | base64 | head -c 32 ; echo
# autre
# openssl rand -hex 32
}
## llm https://rez0.blog/hacking/2023/09/18/vim-llm-hacks.html
comment () {
local system='Add comments to this code. Respond with the code and comments. Do not alter the functional aspect of the code, but still return it. Be sure and include the code in the response. Do not respond in a markdown code block. Just respond with the code and comments. Do not preamble or say anything before or after the code. for example: If the user sent "print(1)\nprint(2)", you would reply "# Prints 1\nprint(1)\n# Prints 2\nprint(2)"'
if test -t 0
then
echo "$*" | llm -m starcoderbase-7b-ggml -s "$system"
else
cat | llm -m starcoderbase-7b-ggml -s "$system"
fi
}
# terraform env
test -r /home/terraform/.terraform_pipelinerc && source /home/terraform/.terraform_pipelinerc
# echo "SSH_AUTH_SOCK=$SSH_AUTH_SOCK"
# ls -l ~/.ssh/ssh_auth_sock
# ssh-add -l
# x11 forwarding FIXME
# echo "DISPLAY=$DISPLAY"
# xauth list
#to launch app with radeon use PRIME
# DRI_PRIME=1 <app>
# cpan config
if test -d /home/patrick/perl5
then
PATH="/home/patrick/perl5/bin${PATH:+:${PATH}}"; export PATH;
PERL5LIB="/home/patrick/perl5/lib/perl5${PERL5LIB:+:${PERL5LIB}}"; export PERL5LIB;
PERL_LOCAL_LIB_ROOT="/home/patrick/perl5${PERL_LOCAL_LIB_ROOT:+:${PERL_LOCAL_LIB_ROOT}}"; export PERL_LOCAL_LIB_ROOT;
PERL_MB_OPT="--install_base \"/home/patrick/perl5\""; export PERL_MB_OPT;
fi
# pyenv
if test -n "$(type -p pyenv)"
then
export PYENV_ROOT="$HOME/.pyenv"
command -v pyenv >/dev/null || export PATH="$PYENV_ROOT/bin:$PATH"
eval "$(pyenv init -)"
# pyenv-virtualenv
# eval "$(pyenv virtualenv-init -)"
fi
#_ shellcheck
export SHELLCHECK_OPTS="-x"
echo "<< .bashrc" echo "<< .bashrc"
# end .bashrc # end .bashrc

View File

@ -71,100 +71,82 @@ TERM xterm-debian
# 30=black 31=red 32=green 33=yellow 34=blue 35=magenta 36=cyan 37=white # 30=black 31=red 32=green 33=yellow 34=blue 35=magenta 36=cyan 37=white
# Background color codes: # Background color codes:
# 40=black 41=red 42=green 43=yellow 44=blue 45=magenta 46=cyan 47=white # 40=black 41=red 42=green 43=yellow 44=blue 45=magenta 46=cyan 47=white
#NORMAL 00 # no color code at all
NORMAL 0 # no color code at all #FILE 00 # regular file: use no color at all
FILE 0 # regular file: use no color at all
RESET 0 # reset to "normal" color RESET 0 # reset to "normal" color
DIR 1;34 # directory DIR 01;34 # directory
LINK 01;36 # symbolic link. (If you set this to 'target' instead of a LINK 01;36 # symbolic link. (If you set this to 'target' instead of a
# numerical value, the color is as for the file pointed to.) # numerical value, the color is as for the file pointed to.)
ORPHAN 1;41;36 # symlink to nonexistent file, or non-stat'able file MULTIHARDLINK 00 # regular file with more than one link
FIFO 40;33 # pipe FIFO 40;33 # pipe
SOCK 01;35 # socket SOCK 01;35 # socket
DOOR 04;35 # door DOOR 01;35 # door
BLK 40;33;01 # block device driver BLK 40;33;01 # block device driver
CHR 40;33;01 # character device driver CHR 40;33;01 # character device driver
SETUID 31;43 # file that is setuid (u+s) ORPHAN 40;31;01 # symlink to nonexistent file, or non-stat'able file
SETGID 34;43 # file that is setgid (g+s) SETUID 37;41 # file that is setuid (u+s)
SETGID 30;43 # file that is setgid (g+s)
CAPABILITY 30;41 # file with capability CAPABILITY 30;41 # file with capability
STICKY_OTHER_WRITABLE 30;42 # dir that is sticky and other-writable (+t,o+w) STICKY_OTHER_WRITABLE 30;42 # dir that is sticky and other-writable (+t,o+w)
OTHER_WRITABLE 34;42 # dir that is other-writable (o+w) and not sticky OTHER_WRITABLE 34;42 # dir that is other-writable (o+w) and not sticky
STICKY 37;44 # dir with the sticky bit set (+t) and not other-writable STICKY 37;44 # dir with the sticky bit set (+t) and not other-writable
# This is for files with execute permission: # This is for files with execute permission:
EXEC 01;32 EXEC 01;32
MULTIHARDLINK 1;4 # regular file with more than one link # List any file extensions like '.gz' or '.tar' that you would like ls
# to colorize below. Put the extension, a space, and the color init string.
# executables win # (and any comments you want to add after a '#')
.cmd 01;32;41 # If you use DOS-style suffixes, you may want to uncomment the following:
.exe 01;32;41 #.cmd 01;32 # executables (bright green)
.com 01;32;41 #.exe 01;32
.btm 01;32;41 #.com 01;32
.bat 01;32;41 #.btm 01;32
#.bat 01;32
# Or if you want to colorize scripts even if they do not have the # Or if you want to colorize scripts even if they do not have the
# executable bit actually set. # executable bit actually set.
#.sh 01;32 #.sh 01;32
#.csh 01;32 #.csh 01;32
# archives or compressed (bright red)
# archives (bold + italic) .tar 01;31
.tar 3;4;32 .tgz 01;31
.tgz 3;4;32 .arc 01;31
.arc 3;4;32 .arj 01;31
.arj 3;4;32 .taz 01;31
.taz 3;4;32 .lha 01;31
.lha 3;4;32 .lz4 01;31
.lz4 3;4;32 .lzh 01;31
.lzh 3;4;32 .lzma 01;31
.lzma 3;4;32 .tlz 01;31
.tlz 3;4;32 .txz 01;31
.txz 3;4;32 .tzo 01;31
.tzo 3;4;32 .t7z 01;31
.t7z 3;4;32 .zip 01;31
.zip 3;4;32 .z 01;31
.z 3;4;32 .Z 01;31
.Z 3;4;32 .dz 01;31
.dz 3;4;32 .gz 01;31
.gz 3;4;32 .lrz 01;31
.lrz 3;4;32 .lz 01;31
.lz 3;4;32 .lzo 01;31
.lzo 3;4;32 .xz 01;31
.xz 3;4;32 .bz2 01;31
.bz2 3;4;32 .bz 01;31
.bz 3;4;32 .tbz 01;31
.tbz 3;4;32 .tbz2 01;31
.tbz2 3;4;32 .tz 01;31
.tz 3;4;32 .deb 01;31
.deb 3;4;32 .rpm 01;31
.rpm 3;4;32 .jar 01;31
.jar 3;4;32 .war 01;31
.war 3;4;32 .ear 01;31
.ear 3;4;32 .sar 01;31
.sar 3;4;32 .rar 01;31
.rar 3;4;32 .alz 01;31
.alz 3;4;32 .ace 01;31
.ace 3;4;32 .zoo 01;31
.zoo 3;4;32 .cpio 01;31
.cpio 3;4;32 .7z 01;31
.7z 3;4;32 .rz 01;31
.rz 3;4;32 .cab 01;31
.cab 3;4;32
# documents
.pdf 3;35
.ps 3;35
.dvi 3;35
# documents office
.odp 35
.ods 35
.odt 35
.doc 35
.docx 35
.xls 35
.xlsx 35
.ppt 35
.pptx 35
# image formats # image formats
.jpg 01;35 .jpg 01;35
.jpeg 01;35 .jpeg 01;35
@ -183,6 +165,27 @@ MULTIHARDLINK 1;4 # regular file with more than one link
.svgz 01;35 .svgz 01;35
.mng 01;35 .mng 01;35
.pcx 01;35 .pcx 01;35
.mov 01;35
.mpg 01;35
.mpeg 01;35
.m2v 01;35
.mkv 01;35
.webm 01;35
.ogm 01;35
.mp4 01;35
.m4v 01;35
.mp4v 01;35
.vob 01;35
.qt 01;35
.nuv 01;35
.wmv 01;35
.asf 01;35
.rm 01;35
.rmvb 01;35
.flc 01;35
.avi 01;35
.fli 01;35
.flv 01;35
.gl 01;35 .gl 01;35
.dl 01;35 .dl 01;35
.xcf 01;35 .xcf 01;35
@ -190,13 +193,11 @@ MULTIHARDLINK 1;4 # regular file with more than one link
.yuv 01;35 .yuv 01;35
.cgm 01;35 .cgm 01;35
.emf 01;35 .emf 01;35
.ico 01;35
# http://wiki.xiph.org/index.php/MIME_Types_and_File_Extensions # http://wiki.xiph.org/index.php/MIME_Types_and_File_Extensions
.axv 01;35 .axv 01;35
.anx 01;35 .anx 01;35
.ogv 01;35 .ogv 01;35
.ogx 01;35 .ogx 01;35
# audio formats # audio formats
.aac 00;36 .aac 00;36
.au 00;36 .au 00;36
@ -215,35 +216,13 @@ MULTIHARDLINK 1;4 # regular file with more than one link
.oga 00;36 .oga 00;36
.spx 00;36 .spx 00;36
.xspf 00;36 .xspf 00;36
# video # video
.mov 1;33 .avi 00;33
.mpg 1;33 .mov 00;33
.mpeg 1;33 .mp4 00;33
.m2v 1;33 .mpg 00;33
.mkv 1;33 .mpeg 00;33
.webm 1;33 .wmv 00;33
.ogm 1;33 .flv 00;33
.mp4 1;33 .webm 00;33
.m4v 1;33
.mp4v 1;33
.vob 1;33
.qt 1;33
.nuv 1;33
.wmv 1;33
.asf 1;33
.rm 1;33
.rmvb 1;33
.flc 1;33
.avi 1;33
.fli 1;33
.flv 1;33
.avi 1;33
.mov 1;33
.mp4 1;33
.mpg 1;33
.mpeg 1;33
.wmv 1;33
.flv 1;33
.webm 1;33
# end .dircolors # end .dircolors

View File

@ -1,24 +1,19 @@
[alias] [alias]
l = log --graph --decorate --oneline --all
ll = log --graph --decorate --pretty=format:'%C(yellow)%h %C(blue)%GK %Creset%ad %Creset%<(20,trunc)%an %C(auto)%d %C(auto)%s' --date=short --all
lol = log --graph --decorate --oneline --all lol = log --graph --decorate --oneline --all
lola = log --graph --decorate --pretty=oneline --abbrev-commit --all lola = log --graph --decorate --pretty=oneline --abbrev-commit --all
st = status --short --branch st = status --short --branch
d = diff --color-words='[^[:space:]]|([[:alnum:]]|UTF_8_GUARD)+' d = diff
dn = diff --name-status --ignore-all-space --histogram dn = diff --name-status
ds = diff --stat --ignore-all-space --histogram ds = diff --stat
f = commit --fixup=HEAD l = log --graph --decorate --oneline --all
s = status --short --branch --untracked-files=no s = status --short --branch
r = rebase -i ll = log --graph --decorate --pretty=format:'%C(yellow)%h %Cred%ad %Cgreen%d %Creset%s' --date=short --all
dw = diff -w
c = commit c = commit
ch = checkout ch = checkout
su = status --short --branch
[color] [color]
ui = true ui = true
[user] [user]
name = Patrick Cao Huu Thien name = Patrick Cao Huu Thien
email = patrick.cao_huu_thien@sorbonne-universite.fr email = patrick.cao_huu_thien@upmc.fr
signingkey = A8F721C80E43073F40DF8F21B57DBE40C72FBCF4
[commit]
gpgsign = true

30
.mutt/mutt_ldap.sh Executable file
View File

@ -0,0 +1,30 @@
#!/bin/bash
function usage {
echo $0: no search string given
exit 1
}
test -z "$1" && usage
search="$1"
resu=""
do_search(){
local LDAPURI="$1"
local LDAPBASE="$2"
local search="$3"
ldapsearch -x -LLL -H $LDAPURI -b $LDAPBASE "(|(uid=~$search)(cn~=$search)(mail~=$search))" mail cn 2>/dev/null |
awk 'BEGIN { n1=1; cn=""; mail="" } /^cn:/ { cn = $2 " " $3 " " $4 " " $5 " " $6 } /^mail:/ { mail = $2 } /^$/ { resu[n1] = mail "\t" cn; mail=""; cn=""; n1++ } END { for (v in resu) print resu[v] } ' |
sed '/^$/d'
}
# search in labo ldap + in university
resu="$(do_search ldap://ldap.dalembert.upmc.fr o=ijlrda "$search")
$(do_search ldap://ldap.upmc.fr ou=People,dc=upmc,dc=fr "$search")"
echo $(echo "$resu" | wc -l) "address(es) found:"
echo "$resu"

205
.mutt/muttrc Normal file
View File

@ -0,0 +1,205 @@
# mutt config
#
# from https://github.com/Nelyah/dotfiles/blob/master/.mutt/settings
#
# define realname, from, hostname and alternates
source ~/.mutt/muttrc-me
set use_envelope_from=yes
set reverse_name
set reverse_realname
#
# paths
#
# set folder = ~/.mail # mailbox location -- set in accounts files
set alias_file = ~/.mutt/alias # where to store aliases
set header_cache = ~/.mutt/cache/headers # where to store headers
set message_cachedir = ~/.mutt/cache/bodies # where to store bodies
set certificate_file = ~/.mutt/certificates # where to store certs
set tmpdir = ~/.mutt/temp # where to keep temp files
set print_command = lp
set ispell = "aspell check"
#
# general
#
set mail_check=90 # check mail every (s)
set timeout=15 # wait only (s) max
set editor='vim "+set spelllang=fr"'
set nowait_key
# text/html ....
alternative_order text/plain text/html
auto_view text/html
# status format
# default is = "-%r-Mutt: %f [Msgs:%?M?%M/?%m%?n? New:%n?%?o? Old:%o?%?d? Del:%d?%?F? Flag:%F?%?t? Tag:%t?%?p? Post:%p?%?b? Inc:%b?%?l? %l?]---(%s/%S)-%>-(%P)---"
set status_format = "-%r-%v@%h: %f [Msgs:%?M?%M/?%m%?n? New:%n?%?o? Old:%o?%?d? Del:%d?%?F? Flag:%F?%?t? Tag:%t?%?p? Post:%p?%?b? Inc:%b?%?l? %l?]---(%s/%S)-%>-(%P)---"
#
# pager format
# default is "-%Z- %C/%m: %-20.20n %s%* -- (%P)"
set pager_format = "-%Z- %C/%m: from <%n> « %s »%* -- (%P)"
#
# index
#
# index format dynamic change
# from https://muttmua.gitlab.io/mutt/manual-dev.html#index-format-hook
set index_format="%4C %Z %?H?[%H]? %-10@date@ %-30.30L (%?l?%4l&%4c?) %s"
index-format-hook date "~d<1d" "%[%H:%M]"
index-format-hook date "~d<2d" "hier %[%H:%M]"
index-format-hook date "~d<5d" "%[%a %H:%M]"
index-format-hook date "~d<1m" "%[%a %d]"
index-format-hook date "~d<1y" "%[%d %b]"
index-format-hook date "~A" "%[%m/%Y]"
set sort = threads # default sorting
set sort_aux = last-date-received # second sorting
#
# aliases
#
source ~/.mutt/alias
#
# keybinding
#
bind index '"' what-key # print key code -- ctrl+g to quit
bind index G imap-fetch-mail # force fetch new email
bind index K previous-unread
bind index J next-unread
bind pager <pageup> half-up
bind pager <pagedown> half-down
#
# Macros
#
# save messages
macro index >S <tag-prefix><save-message>=SPAM<enter> 'save to SPAM'
macro index >V <tag-prefix><save-message>=VLAN<enter> 'save to VLAN'
macro index >D <tag-prefix><save-message>=diffusion<enter> 'save to diffusion'
macro index >C <tag-prefix><save-message>=CSSI<enter> 'save to CSSI'
macro index >I <tag-prefix><save-message>=IMPRIMANTES<enter> 'save to IMPRIMANTES'
macro index >L <tag-prefix><save-message>=logwatchs<enter> 'save to logwatchs'
# urlview
# macro index,pager \cb "|urlview\n" "urlview to extract URLs"
macro index,pager \cb "<pipe-message>urlscan<enter>" "open URL in BROWSER"
# limit to new/old/flag messages
macro index ,n "<limit>(~N|~O|~F)<Enter>" "view new/flag"
macro index ,a "<limit>~A<Enter>" "view all"
# get new messages by default
folder-hook . push ,n
# urlscan
# macro index,pager \cb "<pipe-message>urlscan<Enter>" "urlscan to extract URLs"
# macro attach,compose \cb "<pipe-entry>urlscan<Enter>" "urlscan to extract URLs"
# macro index,pager \cc "<pipe-message>urlscanchrome<Enter>" "urlscan to extract URLs (chrome)"
# macro attach,compose \cc "<pipe-entry>urlscanchrome<Enter>" "call urlscan to extract URLs out of a message"
# identities
macro compose \cf "<edit-from>^Umoi\_<tab>" "Select from"
#
# notmoch-mutt from debian
# from /etc/Muttrc.d/notmuch-mutt.rc
#
macro index <F8> \
"<enter-command>set my_old_pipe_decode=\$pipe_decode my_old_wait_key=\$wait_key nopipe_decode nowait_key<enter>\
<shell-escape>notmuch-mutt -r --prompt search<enter>\
<change-folder-readonly>`echo ${XDG_CACHE_HOME:-$HOME/.cache}/notmuch/mutt/results`<enter>\
<enter-command>set pipe_decode=\$my_old_pipe_decode wait_key=\$my_old_wait_key<enter>" \
"notmuch: search mail"
macro index <F9> \
"<enter-command>set my_old_pipe_decode=\$pipe_decode my_old_wait_key=\$wait_key nopipe_decode nowait_key<enter>\
<pipe-message>notmuch-mutt -r thread<enter>\
<change-folder-readonly>`echo ${XDG_CACHE_HOME:-$HOME/.cache}/notmuch/mutt/results`<enter>\
<enter-command>set pipe_decode=\$my_old_pipe_decode wait_key=\$my_old_wait_key<enter>" \
"notmuch: reconstruct thread"
macro index <F6> \
"<enter-command>set my_old_pipe_decode=\$pipe_decode my_old_wait_key=\$wait_key nopipe_decode nowait_key<enter>\
<pipe-message>notmuch-mutt tag -- -inbox<enter>\
<enter-command>set pipe_decode=\$my_old_pipe_decode wait_key=\$my_old_wait_key<enter>" \
"notmuch: remove message from inbox"
#
# spam detection - champs %H
#
spam "X-j-chkmail-Status: Spam (.*)" "ju/%1"
spam "X-Spam-Status: Yes" "sa"
spam "X-Amavis-Spam-Status: Yes" "am"
spam "X-Renater-SpamScore: ([1-9][0-9]*)" "re/%1"
set spam_separator="|"
#
# Messages
#
set rfc2047_parameters # decoded some
set send_charset = "us-ascii:utf-8" # UTF stuff
set assumed_charset = "utf-8"
set charset = "utf-8"
set date_format = "%d %b %Y a %H:%M:%S %Z"
set attribution_locale = "fr_FR.UTF-7"
set attribution="Le %d, %n a écrit :"
#
# headers
#
ignore *
unignore from date subject to cc User-Agent Content-Length
unignore organization organisation x-mailer: x-newsreader: x-mailing-list:
unignore posted-to: List-Id:
unignore X-j-chkmail-Status: X-Spam-Status: X-Amavis-Spam-Status: X-Renater-SpamScore:
# reset header order
unhdr_order *
hdr_order Date: Subject: From: From To: Cc: User-Agent: x-mailer: posted-to: List-Id: x-mailing-list: Content-Length: X-*:
# pager
set pager_stop # dont exit at the end of the message with <space>
#
# Listes
#
subscribe .*@listes.upmc.fr
subscribe .*@lists.debian.org
subscribe .*@pmichaud.com
subscribe .*@services.cnrs.fr
subscribe .*@listes.fercsup-cgt.org
#
# Colors
#
source $HOME/.mutt/muttrc-colors
#
# from https://github.com/Nelyah/dotfiles/blob/master/.mutt/settings
# use <tab> to change
macro generic \Cx| "<enter-command>source"
macro generic \Cx& "<enter-command>macro index \\t \"\\Cx"
macro index <tab> "\Cx1"
# macro generic \Cx0 "\Cx| ~/.mutt/accounts/archive\"\n\Cx&1\"<enter><change-folder>!<enter>"
# define accounts and Fx links
# +smtp_url, sll_force_tls, ssl_starttls
source $HOME/.mutt/muttrc-accounts
#
# Query : ldap
#
# Use with Ctrl+t
set query_command = "$HOME/.mutt/mutt_ldap.sh %s"

74
.mutt/muttrc-colors Normal file
View File

@ -0,0 +1,74 @@
# vim: filetype=muttrc
# from https://github.com/LukeSmithxyz/mutt-wizard/blob/master/etc/muttcol
#
# Header colors:
# color ( header | body ) <foreground> <background> <regexp>
color header brightwhite color236 "^Subject"
color header color124 color236 "^From"
color header color11 color236 "^From:"
color header color10 color236 "^To"
color header color40 color236 "^(CC|BCC)"
color header color9 color240 "^(X-j-chkmail-Status|X-Spam-Status|X-Amavis-Spam-Status|X-Renater-SpamScore)"
color body brightred default "[\-\.+_a-zA-Z0-9]+@[\-\.a-zA-Z0-9]+" # Email addresses
color body brightblue default "(https?|ftp)://[\-\.,/%~_:?&=\#a-zA-Z0-9]+" # URL
color body green default "\`[^\`]*\`" # Green text between ` and `
color body brightblue default "^# \.*" # Headings as bold blue
color body brightcyan default "^## \.*" # Subheadings as bold cyan
color body brightgreen default "^### \.*" # Subsubheadings as bold green
color body yellow default "^(\t| )*(-|\\*) \.*" # List items as yellow
color body brightcyan default "[;:][-o][)/(|]" # emoticons
color body brightcyan default "[;:][)(|]" # emoticons
color body brightcyan default "[ ][*][^*]*[*][ ]?" # more emoticon?
color body brightcyan default "[ ]?[*][^*]*[*][ ]" # more emoticon?
color body red default "(BAD signature)"
color body cyan default "(Good signature)"
color body brightblack default "^gpg: Good signature .*"
color body brightyellow default "^gpg: "
color body brightyellow red "^gpg: BAD signature from.*"
color body red default "([a-z][a-z0-9+-]*://(((([a-z0-9_.!~*'();:&=+$,-]|%[0-9a-f][0-9a-f])*@)?((([a-z0-9]([a-z0-9-]*[a-z0-9])?)\\.)*([a-z]([a-z0-9-]*[a-z0-9])?)\\.?|[0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+)(:[0-9]+)?)|([a-z0-9_.!~*'()$,;:@&=+-]|%[0-9a-f][0-9a-f])+)(/([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*(;([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*)*(/([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*(;([a-z0-9_.!~*'():@&=+$,-]|%[0-9a-f][0-9a-f])*)*)*)?(\\?([a-z0-9_.!~*'();/?:@&=+$,-]|%[0-9a-f][0-9a-f])*)?(#([a-z0-9_.!~*'();/?:@&=+$,-]|%[0-9a-f][0-9a-f])*)?|(www|ftp)\\.(([a-z0-9]([a-z0-9-]*[a-z0-9])?)\\.)*([a-z]([a-z0-9-]*[a-z0-9])?)\\.?(:[0-9]+)?(/([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*(;([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*)*(/([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*(;([-a-z0-9_.!~*'():@&=+$,]|%[0-9a-f][0-9a-f])*)*)*)?(\\?([-a-z0-9_.!~*'();/?:@&=+$,]|%[0-9a-f][0-9a-f])*)?(#([-a-z0-9_.!~*'();/?:@&=+$,]|%[0-9a-f][0-9a-f])*)?)[^].,:;!)? \t\r\n<>\"]"
# color index <foreground> <background> <pattern>
# color index default default '.*' # default
color index default default '~u' # list messages
color index green default '~P' # from me
color index brightgreen color0 '~p' # for me
color index brightyellow color0 "~N" # new messages
color index yellow color0 "~O" # ols messages
color index red color0 '~T' # tagged messages
color index red default '~H ..*' # spam messages
color index cyan blue '~D' # deleted messages
color index magenta default 'ray|lesaec|mackagny|popinet|info'
color index color202 default '~f netdata ~s "needs attention"'
# color <ojb> <foreground> <background>
color normal default default
color indicator brightblack white
color normal brightyellow default
color error red default
color tilde black default
color message cyan default
color markers red white
color attachment white default
color search brightmagenta default
color status brightyellow blue
color hdrdefault color248 color236
color quoted green default
color quoted1 blue default
color quoted2 cyan default
color quoted3 yellow default
color quoted4 red default
color quoted5 brightred default
color signature brightgreen default
color bold black default
color underline black default
color normal default default
# mono
mono bold bold
mono underline underline
mono indicator reverse
mono error bold
mono body bold "^gpg: Good signature"
mono body bold "^gpg: BAD signature from.*"

37
.tmux.conf Normal file
View File

@ -0,0 +1,37 @@
## pcht tmux configurarion
# (c) 2018
# change prefix to ctrl+a and
# use "C-a a"to send C-a to shell
unbind C-b
set -g prefix C-a
bind a send-prefix
# disable login-shell on tmux
# https://wiki.archlinux.org/index.php/Tmux#Start_a_non-login_shell
set -g default-command "${SHELL}"
# set default term to 256 colors
#set -g default-terminal "tmux-255color"
set -g default-terminal "screen"
# open pane/window in same directory
# https://unix.stackexchange.com/questions/12032/create-new-window-with-current-directory-in-tmux
bind '"' split-window -c "#{pane_current_path}"
bind s split-window -c "#{pane_current_path}"
bind % split-window -h -c "#{pane_current_path}"
bind '|' split-window -h -c "#{pane_current_path}"
bind c new-window -c "#{pane_current_path}"
# last window like in screen
bind C-a last-window
# reload this file
bind r source-file /home/patrick/.tmux.conf \; display-message ".tmux.conf reloaded"
# automatic update env for ssh-agent
# https://stackoverflow.com/questions/21378569/how-to-auto-update-ssh-agent-environment-variables-when-attaching-to-existing-tm
set-option -g update-environment SSH_AUTH_SOCK
# urlview in term
run-shell ~/src/tmux-urlview/urlview.tmux

View File

@ -8,13 +8,9 @@
" <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~> " <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~>
" (_) (_) " (_) (_)
" Vundle https://github.com/VundleVim/Vundle.vim
" install with :
" git clone https://github.com/VundleVim/Vundle.vim.git ~/.vim/bundle/Vundle.vim
" set nocompatible be iMproved, required - Isnt it automatic with .vimrc??
" utf8 " utf8
set encoding=utf-8 set encoding=utf-8
filetype off " required filetype off " required
" _\|/_ " _\|/_
@ -30,6 +26,7 @@ filetype off " required
" <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~> " <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~>
" (_) (_) " (_) (_)
" "
" set the runtime path to include Vundle and initialize " set the runtime path to include Vundle and initialize
set rtp+=~/.vim/bundle/Vundle.vim set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin() call vundle#begin()
@ -39,8 +36,14 @@ Plugin 'VundleVim/Vundle.vim'
" git " git
Plugin 'tpope/vim-fugitive' Plugin 'tpope/vim-fugitive'
" commentary " commentary
Plugin 'commentary.vim' Plugin 'tpope/vim-commentary'
xmap \\ <Plug>Commentary
nmap \\ <Plug>Commentary
nmap \\\ <Plug>CommentaryLine
nmap \\u <Plug>CommentaryUndo
" Plugin 'Syntastic' " Plugin 'Syntastic'
" set statusline+=%#warningmsg# " set statusline+=%#warningmsg#
" set statusline+=%{SyntasticStatuslineFlag()} " set statusline+=%{SyntasticStatuslineFlag()}
@ -51,25 +54,11 @@ Plugin 'commentary.vim'
" let g:syntastic_check_on_open = 1 " let g:syntastic_check_on_open = 1
" let g:syntastic_check_on_wq = 0 " let g:syntastic_check_on_wq = 0
" let g:syntastic_auto_jump = 2 " let g:syntastic_auto_jump = 2
Plugin 'ctrlpvim/ctrlp.vim'
" Plugin 'ctrlpvim/ctrlp.vim'
Plugin 'tpope/vim-surround' Plugin 'tpope/vim-surround'
Plugin 'tpope/vim-repeat' Plugin 'tpope/vim-repeat'
" ys<target><obj> : ajoute <ojb> autour de <target> (sous le curseur)
" ysw" : ajoute des " autour du word
" ysW' : ajout des ' autour du WORD
" yss{ : ajoute { a la phrase (avec espace)
" yss} : ajoute { a la phrase
" ySS[ : ajoute [ a la phrase, en indentant + a la ligne
"
" cs<target><rep> : change <obj> en <rep> dans <t>
" cs"' : change les " par des '
"
" ds<target> : supprime une <target>
" ds" : supprime les "
"
" <target> : w = word, W = WORD, s = sentence, p = paragraph
" " ' ( ) [ ] { } < >
" t <tag>
" unicode characters " unicode characters
" :h unicode-plugin " :h unicode-plugin
@ -334,6 +323,7 @@ au FileType sh compiler shellcheck
au FileType sh nmap <leader>m :ShellCheck!<cr> au FileType sh nmap <leader>m :ShellCheck!<cr>
au FileType sh imap <leader>m <esc>:ShellCheck!<cr>i au FileType sh imap <leader>m <esc>:ShellCheck!<cr>i
" All of your Plugins must be added before the following line " All of your Plugins must be added before the following line
call vundle#end() " required call vundle#end() " required
filetype plugin indent on " required filetype plugin indent on " required
@ -346,6 +336,7 @@ filetype plugin indent on " required
" | | " | |
" <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~> " <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~>
" (_) (_) " (_) (_)
" syntax " syntax
syntax on syntax on
@ -375,6 +366,7 @@ set backspace=2
set statusline=%F%m%r%h%w\ %{fugitive#statusline()}%=[BUF=%n][FORMAT=%{&ff}][TYPE=%Y][ASCII=%03.3b][LINE=%03l][COL=%03v][%p%%] set statusline=%F%m%r%h%w\ %{fugitive#statusline()}%=[BUF=%n][FORMAT=%{&ff}][TYPE=%Y][ASCII=%03.3b][LINE=%03l][COL=%03v][%p%%]
set laststatus=2 set laststatus=2
""""""""""""""""""" """""""""""""""""""
" affiche les touches en mode commande " affiche les touches en mode commande
set showcmd set showcmd
@ -487,8 +479,9 @@ set foldlevel=3
" | | " | |
" <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~> " <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~>
" (_) (_) " (_) (_)
" tabe <file> créer un onglet " tabe <file> créer un onglet
"function! MoveTab(direction) " function! MoveTab(direction)
" if (a:direction == 'left') " if (a:direction == 'left')
" let tabnum = tabpagenr()-2 " let tabnum = tabpagenr()-2
" if (tabnum < 0) " if (tabnum < 0)
@ -499,7 +492,7 @@ set foldlevel=3
" let tabnum = tabpagenr() " let tabnum = tabpagenr()
" execute 'tabm '.tabnum " execute 'tabm '.tabnum
" endif " endif
"endfunction " endfunction
highlight TabLine term=none cterm=none highlight TabLine term=none cterm=none
highlight TabLineSel ctermbg=darkblue highlight TabLineSel ctermbg=darkblue
" raccourcis " raccourcis
@ -641,6 +634,7 @@ set scrolloff=999
" | | " | |
" <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~> " <~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~>
" (_) (_) " (_) (_)
" no arrows keys no more " no arrows keys no more
nmap <left> <nop> nmap <left> <nop>
nmap <right> <nop> nmap <right> <nop>
@ -666,6 +660,7 @@ nmap gf :e <cfile><cr>
" increase / decrease " increase / decrease
:nnoremap <A-a> <C-a> :nnoremap <A-a> <C-a>
:nnoremap <A-x> <C-x> :nnoremap <A-x> <C-x>
" speed up " speed up
" edit .vimrc " edit .vimrc
nmap <leader>v :vs ~/.vimrc<cr> nmap <leader>v :vs ~/.vimrc<cr>
@ -697,3 +692,4 @@ nmap ; :

32
.xinitrc Normal file
View File

@ -0,0 +1,32 @@
# hiDPI
test -f $HOME/.Xresources && xrdb -merge $HOME/.Xresources
# my keyboards
setxkbmap -layout us,us -variant ,intl -option grp:rctrl_rshift_toggle
# my monitors
xrandr --output DVI-D-1 --primary --mode 1920x1080 --scale 1x1
xrandr --output HDMI-0 --mode 3840x2160 --scale 1x1 --right-of DVI-D-1
# background
feh --bg-scale /home/patrick/perso/wallpapers/20190303_les_filles.jpg
# tools
# status
slstatus &
eval $(ssh-agent)
## restart with Alt-Shift-Q
## (only in debug process because make dwm slow not using exec)
# while true
# do
# dwm 2> $HOME/.dwm.log
# done
## or do a simple exec
# eval $(gpg-agent --daemon) #DONT NEED TO LAUNCH IT
exec dwm 2> $HOME/.dwm.log

1
.xinitrc-keyboard Executable file
View File

@ -0,0 +1 @@
setxkbmap -layout us,us -variant ,intl -option grp:rctrl_rshift_toggle

2
.xinitrc-xrandr Executable file
View File

@ -0,0 +1,2 @@
xrandr --output DVI-D-1 --primary --mode 1920x1080 --scale 1x1
xrandr --output HDMI-0 --mode 3840x2160 --scale 1x1 --right-of DVI-D-1

View File

@ -15,23 +15,23 @@ set use_domain
# SMTP # SMTP
# #
# heywood dont handle TLS -- too old version # heywood dont handle TLS -- too old version
set smtp_url=smtps://imap.dalembert.upmc.fr set smtp_url=smtp://heywood.dalembert.upmc.fr
# unset ssl_force_tls unset ssl_force_tls
# unset ssl_starttls unset ssl_starttls
# set smtp_url=smtp://mail.lam.jussieu.fr # set smtp_url=smtp://mail.lam.jussieu.fr
# #
# accounts # accounts
# #
source /home/patrick/.mutt/accounts/default source /home/patrick/.mutt/accounts/upmc-offline
macro generic \Cx0 "\Cx| ~/.mutt/accounts/default\"\n\Cx&1\"<enter><change-folder>!<enter>" macro generic \Cx0 "\Cx| ~/.mutt/accounts/upmc-offline\"\n\Cx&1\"<enter><change-folder>!<enter>"
macro generic \Cx1 "\Cx| ~/.mutt/accounts/gmail\"\n\Cx&0\"<enter><change-folder>!<enter>" macro generic \Cx1 "\Cx| ~/.mutt/accounts/gmail-offline\"\n\Cx&0\"<enter><change-folder>!<enter>"
# switch account with <tab> # switch account with <tab>
macro index <tab> "\Cx1" macro index <tab> "\Cx1"
macro index <f2> '<sync-mailbox><enter-command>source ~/.mutt/accounts/default<enter><change-folder>!<enter>' macro index <f2> '<sync-mailbox><enter-command>source ~/.mutt/accounts/upmc-offline<enter><change-folder>!<enter>'
macro index <f3> '<sync-mailbox><enter-command>source ~/.mutt/accounts/gmail<enter><change-folder>!<enter>' macro index <f3> '<sync-mailbox><enter-command>source ~/.mutt/accounts/gmail-offline<enter><change-folder>!<enter>'

View File

@ -1,4 +1,4 @@
# used by macro compose v
alias moi_1 Patrick CAO HUU THIEN <patrick.cao_huu_thien@sorbonne-universite.fr> alias moi_1 Patrick CAO HUU THIEN <patrick.cao_huu_thien@sorbonne-universite.fr>
alias moi_1bis Patrick CAO HUU THIEN <patrick.cao_huu_thien@upmc.fr> alias moi_1bis Patrick CAO HUU THIEN <patrick.cao_huu_thien@upmc.fr>
alias moi_2 Master ZU <master.h2zu@gmail.com> alias moi_2 Master ZU <master.h2zu@gmail.com>

View File

@ -1,4 +1,8 @@
# vim: filetype=muttrc
# from https://github.com/LukeSmithxyz/mutt-wizard/blob/master/etc/muttcol
#
# Header colors:
# color ( header | body ) <foreground> <background> <regexp>
color header brightwhite color236 "^Subject" color header brightwhite color236 "^Subject"
color header color124 color236 "^From" color header color124 color236 "^From"
color header color11 color236 "^From:" color header color11 color236 "^From:"

View File

@ -17,9 +17,9 @@ set header_cache = ~/.mutt/cache/headers # where to store headers
set message_cachedir = ~/.mutt/cache/bodies # where to store bodies set message_cachedir = ~/.mutt/cache/bodies # where to store bodies
set certificate_file = ~/.mutt/certificates # where to store certs set certificate_file = ~/.mutt/certificates # where to store certs
set tmpdir = ~/.mutt/temp # where to keep temp files set tmpdir = ~/.mutt/temp # where to keep temp files
set print = ask-yes
set print_command = lp set print_command = lp
set ispell = "aspell check" set ispell = "aspell check"
set mbox_type = "MailDir"
# #
# general # general
@ -27,11 +27,8 @@ set ispell = "aspell check"
set mail_check=90 # check mail every (s) set mail_check=90 # check mail every (s)
set timeout=15 # wait only (s) max set timeout=15 # wait only (s) max
set editor='vim "+set spelllang=fr"' set editor='vim "+set spelllang=fr"'
set wait_key=no set nowait_key
set user_agent=yes set user_agent=yes
set mime_forward=yes # set forward message as attach and not in text
set pipe_decode=yes
set pipe_decode_weed=yes
# text/html .... # text/html ....
alternative_order text/plain text/html alternative_order text/plain text/html
@ -75,10 +72,6 @@ bind generic '"' what-key # print key code -- ctrl+g to quit
bind index G imap-fetch-mail # force fetch new email bind index G imap-fetch-mail # force fetch new email
bind index K previous-unread bind index K previous-unread
bind index J next-unread bind index J next-unread
bind index \ct tag-thread
# TODO macro index <Esc>t <enter-command>untag-pattern<enter>
bind pager <pageup> half-up bind pager <pageup> half-up
bind pager <up> half-up bind pager <up> half-up
bind pager <pagedown> half-down bind pager <pagedown> half-down
@ -87,43 +80,39 @@ bind pager <down> half-down
# #
# Macros # Macros
# #
macro index <esc>T <untag-pattern>
# urlscan/urlview
# FIXME BROKEN macro index,pager \cb "<pipe-message>urlscan<enter>" "open URL in urlscan"
macro index,pager \cb "<pipe-message>urlview<enter>" "open URL in urlview"
# save messages # save messages
macro index >C <tag-prefix><save-message>=CSSI<enter> 'save to CSSI'
macro index >i <tag-prefix><save-message>=dalembert-inscription<enter> 'save to IMPRIMANTES'
macro index ,i "<limit>Demande.*inscription<Enter>" "view logwatch"
macro index >I <tag-prefix><save-message>=SERVICE.INFO<enter> 'save to service info' macro index >I <tag-prefix><save-message>=SERVICE.INFO<enter> 'save to service info'
macro index >L <tag-prefix><save-message>=logwatchs<enter> 'save to logwatchs'
macro index ,l "<limit>logwatch<Enter>" "view logwatch"
macro index >N <tag-prefix><save-message>=netdata<enter> 'save to netdata' macro index >N <tag-prefix><save-message>=netdata<enter> 'save to netdata'
macro index >P <tag-prefix><save-message>=2019-2020-PYL<enter> 'Le chef' macro index >P <tag-prefix><save-message>=2019-2020-PYL<enter> 'Le chef'
macro index >S <tag-prefix><save-message>=SPAM<enter> 'save to SPAM' macro index >S <tag-prefix><save-message>=SPAM<enter> 'save to SPAM'
macro index >V <tag-prefix><save-message>=VLAN<enter> 'save to VLAN'
macro index ,v "<limit>vlan<Enter>" "view vlan"
# filtres to new/old/flag messages
# urlscan
macro index,pager \cb "<pipe-message>urlscan<enter>" "open URL in urlscan"
# limit to new/old/flag messages
macro index ,a "<limit>~A<Enter>" "Voir: all" macro index ,a "<limit>~A<Enter>" "Voir: all"
macro index ,n "<limit>(~N|~O|~F)<Enter>" "Voir: new/flag" macro index ,n "<limit>(~N|~O|~F)<Enter>" "Voir: new/flag"
macro index ,m "<limit>(~N|~O)(~p|~P|~C info@)|~C printers@|~C proxmox@|~s 'monit alert'|~s SMART|~F<Enter>" "Voir: new+from/to me" macro index ,m "<limit>(~N|~O)(~p|~P|~C info@|~C printers@|~C proxmox@|~s monit)|~F<Enter>" "Voir: new+from/to me"
macro index ,M "<limit>(~p|~P|~C info@|~C printers@)|~C proxmox@|~s 'monit alert'|~s SMART|~F<Enter>" "Voir: from/to me" macro index ,M "<limit>(~p|~P|~C info@|~C printers@|~C proxmox@|~s monit)|~F<Enter>" "Voir: from/to me"
macro index ,t "<limit>(~N|~O|~F) ~C tout.?ida@<Enter>" "Voir: new+toutida" macro index ,t "<limit>(~N|~O|~F) ~C tout.?ida@<Enter>" "Voir: new+toutida"
macro index ,T "<limit>~C tout.?ida@<Enter>" "Voir: toutida" macro index ,T "<limit>~C tout.?ida@<Enter>" "Voir: toutida"
# filtres autres
macro index ,i "<limit>Demande.*inscription<Enter>" "view logwatch"
macro index >i <tag-prefix><save-message>=dalembert-inscription<enter> 'save to IMPRIMANTES'
macro index,pager .i "<tag-prefix><pipe-message>mutt_process | LESS=-RC less<enter>"
# macro index,pager .i ":set wait_key=yes<enter><tag-prefix><pipe-message>mutt_inscription<enter>:set wait_key=no<enter>"
# macro index /c "<limit>~C su-adherents|~C diffusion-fercsup|~C bureau-sntrsjussieu|~C communication-syndicale|~C commob_jussieu|~s CGT|~s 'commission sociale'<Enter>" "view listes CGT"
macro index ,c "<limit>~C corresp_ssi@services.cnrs.fr | ~C cssi_dr2@services.cnrs.fr | ~C netadmin@listes.sorbonne-universite.fr | ~c cssi@listes.sorbonne-universite.fr | ~f support@cert-manager.com | ~s genci <Enter>" "view CSSI"
macro index >C <tag-prefix><save-message>=CSSI<enter> 'save to CSSI'
macro index ,l "<limit>logwatch|cron<Enter>" "view logwatch"
macro index >L <tag-prefix><save-message>=logwatchs<enter> 'save to logwatchs'
macro index ,v "<limit>~f @brahma<Enter>" "view brahma logs"
macro index >V <tag-prefix><save-message>=VLAN<enter> 'save to VLAN'
# listes macro index /a "<limit>~C asr@services.cnrs.fr<Enter>" "Voir: liste-ASR"
macro index >A <tag-prefix><save-message>=liste-ASR<enter> "save to liste-ASR" macro index >A <tag-prefix><save-message>=liste-ASR<enter> "save to liste-ASR"
macro index >D <tag-prefix><save-message>=liste-DEBIAN<enter> "save to liste-DEBIAN" macro index /h "<limit>~C hackesr@groupes.renater.fr<Enter>" "Voir: liste-hackesr"
macro index >H <tag-prefix><save-message>=liste-hackesr<enter> "save to liste-hackesr" macro index >H <tag-prefix><save-message>=liste-hackesr<enter> "save to liste-hackesr"
macro index /l "<limit>(~C @listes.sorbonne-universite.fr|~C @listes.upmc.fr|~C @services.cnrs.fr|~C @groupes.renater.fr|~C @pmichaud.com|~C @lists.debian.org)<Enter>" "Voir: Listes" macro index /d "<limit>~C @lists.debian.org<Enter>" "Voir: liste-Debian"
macro index >D <tag-prefix><save-message>=liste-DEBIAN<enter> "save to liste-DEBIAN"
macro index /l "<limit>(~C @listes.upmc.fr|~C @services.cnrs.fr|~C @groupes.renater.fr|~C @pmichaud.com)<Enter>" "Voir: Listes pro"
macro index /m "<limit>monit<Enter>" "Voir: monit" macro index /m "<limit>monit<Enter>" "Voir: monit"
# get new messages by default # get new messages by default
@ -152,9 +141,6 @@ set date_format = "%d %b %Y a %H:%M:%S %Z"
set attribution_locale = "fr_FR.UTF-7" set attribution_locale = "fr_FR.UTF-7"
set attribution="Le %d, %n a écrit :" set attribution="Le %d, %n a écrit :"
# delete duplicate messages
folder-hook . push "<delete-pattern>~=<enter>"
# #
# headers # headers
# #
@ -183,25 +169,6 @@ macro generic \Cx| "<enter-command>source"
macro generic \Cx& "<enter-command>macro index \\t \"\\Cx" macro generic \Cx& "<enter-command>macro index \\t \"\\Cx"
source $HOME/.mutt/muttrc-accounts source $HOME/.mutt/muttrc-accounts
#
# GPG
#
source $HOME/.mutt/gpg.rc
set crypt_autosign = yes
set crypt_replysign = yes
set crypt_replyencrypt = yes
set crypt_replysignencrypted = yes
set crypt_protected_headers_write = yes # protect subject
set crypt_protected_headers_subject = 'Sujet Sensible (chiffré)'
# OLD set pgp_default_key = D7B87DFB479CA02E48A2383C00054A3358D16D27
set pgp_default_key = A8F721C80E43073F40DF8F21B57DBE40C72FBCF4
# auto attach pub key from https://stackoverflow.com/a/67065558
# Esc-k pour inclure manuellement
macro compose y "<attach-key>`echo A8F721C80E43073F40DF8F21B57DBE40C72FBCF4`<enter><enter><send-message>"
macro compose Y "<send-message>"
# #
# Query : ldap # Query : ldap
# #