|
@@ -95,6 +95,7 @@ MINIMAL_INSTALL="yes"
|
95
|
95
|
DEFAULT_LANGUAGE='en_GB.UTF-8'
|
96
|
96
|
ONION_ONLY="no"
|
97
|
97
|
SELECTED_USERNAME=
|
|
98
|
+SOCIALINSTANCE=
|
98
|
99
|
|
99
|
100
|
# Mirrors settings
|
100
|
101
|
FRIENDS_MIRRORS_SERVER=
|
|
@@ -144,13 +145,14 @@ function show_help {
|
144
|
145
|
echo $'Creates an inventory of remote backup locations'
|
145
|
146
|
echo ''
|
146
|
147
|
echo ''
|
147
|
|
- echo $' -h --help Show help'
|
148
|
|
- echo $' -f --filename Configuration file (usually freedombone.cfg)'
|
149
|
|
- echo $' -m --min Minimum password length (characters)'
|
150
|
|
- echo $' -w --www Freedombone web site'
|
151
|
|
- echo $' -b --bm Freedombone support Bitmessage address'
|
152
|
|
- echo $' -o --onion [yes|no] Whether to only create .onion sites'
|
153
|
|
- echo $' --minimal [yes|no] For minimalistic "consumer grade" installs'
|
|
148
|
+ echo $' -h --help Show help'
|
|
149
|
+ echo $' -f --filename Configuration file (usually freedombone.cfg)'
|
|
150
|
+ echo $' -m --min Minimum password length (characters)'
|
|
151
|
+ echo $' -w --www Freedombone web site'
|
|
152
|
+ echo $' -b --bm Freedombone support Bitmessage address'
|
|
153
|
+ echo $' -o --onion [yes|no] Whether to only create .onion sites'
|
|
154
|
+ echo $' --minimal [yes|no] For minimalistic "consumer grade" installs'
|
|
155
|
+ echo $' --social [gnusocial|postactiv] Create gnusocial/postactiv instance'
|
154
|
156
|
echo ''
|
155
|
157
|
exit 0
|
156
|
158
|
}
|
|
@@ -184,7 +186,63 @@ function choose_email_address {
|
184
|
186
|
save_configuration_values
|
185
|
187
|
}
|
186
|
188
|
|
|
189
|
+function choose_social_instance_domain_name {
|
|
190
|
+ DEFAULT_DOMAIN_DETAILS_COMPLETE=
|
|
191
|
+ while [ ! $DEFAULT_DOMAIN_DETAILS_COMPLETE ]
|
|
192
|
+ do
|
|
193
|
+ data=$(tempfile 2>/dev/null)
|
|
194
|
+ trap "rm -f $data" 0 1 2 5 15
|
|
195
|
+ if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
|
|
196
|
+ dialog --backtitle $"Freedombone Configuration" \
|
|
197
|
+ --title $"Instance domain" \
|
|
198
|
+ --form $"\nEnter your instance domain name and its FreeDNS code:" 11 55 3 \
|
|
199
|
+ $"Domain:" 1 1 "$(grep 'DEFAULT_DOMAIN_NAME' temp.cfg | awk -F '=' '{print $2}')" 1 24 33 40 \
|
|
200
|
+ $"Code:" 2 1 "$(grep 'DEFAULT_DOMAIN_CODE' temp.cfg | awk -F '=' '{print $2}')" 2 24 33 255 \
|
|
201
|
+ 2> $data
|
|
202
|
+ sel=$?
|
|
203
|
+ case $sel in
|
|
204
|
+ 1) exit 1;;
|
|
205
|
+ 255) exit 1;;
|
|
206
|
+ esac
|
|
207
|
+ DEFAULT_DOMAIN_NAME=$(cat $data | sed -n 1p)
|
|
208
|
+ DEFAULT_DOMAIN_CODE=$(cat $data | sed -n 2p)
|
|
209
|
+ if [ $DEFAULT_DOMAIN_NAME ]; then
|
|
210
|
+ validate_freedns_code "$DEFAULT_DOMAIN_CODE"
|
|
211
|
+ if [ ! $VALID_CODE ]; then
|
|
212
|
+ DEFAULT_DOMAIN_NAME=
|
|
213
|
+ fi
|
|
214
|
+ fi
|
|
215
|
+ else
|
|
216
|
+ dialog --backtitle $"Freedombone Configuration" \
|
|
217
|
+ --inputbox $"Enter your instance domain name:" 10 45 \
|
|
218
|
+ "$(grep 'DEFAULT_DOMAIN_NAME' temp.cfg | awk -F '=' '{print $2}')" 2> $data
|
|
219
|
+ sel=$?
|
|
220
|
+ case $sel in
|
|
221
|
+ 0) DEFAULT_DOMAIN_NAME=$(cat $data);;
|
|
222
|
+ 1) exit 1;;
|
|
223
|
+ 255) exit 1;;
|
|
224
|
+ esac
|
|
225
|
+ fi
|
|
226
|
+ if [ $DEFAULT_DOMAIN_NAME ]; then
|
|
227
|
+ TEST_DOMAIN_NAME=$DEFAULT_DOMAIN_NAME
|
|
228
|
+ validate_domain_name
|
|
229
|
+ if [[ $TEST_DOMAIN_NAME != $DEFAULT_DOMAIN_NAME ]]; then
|
|
230
|
+ DEFAULT_DOMAIN_NAME=
|
|
231
|
+ dialog --title $"Domain name validation" --msgbox "$TEST_DOMAIN_NAME" 15 50
|
|
232
|
+ else
|
|
233
|
+ DEFAULT_DOMAIN_DETAILS_COMPLETE="yes"
|
|
234
|
+ fi
|
|
235
|
+ fi
|
|
236
|
+ done
|
|
237
|
+ save_configuration_values
|
|
238
|
+}
|
|
239
|
+
|
187
|
240
|
function choose_default_domain_name {
|
|
241
|
+ if [ $SOCIALINSTANCE ]; then
|
|
242
|
+ choose_social_instance_domain_name
|
|
243
|
+ return
|
|
244
|
+ fi
|
|
245
|
+
|
188
|
246
|
if [[ $ONION_ONLY != "no" ]]; then
|
189
|
247
|
DEFAULT_DOMAIN_NAME="${PROJECT_NAME}.local"
|
190
|
248
|
else
|
|
@@ -782,6 +840,12 @@ do
|
782
|
840
|
shift
|
783
|
841
|
FREEDOMBONE_WEBSITE="$1"
|
784
|
842
|
;;
|
|
843
|
+ --social)
|
|
844
|
+ shift
|
|
845
|
+ if [[ "$1" == 'gnusocial' || "$1" == 'postactiv' ]]; then
|
|
846
|
+ SOCIALINSTANCE="$1"
|
|
847
|
+ fi
|
|
848
|
+ ;;
|
785
|
849
|
--minimal)
|
786
|
850
|
shift
|
787
|
851
|
MINIMAL_INSTALL="$1"
|
|
@@ -1046,10 +1110,14 @@ function interactive_config {
|
1046
|
1110
|
|
1047
|
1111
|
interactive_select_language
|
1048
|
1112
|
|
1049
|
|
- if [[ $ONION_ONLY == "no" ]]; then
|
1050
|
|
- INITIAL_MESSAGE=$"Welcome to the Freedombone interactive installer. Communications freedom is only a short time away.\n\nEnsure that you have your domain and dynamic DNS settings ready.\n\nFor more information please visit $FREEDOMBONE_WEBSITE."
|
|
1113
|
+ if [ $SOCIALINSTANCE ]; then
|
|
1114
|
+ INITIAL_MESSAGE=$"Welcome to your Freedombone $SOCIALINSTANCE instance.\n\nEnsure that you have your domain and dynamic DNS settings ready.\n\nFor more information please visit ${FREEDOMBONE_WEBSITE}/socialinstance.html."
|
1051
|
1115
|
else
|
1052
|
|
- INITIAL_MESSAGE=$"Welcome to the Freedombone interactive installer. Communications freedom is only a short time away.\n\nWeb sites created will only be viewable within a Tor browser.\n\nFor more information please visit $FREEDOMBONE_WEBSITE."
|
|
1116
|
+ if [[ $ONION_ONLY == "no" ]]; then
|
|
1117
|
+ INITIAL_MESSAGE=$"Welcome to the Freedombone interactive installer. Communications freedom is only a short time away.\n\nEnsure that you have your domain and dynamic DNS settings ready.\n\nFor more information please visit $FREEDOMBONE_WEBSITE."
|
|
1118
|
+ else
|
|
1119
|
+ INITIAL_MESSAGE=$"Welcome to the Freedombone interactive installer. Communications freedom is only a short time away.\n\nWeb sites created will only be viewable within a Tor browser.\n\nFor more information please visit $FREEDOMBONE_WEBSITE."
|
|
1120
|
+ fi
|
1053
|
1121
|
fi
|
1054
|
1122
|
|
1055
|
1123
|
dialog --title $"Freedombone" --msgbox "$INITIAL_MESSAGE" 15 50
|