Correction : openerp7_burette : -addon : autorise SSH.
[lhc/ateliers.git] / etc / sv / openerp7_burette / local.sh
1 home=/home/"$sv"
2 version=7.0
3
4 "$tool"/local/apt-get-install openerp --force-yes --no-upgrade
5 # XXX: --force-yes car les paquets de nightly.openerp.com
6 # ne sont pas signés par OpenPGP..
7 "$tool"/local/insserv-remove openerp
8
9 "$tool"/local/adduser "$sv" \
10 --disabled-login \
11 --disabled-password \
12 --group \
13 --home "$home" \
14 --shell /bin/false \
15 --system
16 "$tool"/local/adduser "$sv"-addon \
17 --disabled-login \
18 --disabled-password \
19 --group \
20 --home "$home"/addon.d \
21 --shell /bin/sh \
22 --system
23
24 sudo install -d -m 1777 -o root -g root \
25 /etc/openerp \
26 /etc/openerp/$version
27 sudo install -d -m 3771 -o "$sv" -g "$sv" \
28 "$home" \
29 "$home"/etc
30 sudo install -d -m 2750 -o "$sv"-addon -g "$sv"-addon \
31 "$home"/addon.d \
32 "$home"/addon.d/etc
33 sudo ln -fns \
34 /etc/openerp/$version \
35 "$home"/etc/openerp
36
37 while ! sudo -u postgres psql </dev/null
38 do sleep 1; done
39 "$tool"/local/postgresql-user-create "$sv"
40 for db in \
41 cyclo_ivry \
42 cyclo_pantin \
43 cyclo_paris_est \
44 dynamo \
45 ptitvelo \
46 velorution_idf \
47 velosenville \
48 vieuxbiclou
49 do
50 #"$tool"/local/postgresql-role-create "${sv}_$db"
51 "$tool"/local/postgresql-database-create "${sv}_$db" "$sv"
52 sudo -u postgres psql -AqtX "${sv}_$db" <<-EOF
53 \set ON_ERROR_STOP on
54 GRANT USAGE ON SCHEMA pg_catalog TO $sv;
55 GRANT SELECT ON TABLE pg_catalog.pg_attribute TO $sv;
56 GRANT SELECT ON TABLE pg_catalog.pg_class TO $sv;
57 GRANT SELECT ON TABLE pg_catalog.pg_constraint TO $sv;
58 GRANT SELECT ON TABLE pg_catalog.pg_indexes TO $sv;
59 GRANT SELECT ON TABLE pg_catalog.pg_proc TO $sv;
60 GRANT SELECT ON TABLE pg_catalog.pg_type TO $sv;
61 EOF
62 done
63
64 sudo adduser git "$sv"-addon
65 sudo adduser "$sv" "$sv"-addon
66 sudo adduser "$sv" postgres-data
67
68 for addon in \
69 bikecoop \
70 bikecoop_l10n_fr \
71 pos_membership \
72 remembership \
73 cyclofficine_ivry \
74 cyclofficine_paris_est \
75 no_db_management \
76 ptitvelo \
77 velorution_idf \
78 velosenville
79 #vieuxbiclou_mpt
80 #dynamo \
81 #cyclofficine_pantin \
82 do
83 sudo install -d -m 2771 -o "$sv" -g "$sv"-addon \
84 "$home"/addon.d/"$addon"
85 sudo -u git git \
86 --git-dir ~git-data/burette/"$addon".git \
87 --work-tree="$home"/addon.d/"$addon" \
88 checkout -f master
89 sudo -u git git \
90 --git-dir ~git-data/burette/"$addon".git \
91 --work-tree="$home"/addon.d/"$addon" \
92 clean -d -e sec/ -f -f -x
93 sudo chmod a-x \
94 /home/git/data/burette/"$addon".git/hooks/post-update.sample
95 sudo install -m 550 -o git -g git /dev/stdin \
96 /home/git/data/burette/"$addon".git/hooks/post-update <<-EOF
97 #!/bin/sh -efux
98 find . -type f -perm /+x -name 'post-update.*' |
99 while IFS= read -r hook
100 do "\$hook" "\$@"
101 done
102 EOF
103 sudo install -m 550 -o git -g git /dev/stdin \
104 /home/git/data/burette/"$addon".git/hooks/post-update."$sv" <<-EOF
105 #!/bin/sh -efux
106 case \$1 in
107 (refs/heads/master)
108 git \\
109 --git-dir ~git-data/burette/"$addon".git \\
110 --work-tree="$home"/addon.d/"$addon" \\
111 checkout -f master
112 git \\
113 --git-dir ~git-data/burette/"$addon".git \\
114 --work-tree="$home"/addon.d/"$addon" \\
115 clean -d -e sec/ -f -f -x
116 #sv restart "$sv"
117 ;;
118 esac
119 EOF
120 done