summaryrefslogtreecommitdiffstats
path: root/scripts/mount-store
blob: 715a8a4a7f665932ac7706ba402fbd2fbf210bc4 (plain) (blame)
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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
#!/bin/bash

if [ $# -lt 2 ]; then
	echo "Bad call to $0." >&2
	echo "Expected: $0 images <source> [username] [password]" >&2
	exit 1
fi

declare -rg CIFS_OPTS="/opt/openslx/cifs.opts"
declare -rg NFS_OPTS="/opt/openslx/nfs.opts"

WHAT="$1"
SOURCE="$2"
USERNAME="$3"
PASSWORD="$4"

# Currently WHAT can only be images (the central store for all images),
# but maybe there will be other storage types in the future.
case "$WHAT" in
images)
	DEST="/srv/openslx/nfs"
	;;
*)
	echo "Invalid/Unknown mount type: '$WHAT'." >&2
	exit 1
	;;
esac

FLAG="${DEST}/.notmounted"
SUBDIR="${DEST}/bwlehrpool_store"

storage_test () {
	rm -f -- "${FLAG}"
	if [ -e "${FLAG}" ]; then
		echo "Error: File '.notmounted' exists on remote storage and could not be deleted." >&2
		echo "Error: Make sure the share is writable." >&2
		return 5
	fi
	chgrp images "${DEST}" 2>/dev/null
	mkdir -p "${SUBDIR}"
	if [ ! -d "${SUBDIR}" ]; then
		echo "Error: Could not create $(basename "$SUBDIR")! Storage not writable!" >&2
		return 6
	fi
	echo "Applying group..."
	find "${SUBDIR}" -type d -exec chgrp images {} \; 2>/dev/null
	echo "Applying permissions..."
	find "${SUBDIR}" -type d -exec chmod ug+rwx {} \; 2>/dev/null
	echo "Creating test file..."
	local TEST="${SUBDIR}/.deleteme-$RANDOM-$RANDOM"
	sudo -n -u dmsd touch "$TEST"
	local RET=$?
	if [ -e "$TEST" ]; then
		sudo -n -u dmsd rm -f -- "$TEST"
	else
		[ "$RET" = "0" ] && RET=127
		echo "Error: Mounted share is not writable." >&2
		ls -al "${DEST}" "${SUBDIR}" >&2
	fi
	return $RET
}

# Already mounted?
TRIES=0
while awk '{print $2}' "/proc/mounts" | grep -q "^${DEST}\$"; do
	echo "Trying to unmount '$DEST'..."
	if [ "$TRIES" -gt 5 ]; then
		echo "Error: Cannot unmount '$DEST', giving up." >&2
		exit "$RET"
	elif [ "$TRIES" -gt 3 ]; then
		umount -v -f "$DEST"
	else
		umount -v "$DEST"
	fi
	RET=$?
	if [ "$RET" -ne "0" ]; then
		cat >&2 <<-HEREDOC
			Error: Cannot unmount '$DEST'!
			Storage might be in use (running VM upload etc.)
			Try stopping DMSD first

			If the problem persists, try rebooting the server.
		HEREDOC
		exit "$RET"
	fi
	TRIES=$(( $TRIES + 1 ))
done

# Sanity checks: Destination exists?
if [ ! -d "$DEST" ]; then
	mkdir -p "$DEST"
	chown root:images "$DEST"
	chmod 0775 "$DEST"
fi

# Still a no?
if [ ! -d "$DEST" ]; then
	echo "Mount point '$DEST' does not exist and could not be created!" >&2
	echo "This should not happen and means this server is severely messed up. :(" >&2
	exit 1
fi

# Unmount and not requested to mount (local mode)
if [[ "${SOURCE}" == "null" ]]; then
	rm -f -- "${FLAG}"
	echo "Success. Now using internal storage."
	exit 0
fi

touch "${FLAG}"

if [[ "${SOURCE}" == "unknown" ]]; then
	echo "Storage type not configured, doing nothing."
	exit 0
fi

# Mount!

if grep -E -q '^[^/].+:.+' <<<$SOURCE; then
	# seems to be NFS
	for opt in vers=4 vers=3; do
		echo " * Trying ${opt}..."
		mount -v -t nfs -o rw,noatime,noexec,nodev,async,nolock,$opt,fg,ac,retry=0,timeo=200,sec=sys "$SOURCE" "$DEST"
		RET=$?
		[ "$RET" -ne "0" ] && continue
		echo "Mount succeeded, checking write permissions...."
		storage_test
		RET=$?
		[ "$RET" -eq "0" ] && break
		umount -v "$DEST" || umount -v -f -l "$DEST"
	done
elif grep -E -q '^//' <<<$SOURCE; then
	# seems to be SMB
	export USER="$USERNAME"
	export PASSWD="$PASSWORD"
	RET=999
	OPTSTR=
	if [ -f "$CIFS_OPTS" ]; then
		OPTSTR=$(cat "$CIFS_OPTS")
	fi
	if [ -n "$OPTSTR" ]; then
		echo " * Trying last successful mount options..."
		if mount -v -t cifs -o "$OPTSTR" "$SOURCE" "$DEST"; then
			echo "Mount succeeded, checking write permissions...."
			storage_test
			RET=$?
			if [ "$RET" -ne "0" ]; then
				umount -v "$DEST" || umount -v -f -l "$DEST"
			fi
		fi
	fi
	if [ "$RET" -ne "0" ]; then
		for vers in "" "3.0" "2.1" "1.0" "2.0"; do
			[ -n "$vers" ] && vers=",vers=${vers}"
			for sec in "" "ntlmssp" "ntlmv2" "ntlm"; do
				[ -n "$sec" ] && sec=",sec=${sec}"
				echo " * Trying ...${vers}${sec}..."
				OPTSTR="rw,uid=0,gid=12345,forceuid,forcegid,nounix,file_mode=0664,dir_mode=0775$vers$sec"
				mount -v -t cifs -o "$OPTSTR" "$SOURCE" "$DEST"
				RET=$?
				[ "$RET" -ne "0" ] && continue
				echo "Mount succeeded, checking write permissions...."
				storage_test
				RET=$?
				[ "$RET" -eq "0" ] && break
				umount -v "$DEST" || umount -v -f -l "$DEST"
			done
			[ "$RET" -eq "0" ] && break
		done
		if [ "$RET" -eq "0" ] && [ -n "$OPTSTR" ]; then
			echo "$OPTSTR" > "$CIFS_OPTS"
		fi
	fi
	unset USER PASSWD
else
	echo "Unknown mount type: $SOURCE"
	exit 1
fi

echo ""

if [ "$RET" = "0" ]; then
	echo "----------------------------------"
	echo "-- Share mounted successfully!  --"
	echo "----------------------------------"
fi

exit $RET