root / snf-image-helper / tasks / 50EnforcePersonality.in @ 10bf026d
History | View | Annotate | Download (2.2 kB)
1 |
#! /bin/bash |
---|---|
2 |
|
3 |
# Copyright (C) 2011 GRNET S.A. |
4 |
# |
5 |
# This program is free software; you can redistribute it and/or modify |
6 |
# it under the terms of the GNU General Public License as published by |
7 |
# the Free Software Foundation; either version 2 of the License, or |
8 |
# (at your option) any later version. |
9 |
# |
10 |
# This program is distributed in the hope that it will be useful, but |
11 |
# WITHOUT ANY WARRANTY; without even the implied warranty of |
12 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
13 |
# General Public License for more details. |
14 |
# |
15 |
# You should have received a copy of the GNU General Public License |
16 |
# along with this program; if not, write to the Free Software |
17 |
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA |
18 |
# 02110-1301, USA. |
19 |
|
20 |
### BEGIN TASK INFO |
21 |
# Provides: EnforcePersonality |
22 |
# RunBefore: UmountImage |
23 |
# RunAfter: DeleteSSHKeys |
24 |
# Short-Description: Inject files to the instance |
25 |
### END TASK INFO |
26 |
|
27 |
set -e |
28 |
|
29 |
. "@commondir@/common.sh" |
30 |
|
31 |
# Check if the task should be prevented from running. |
32 |
check_if_excluded |
33 |
|
34 |
if [ ! -d "$SNF_IMAGE_TARGET" ]; then |
35 |
log_error "Target dir: \`$SNF_IMAGE_TARGET' is missing" |
36 |
fi |
37 |
|
38 |
if [ -z "$SNF_IMAGE_PERSONALITY" ]; then |
39 |
warn "This image has no personality (0 files to inject)" |
40 |
exit 0 |
41 |
fi |
42 |
|
43 |
if [ "$SNF_IMAGE_PROPERTY_OSFAMILY" = "windows" ]; then |
44 |
echo "$SNF_IMAGE_PERSONALITY" | |
45 |
@scriptsdir@/inject-files.py "$SNF_IMAGE_TARGET" |
46 |
exit 0 |
47 |
elif [ "$SNF_IMAGE_PROPERTY_OSFAMILY" = "linux" ]; then |
48 |
tmpdir=$(chroot "$SNF_IMAGE_TARGET" mktemp -d) |
49 |
add_cleanup rm -rf "$SNF_IMAGE_TARGET/$tmpdir" |
50 |
echo "$SNF_IMAGE_PERSONALITY" | |
51 |
@scriptsdir@/inject-files.py -d "$SNF_IMAGE_TARGET/$tmpdir" |
52 |
chroot "$SNF_IMAGE_TARGET" chmod 777 "$tmpdir" |
53 |
{ |
54 |
while read -d $'\0' src; do |
55 |
read -d $'\0' owner; |
56 |
read -d $'\0' group; |
57 |
read -d $'\0' mode; |
58 |
read -d $'\0' dest; |
59 |
chroot "$SNF_IMAGE_TARGET" chown "$owner:$group" "$tmpdir/$src" |
60 |
chroot "$SNF_IMAGE_TARGET" su -l "$owner" -c \ |
61 |
"install -D -m $mode $(printf "%q" "$tmpdir")/$src \ |
62 |
$(printf "%q" "$dest")" |
63 |
done |
64 |
} < "$SNF_IMAGE_TARGET/$tmpdir/manifest" |
65 |
fi |
66 |
|
67 |
exit 0 |
68 |
|
69 |
# vim: set sta sts=4 shiftwidth=4 sw=4 et ai : |
70 |
|