summaryrefslogtreecommitdiff
path: root/zshrc
blob: a2fff9b838b6f04ac36a76552588116118efbdae (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
##
## THIS FILE IS NOT INTENDED TO BE MODIFIED ! READ ABOVE...
##
#
# Instead, add/edit your configuration files inside $ZDOTDIR.
#
# If you want to add a file, name it specifically in the form
#
# 	$ZDOTDIR/??_*.zsh
#
# Where "??" should be a two-digit number.
# With that, file ``10_Toto.zsh'' would be parsed before
# file ``20_Tutu.zsh'', allowing you ordering your scripts.
# 
# If you want to make user, host or network specific configurations,
# add your specific scripts to the folders
#  - "sys:$(uname -s)" for OS-specific conf,
#  - "user:$(whoami)" for user-specific conf,
#  - "host:$(hostname -s)" for host-specific conf,
#  - "net:$(domainname)" for network-specific conf,
# rename your scripts to the form mentionned above, minus the "??_"
# prefix. An original script prefixed by a two-digits number SHOULD
# be present on the $ZDOTDIR folder, even if empty.
#

ZDOTDIR=${ZDOTDIR:-~/.zsh}
mkdir -p $ZDOTDIR

trap "source ~/.zshrc" USR1

# Useful environment variables which may be used
# at any time - We compute them now to avoid calling
# the required processes each time we'll need.
OSNAME=`uname -s`
USER=${USER:-`whoami`}
UID=${UID:-`id -u`}
HOST=$HOST:r
HOST=${HOST:-$(hostname -s)}
DOMAIN=${DOMAIN:-$(hostname -a 2>&-| sed 's/^[^\.]*\.\?//')}
DOMAIN=${DOMAIN:-$(hostname -d 2>&-)}
DOMAIN=${DOMAIN:-$(hostname -y 2>&-)}
[ "$DOMAIN" = "" -o "$DOMAIN" = "localdomain" -o "$DOMAIN" = "(none)" ] && DOMAIN=$(grep "^search " /etc/resolv.conf | cut -d' ' -f2)

## Agent de clefs SSH/GPG
KEYCHAIN=~/.keychain/$(hostname)-sh
[ -r "${KEYCHAIN}"     ] && source ${KEYCHAIN}
[ -r "${KEYCHAIN}-gpg" ] && source ${KEYCHAIN}-gpg

__debug ()
{
    [ -n "$DEBUG" ] && echo >&2 $@
}

export USER HOST DOMAIN UID

if [ -d $ZDOTDIR ]; then

	for script in $ZDOTDIR/??_*.zsh
	do

        __debug -n "${${script:t:r}/??_/}... "
		source $script
		__debug

        for i in	"net:$DOMAIN"\
					"host:$HOST"\
					"sys:$OSNAME"\
					"user:$USER"\
					"user:$USER/net:$DOMAIN"\
					"user:$SUDO_USER"\
					"net:$DOMAIN/host:$HOST"\
					"net:$DOMAIN/sys:$OSNAME"\
					"net:$DOMAIN/user:$USER"\
					"net:$DOMAIN/user:$SUDO_USER"\
					"net:$DOMAIN/host:$HOST/sys:$OSNAME"\
					"net:$DOMAIN/host:$HOST/user:$USER"\
					"net:$DOMAIN/host:$HOST/user:$SUDO_USER"\
					"net:$DOMAIN/host:$HOST/sys:$OSNAME"\
					"net:$DOMAIN/host:$HOST/sys:$OSNAME/user:$USER"\
					"net:$DOMAIN/host:$HOST/sys:$OSNAME/user:$SUDO_USER"\
					"host:$HOST/sys:$OSNAME"\
					"host:$HOST/user:$USER"\
					"host:$HOST/user:$SUDO_USER"\
					"host:$HOST/sys:$OSNAME/user:$USER"\
					"host:$HOST/sys:$OSNAME/user:$SUDO_USER"
        do
            specific_script=${script:h}/$i/${${script:t}/??_/}
            if test -f $specific_script
			then
                __debug -n "$i/${${specific_script:t:r}/??_/}... ";
				source $specific_script
                __debug
			fi
            if test -f $specific_script.gpg
			then
                __debug -n "$i/${${specific_script:t:r}/??_/} [CRYPTED]... ";
				eval $(gpg --quiet --decrypt $specific_script.gpg)
				__debug
			fi
        done
	done
fi

# For sudo shells
if [ ! -z "$SUDO_USER" ]
then
	export HOME=~$USER
	[ "`pwd`" = ~$SUDO_USER ] && cd
fi