freedombone-config 36KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014
  1. #!/bin/bash
  2. #
  3. # .---. . .
  4. # | | |
  5. # |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
  6. # | | (.-' (.-' ( | ( )| | | | )( )| | (.-'
  7. # ' ' --' --' -' - -' ' ' -' -' -' ' - --'
  8. #
  9. # Freedom in the Cloud
  10. #
  11. # Interactively creates a configuration file for use with the main
  12. # freedombone command
  13. #
  14. # License
  15. # =======
  16. #
  17. # Copyright (C) 2015-2016 Bob Mottram <bob@freedombone.net>
  18. #
  19. # This program is free software: you can redistribute it and/or modify
  20. # it under the terms of the GNU Affero General Public License as published by
  21. # the Free Software Foundation, either version 3 of the License, or
  22. # (at your option) any later version.
  23. #
  24. # This program is distributed in the hope that it will be useful,
  25. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  26. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  27. # GNU Affero General Public License for more details.
  28. #
  29. # You should have received a copy of the GNU Affero General Public License
  30. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  31. NO_OF_ARGS=$#
  32. PROJECT_NAME='freedombone'
  33. # username created by default within a debian image
  34. GENERIC_IMAGE_USERNAME='fbone'
  35. export TEXTDOMAIN=${PROJECT_NAME}-config
  36. export TEXTDOMAINDIR="/usr/share/locale"
  37. # Web site
  38. FREEDOMBONE_WEBSITE="https://freedombone.net or http://4fvfozz6g3zmvf76.onion"
  39. # Minimum number of characters in a password
  40. MINIMUM_PASSWORD_LENGTH=$(cat /usr/share/${PROJECT_NAME}/utils/${PROJECT_NAME}-utils-passwords | grep 'MINIMUM_PASSWORD_LENGTH=' | head -n 1 | awk -F '=' '{print $2}')
  41. # file containing new password
  42. IMAGE_PASSWORD_FILE=/root/login.txt
  43. MY_USERNAME=
  44. DEFAULT_DOMAIN_NAME=
  45. DEFAULT_DOMAIN_CODE=
  46. MY_EMAIL_ADDRESS=
  47. SYSTEM_TYPE='full'
  48. INSTALLING_ON_BBB="no"
  49. DDNS_PROVIDER=
  50. DDNS_USERNAME=
  51. DDNS_PASSWORD=
  52. MY_NAME=
  53. LOCAL_NETWORK_STATIC_IP_ADDRESS=
  54. ROUTER_IP_ADDRESS=
  55. ENABLE_BATMAN=
  56. DEBIAN_REPO=
  57. NAMESERVER1=
  58. NAMESERVER2=
  59. DOKUWIKI_TITLE=
  60. DOKUWIKI_DOMAIN_NAME=
  61. DOKUWIKI_CODE=
  62. HTMLY_TITLE=
  63. HTMLY_DOMAIN_NAME=
  64. HTMLY_CODE=
  65. HUBZILLA_DOMAIN_NAME=
  66. HUBZILLA_CODE=
  67. GNUSOCIAL_DOMAIN_NAME=
  68. GNUSOCIAL_CODE=
  69. GNUSOCIAL_WELCOME_MESSAGE=$"<h1>Welcome to \$GNUSOCIAL_DOMAIN_NAME – a federated social network</h1><p>Another $PROJECT_NAME site</p>"
  70. GNUSOCIAL_BACKGROUND_IMAGE_URL=
  71. GIT_DOMAIN_NAME=
  72. GIT_CODE=
  73. USB_DRIVE=/dev/sdb1
  74. HWRNG_TYPE=
  75. ENABLE_SOCIAL_KEY_MANAGEMENT=
  76. WIFI_INTERFACE=wlan0
  77. WIFI_TYPE='wpa2-psk'
  78. WIFI_SSID=
  79. WIFI_PASSPHRASE=
  80. WIFI_HOTSPOT=
  81. WIFI_NETWORKS_FILE=~/${PROJECT_NAME}-wifi.cfg
  82. BATMAN_CELLID='any'
  83. WIFI_CHANNEL=
  84. CONFIGURATION_FILE=
  85. DH_KEYLENGTH=
  86. MINIMAL_INSTALL="yes"
  87. DEFAULT_LANGUAGE='en_GB.UTF-8'
  88. ONION_ONLY="no"
  89. SELECTED_USERNAME=
  90. # Mirrors settings
  91. FRIENDS_MIRRORS_SERVER=
  92. FRIENDS_MIRRORS_SSH_PORT=2222
  93. FRIENDS_MIRRORS_PASSWORD=
  94. MY_MIRRORS_PASSWORD=
  95. VALID_CODE=
  96. PROJECT_INSTALL_DIR=/usr/local/bin
  97. if [ -f /usr/bin/${PROJECT_NAME} ]; then
  98. PROJECT_INSTALL_DIR=/usr/bin
  99. fi
  100. source $PROJECT_INSTALL_DIR/${PROJECT_NAME}-vars
  101. UTILS_FILES=/usr/share/${PROJECT_NAME}/utils/${PROJECT_NAME}-utils-*
  102. for f in $UTILS_FILES
  103. do
  104. source $f
  105. done
  106. APP_FILES=/usr/share/${PROJECT_NAME}/apps/${PROJECT_NAME}-app-*
  107. for f in $APP_FILES
  108. do
  109. source $f
  110. done
  111. function show_help {
  112. echo ''
  113. echo $"${PROJECT_NAME}-config -f [config filename] -m [min password length]"
  114. echo ''
  115. echo $'Creates an inventory of remote backup locations'
  116. echo ''
  117. echo ''
  118. echo $' -h --help Show help'
  119. echo $' -f --filename Configuration file (usually freedombone.cfg)'
  120. echo $' -m --min Minimum password length (characters)'
  121. echo $' -w --www Freedombone web site'
  122. echo $' -b --bm Freedombone support Bitmessage address'
  123. echo $' -o --onion [yes|no] Whether to only create .onion sites'
  124. echo $' --minimal [yes|no] For minimalistic "consumer grade" installs'
  125. echo ''
  126. exit 0
  127. }
  128. function choose_email_address {
  129. if [[ $ONION_ONLY != "no" ]]; then
  130. EMAIL_ADDRESS=$MY_USERNAME@$DEFAULT_DOMAIN_NAME
  131. else
  132. while [ ${#MY_EMAIL_ADDRESS} -lt 5 ]
  133. do
  134. EMAIL_ADDRESS=$(grep 'MY_EMAIL_ADDRESS' temp.cfg | awk -F '=' '{print $2}')
  135. if [ ! $EMAIL_ADDRESS ]; then
  136. EMAIL_ADDRESS=$MY_USERNAME@$DEFAULT_DOMAIN_NAME
  137. fi
  138. if [ ${#MY_EMAIL_ADDRESS} -lt 5 ]; then
  139. EMAIL_ADDRESS=$MY_USERNAME@$DEFAULT_DOMAIN_NAME
  140. fi
  141. data=$(tempfile 2>/dev/null)
  142. trap "rm -f $data" 0 1 2 5 15
  143. dialog --backtitle $"Freedombone Configuration" \
  144. --inputbox $"Your email address" 10 30 "$EMAIL_ADDRESS" 2> $data
  145. sel=$?
  146. case $sel in
  147. 0) MY_EMAIL_ADDRESS=$(cat $data);;
  148. 1) exit 1;;
  149. 255) exit 1;;
  150. esac
  151. done
  152. fi
  153. save_configuration_values
  154. }
  155. function choose_default_domain_name {
  156. if [[ $ONION_ONLY != "no" ]]; then
  157. DEFAULT_DOMAIN_NAME="${PROJECT_NAME}.local"
  158. else
  159. DEFAULT_DOMAIN_DETAILS_COMPLETE=
  160. while [ ! $DEFAULT_DOMAIN_DETAILS_COMPLETE ]
  161. do
  162. data=$(tempfile 2>/dev/null)
  163. trap "rm -f $data" 0 1 2 5 15
  164. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  165. dialog --backtitle $"Freedombone Configuration" \
  166. --title $"Your main domain name" \
  167. --form $"\nWhich domain name should your email/XMPP/IRC/Mumble be associated with?" 13 55 5 \
  168. $"Domain:" 1 1 "$(grep 'DEFAULT_DOMAIN_NAME' temp.cfg | awk -F '=' '{print $2}')" 1 24 33 40 \
  169. $"Code:" 2 1 "$(grep 'DEFAULT_DOMAIN_CODE' temp.cfg | awk -F '=' '{print $2}')" 2 24 33 255 \
  170. $"mail subdomain Code:" 3 1 "$(grep 'EMAIL_DOMAIN_CODE' temp.cfg | awk -F '=' '{print $2}')" 3 24 33 255 \
  171. $"XMPP subdomain Code:" 4 1 "$(grep 'XMPP_DOMAIN_CODE' temp.cfg | awk -F '=' '{print $2}')" 4 24 33 255 \
  172. 2> $data
  173. sel=$?
  174. case $sel in
  175. 1) exit 1;;
  176. 255) exit 1;;
  177. esac
  178. DEFAULT_DOMAIN_NAME=$(cat $data | sed -n 1p)
  179. DEFAULT_DOMAIN_CODE=$(cat $data | sed -n 2p)
  180. EMAIL_DOMAIN_CODE=$(cat $data | sed -n 2p)
  181. XMPP_DOMAIN_CODE=$(cat $data | sed -n 2p)
  182. if [ $DEFAULT_DOMAIN_NAME ]; then
  183. validate_freedns_code "$DEFAULT_DOMAIN_CODE"
  184. if [ ! $VALID_CODE ]; then
  185. DEFAULT_DOMAIN_NAME=
  186. fi
  187. fi
  188. if [ $EMAIL_DOMAIN_CODE ]; then
  189. validate_freedns_code "$EMAIL_DOMAIN_CODE"
  190. if [ ! $VALID_CODE ]; then
  191. DEFAULT_DOMAIN_NAME=
  192. EMAIL_DOMAIN_CODE=
  193. else
  194. write_config_param "EMAIL_DOMAIN_CODE" "$EMAIL_DOMAIN_CODE"
  195. fi
  196. fi
  197. if [ $XMPP_DOMAIN_CODE ]; then
  198. validate_freedns_code "$XMPP_DOMAIN_CODE"
  199. if [ ! $VALID_CODE ]; then
  200. DEFAULT_DOMAIN_NAME=
  201. XMPP_DOMAIN_CODE=
  202. else
  203. write_config_param "XMPP_DOMAIN_CODE" "$XMPP_DOMAIN_CODE"
  204. fi
  205. fi
  206. else
  207. dialog --backtitle $"Freedombone Configuration" \
  208. --inputbox $"Which domain name should your email/XMPP/IRC/Mumble be associated with?" 10 45 \
  209. "$(grep 'DEFAULT_DOMAIN_NAME' temp.cfg | awk -F '=' '{print $2}')" 2> $data
  210. sel=$?
  211. case $sel in
  212. 0) DEFAULT_DOMAIN_NAME=$(cat $data);;
  213. 1) exit 1;;
  214. 255) exit 1;;
  215. esac
  216. fi
  217. if [ $DEFAULT_DOMAIN_NAME ]; then
  218. TEST_DOMAIN_NAME=$DEFAULT_DOMAIN_NAME
  219. validate_domain_name
  220. if [[ $TEST_DOMAIN_NAME != $DEFAULT_DOMAIN_NAME ]]; then
  221. DEFAULT_DOMAIN_NAME=
  222. dialog --title $"Domain name validation" --msgbox "$TEST_DOMAIN_NAME" 15 50
  223. else
  224. DEFAULT_DOMAIN_DETAILS_COMPLETE="yes"
  225. fi
  226. fi
  227. done
  228. fi
  229. save_configuration_values
  230. }
  231. function choose_dynamic_dns {
  232. if [[ $SYSTEM_TYPE != "mesh"* && $ONION_ONLY == "no" ]]; then
  233. data=$(tempfile 2>/dev/null)
  234. trap "rm -f $data" 0 1 2 5 15
  235. dialog --backtitle $"Freedombone Configuration" \
  236. --radiolist $"Choose Dynamic DNS provider:" 15 40 14 \
  237. 1 dyndns off \
  238. 2 freedns on \
  239. 3 zoneedit off \
  240. 4 no-ip off \
  241. 5 easydns off \
  242. 6 tzo off \
  243. 7 3322 off \
  244. 8 dnsomatic off \
  245. 9 tunnelbroker off \
  246. 10 dns.he.net off \
  247. 11 dynsip off \
  248. 12 sitelutions off \
  249. 13 dnsexit off \
  250. 14 changeip off 2> $data
  251. sel=$?
  252. case $sel in
  253. 1) exit 1;;
  254. 255) exit 1;;
  255. esac
  256. case $(cat $data) in
  257. 1) DDNS_PROVIDER="default@dyndns.org";;
  258. 2) DDNS_PROVIDER="default@freedns.afraid.org";;
  259. 3) DDNS_PROVIDER="default@zoneedit.com";;
  260. 4) DDNS_PROVIDER="default@no-ip.com";;
  261. 5) DDNS_PROVIDER="default@easydns.com";;
  262. 6) DDNS_PROVIDER="default@tzo.com";;
  263. 7) DDNS_PROVIDER="dyndns@3322.org";;
  264. 8) DDNS_PROVIDER="default@dnsomatic.com";;
  265. 9) DDNS_PROVIDER="ipv6tb@he.net";;
  266. 10) DDNS_PROVIDER="dyndns@he.net";;
  267. 11) DDNS_PROVIDER="default@dynsip.org";;
  268. 12) DDNS_PROVIDER="default@sitelutions.com";;
  269. 13) DDNS_PROVIDER="default@dnsexit.com";;
  270. 14) DDNS_PROVIDER="default@changeip.com";;
  271. 255) exit 1;;
  272. esac
  273. save_configuration_values
  274. valid_ddns_username=
  275. while [ ! $valid_ddns_username ]
  276. do
  277. data=$(tempfile 2>/dev/null)
  278. trap "rm -f $data" 0 1 2 5 15
  279. dialog --backtitle $"Freedombone Configuration" \
  280. --inputbox $"Dynamic DNS provider username" 10 30 "$(grep 'DDNS_USERNAME' temp.cfg | awk -F '=' '{print $2}')" 2> $data
  281. sel=$?
  282. case $sel in
  283. 0) possible_username=$(cat $data)
  284. if [ "$possible_username" ]; then
  285. if [ ${#possible_username} -gt 1 ]; then
  286. valid_ddns_username=$(cat $data)
  287. DDNS_USERNAME=$valid_ddns_username
  288. break;
  289. fi
  290. fi
  291. ;;
  292. 1) exit 1;;
  293. 255) exit 1;;
  294. esac
  295. done
  296. save_configuration_values
  297. valid_ddns_password=
  298. while [ ! $valid_ddns_password ]
  299. do
  300. data=$(tempfile 2>/dev/null)
  301. trap "rm -f $data" 0 1 2 5 15
  302. dialog --backtitle $"Freedombone Configuration" \
  303. --clear \
  304. --insecure \
  305. --passwordbox $"Dynamic DNS provider password" 10 30 "$(grep 'DDNS_PASSWORD' temp.cfg | awk -F '=' '{print $2}')" 2> $data
  306. sel=$?
  307. case $sel in
  308. 0) possible_password=$(cat $data)
  309. if [ "$possible_password" ]; then
  310. if [ ${#possible_password} -gt 1 ]; then
  311. valid_ddns_password=$(cat $data)
  312. DDNS_PASSWORD=$valid_ddns_password
  313. break;
  314. fi
  315. fi
  316. ;;
  317. 1) exit 1;;
  318. 255) exit 1;;
  319. esac
  320. if [ ${#DDNS_PASSWORD} -lt $MINIMUM_PASSWORD_LENGTH ]; then
  321. dialog --title $"Password quality check" --msgbox $"The password given was too short. It must be at least $MINIMUM_PASSWORD_LENGTH characters. You may need to change your password on the dynamic DNS provider's web site." 10 40
  322. DDNS_PASSWORD=""
  323. fi
  324. done
  325. save_configuration_values
  326. fi
  327. }
  328. function choose_debian_repo {
  329. if [[ $MINIMAL_INSTALL == "no" ]]; then
  330. data=$(tempfile 2>/dev/null)
  331. trap "rm -f $data" 0 1 2 5 15
  332. dialog --backtitle $"Freedombone Configuration" \
  333. --radiolist $"Where to download Debian packages from:" 25 45 49 \
  334. 1 $"Australia" off \
  335. 2 $"Austria" off \
  336. 3 $"Belarus" off \
  337. 4 $"Belgium" off \
  338. 5 $"Bosnia and Herzegovina" off \
  339. 6 $"Brazil" off \
  340. 7 $"Bulgaria" off \
  341. 8 $"Canada" off \
  342. 9 $"Chile" off \
  343. 10 $"China" off \
  344. 11 $"Croatia" off \
  345. 12 $"Czech Republic" off \
  346. 13 $"Denmark" off \
  347. 14 $"El Salvador" off \
  348. 15 $"Estonia" off \
  349. 16 $"Finland" off \
  350. 17 $"France 1" off \
  351. 18 $"France 2" off \
  352. 19 $"Germany 1" off \
  353. 20 $"Germany 2" off \
  354. 21 $"Greece" off \
  355. 22 $"Hungary" off \
  356. 23 $"Iceland" off \
  357. 24 $"Iran" off \
  358. 25 $"Ireland" off \
  359. 26 $"Italy" off \
  360. 27 $"Japan" off \
  361. 28 $"Korea" off \
  362. 29 $"Lithuania" off \
  363. 30 $"Mexico" off \
  364. 31 $"Netherlands" off \
  365. 32 $"New Caledonia" off \
  366. 33 $"New Zealand" off \
  367. 34 $"Norway" off \
  368. 35 $"Poland" off \
  369. 36 $"Portugal" off \
  370. 37 $"Romania" off \
  371. 38 $"Russia" off \
  372. 39 $"Slovakia" off \
  373. 40 $"Slovenia" off \
  374. 41 $"Spain" off \
  375. 42 $"Sweden" off \
  376. 43 $"Switzerland" off \
  377. 44 $"Taiwan" off \
  378. 45 $"Thailand" off \
  379. 46 $"Turkey" off \
  380. 47 $"Ukraine" off \
  381. 48 $"United Kingdom" off \
  382. 49 $"United States" on 2> $data
  383. sel=$?
  384. case $sel in
  385. 1) exit 1;;
  386. 255) exit 1;;
  387. esac
  388. case $(cat $data) in
  389. 1) DEBIAN_REPO='ftp.au.debian.org';;
  390. 2) DEBIAN_REPO='ftp.at.debian.org';;
  391. 3) DEBIAN_REPO='ftp.by.debian.org';;
  392. 4) DEBIAN_REPO='ftp.be.debian.org';;
  393. 5) DEBIAN_REPO='ftp.ba.debian.org';;
  394. 6) DEBIAN_REPO='ftp.br.debian.org';;
  395. 7) DEBIAN_REPO='ftp.bg.debian.org';;
  396. 8) DEBIAN_REPO='ftp.ca.debian.org';;
  397. 9) DEBIAN_REPO='ftp.cl.debian.org';;
  398. 10) DEBIAN_REPO='ftp.cn.debian.org';;
  399. 11) DEBIAN_REPO='ftp.hr.debian.org';;
  400. 12) DEBIAN_REPO='ftp.cz.debian.org';;
  401. 13) DEBIAN_REPO='ftp.dk.debian.org';;
  402. 14) DEBIAN_REPO='ftp.sv.debian.org';;
  403. 15) DEBIAN_REPO='ftp.ee.debian.org';;
  404. 16) DEBIAN_REPO='ftp.fi.debian.org';;
  405. 17) DEBIAN_REPO='ftp2.fr.debian.org';;
  406. 18) DEBIAN_REPO='ftp.fr.debian.org';;
  407. 19) DEBIAN_REPO='ftp2.de.debian.org';;
  408. 20) DEBIAN_REPO='ftp.de.debian.org';;
  409. 21) DEBIAN_REPO='ftp.gr.debian.org';;
  410. 22) DEBIAN_REPO='ftp.hu.debian.org';;
  411. 23) DEBIAN_REPO='ftp.is.debian.org';;
  412. 24) DEBIAN_REPO='ftp.ir.debian.org';;
  413. 25) DEBIAN_REPO='ftp.ie.debian.org';;
  414. 26) DEBIAN_REPO='ftp.it.debian.org';;
  415. 27) DEBIAN_REPO='ftp.jp.debian.org';;
  416. 28) DEBIAN_REPO='ftp.kr.debian.org';;
  417. 29) DEBIAN_REPO='ftp.lt.debian.org';;
  418. 30) DEBIAN_REPO='ftp.mx.debian.org';;
  419. 31) DEBIAN_REPO='ftp.nl.debian.org';;
  420. 32) DEBIAN_REPO='ftp.nc.debian.org';;
  421. 33) DEBIAN_REPO='ftp.nz.debian.org';;
  422. 34) DEBIAN_REPO='ftp.no.debian.org';;
  423. 35) DEBIAN_REPO='ftp.pl.debian.org';;
  424. 36) DEBIAN_REPO='ftp.pt.debian.org';;
  425. 37) DEBIAN_REPO='ftp.ro.debian.org';;
  426. 38) DEBIAN_REPO='ftp.ru.debian.org';;
  427. 39) DEBIAN_REPO='ftp.sk.debian.org';;
  428. 40) DEBIAN_REPO='ftp.si.debian.org';;
  429. 41) DEBIAN_REPO='ftp.es.debian.org';;
  430. 42) DEBIAN_REPO='ftp.se.debian.org';;
  431. 43) DEBIAN_REPO='ftp.ch.debian.org';;
  432. 44) DEBIAN_REPO='ftp.tw.debian.org';;
  433. 45) DEBIAN_REPO='ftp.th.debian.org';;
  434. 46) DEBIAN_REPO='ftp.tr.debian.org';;
  435. 47) DEBIAN_REPO='ftp.ua.debian.org';;
  436. 48) DEBIAN_REPO='ftp.uk.debian.org';;
  437. 49) DEBIAN_REPO='ftp.us.debian.org';;
  438. 255) exit 1;;
  439. esac
  440. save_configuration_values
  441. else
  442. DEBIAN_REPO='ftp.de.debian.org'
  443. fi
  444. }
  445. function choose_rng {
  446. if [[ $MINIMAL_INSTALL == "no" ]]; then
  447. data=$(tempfile 2>/dev/null)
  448. trap "rm -f $data" 0 1 2 5 15
  449. if [[ $INSTALLING_ON_BBB != "yes" ]]; then
  450. dialog --backtitle $"Freedombone Configuration" \
  451. --radiolist $"Type of Random Number Generator:" 10 40 2 \
  452. 1 Haveged on \
  453. 2 OneRNG off 2> $data
  454. sel=$?
  455. case $sel in
  456. 1) exit 1;;
  457. 255) exit 1;;
  458. esac
  459. case $(cat $data) in
  460. 2) HWRNG_TYPE="onerng"
  461. dialog --title $"OneRNG Device" \
  462. --msgbox $"Please ensure that the OneRNG device is disconnected. You can reconnect it later during the installation" 8 60
  463. ;;
  464. 255) exit 1;;
  465. esac
  466. else
  467. HWRNG_TYPE="beaglebone"
  468. fi
  469. save_configuration_values
  470. fi
  471. }
  472. function choose_social_key_management {
  473. if [[ $MINIMAL_INSTALL == "no" ]]; then
  474. interactive_gpg
  475. data=$(tempfile 2>/dev/null)
  476. trap "rm -f $data" 0 1 2 5 15
  477. SOCIAL_KEY_STR=$"\nDo you wish to enable social key management, otherwise known as \"the unforgettable key\"?\n\nThis means that fragments of your GPG key will be included with any remote backups so that if you later lose your key then it can be reconstructed from your friends servers. If you select \"no\" then you can still do social key management, but offline using physical USB thumb drives, which is more secure but less convenient."
  478. if [[ $(grep "ENABLE_SOCIAL_KEY_MANAGEMENT" temp.cfg | awk -F '=' '{print $2}') == "yes" ]]; then
  479. dialog --title $"Social Key Management" \
  480. --backtitle $"Freedombone Configuration" \
  481. --yesno "$SOCIAL_KEY_STR" 15 60
  482. else
  483. dialog --title $"Social Key Management" \
  484. --backtitle $"Freedombone Configuration" \
  485. --defaultno \
  486. --yesno "$SOCIAL_KEY_STR" 15 60
  487. fi
  488. sel=$?
  489. case $sel in
  490. 0) ENABLE_SOCIAL_KEY_MANAGEMENT="yes";;
  491. 255) exit 1;;
  492. esac
  493. save_configuration_values
  494. else
  495. # enable for the minimal case
  496. ENABLE_SOCIAL_KEY_MANAGEMENT="yes"
  497. fi
  498. }
  499. function choose_username {
  500. if [ -d /home/$GENERIC_IMAGE_USERNAME ]; then
  501. if [ ! -f $IMAGE_PASSWORD_FILE ]; then
  502. echo 'Cannot find the password file for the admin user'
  503. exit 62753
  504. fi
  505. # when installing from an image which comes with a known default user account
  506. SELECTED_USERNAME=
  507. while [ ! $SELECTED_USERNAME ]
  508. do
  509. if [ ! $SELECTED_USERNAME ]; then
  510. SELECTED_USERNAME=$(grep 'MY_USERNAME' temp.cfg | awk -F '=' '{print $2}')
  511. fi
  512. data=$(tempfile 2>/dev/null)
  513. trap "rm -f $data" 0 1 2 5 15
  514. dialog --backtitle $"Freedombone Configuration" \
  515. --title $"Username" \
  516. --inputbox $"Set your username for the system\n\nYour username should not contain any spaces" 12 60 "$SELECTED_USERNAME" 2> $data
  517. sel=$?
  518. case $sel in
  519. 0) possible_username=$(cat $data)
  520. SELECTED_USERNAME=
  521. if [[ $possible_username != *' '* && $possible_username != *'/'* && $possible_username != *'\'* && $possible_username != *'*'* ]]; then
  522. if [ $possible_username ]; then
  523. if [ ${#possible_username} -gt 1 ]; then
  524. if [[ $possible_username != $GENERIC_IMAGE_USERNAME ]]; then
  525. MY_USERNAME=$(cat $data)
  526. chmod 600 /etc/shadow
  527. chmod 600 /etc/gshadow
  528. useradd -m -s /bin/bash $MY_USERNAME
  529. chmod 0000 /etc/shadow
  530. chmod 0000 /etc/gshadow
  531. if [ -d /home/$MY_USERNAME ]; then
  532. echo "${MY_USERNAME}:$(printf `cat $IMAGE_PASSWORD_FILE`)" | chpasswd
  533. # Add the user as a sudoer - they will be the new admin user
  534. if ! grep -q "$MY_USERNAME ALL=(ALL) ALL" /etc/sudoers; then
  535. echo "$MY_USERNAME ALL=(ALL) ALL" >> /etc/sudoers
  536. # remove the generic image admin user from sudoers
  537. sed -i "s|${GENERIC_IMAGE_USERNAME}.*||g" /etc/sudoers
  538. fi
  539. break
  540. fi
  541. fi
  542. fi
  543. fi
  544. fi
  545. ;;
  546. 1) exit 1;;
  547. 255) exit 1;;
  548. esac
  549. done
  550. else
  551. no_of_users=$(find /home/* -maxdepth 0 -type d | wc -l)
  552. if [ $no_of_users -eq 1 ]; then
  553. # only a single user on the system
  554. MY_USERNAME=$(ls /home)
  555. else
  556. # select one from a number of users
  557. select_user
  558. if [ ! $SELECTED_USERNAME ]; then
  559. echo $'No username selected'
  560. exit 72589
  561. fi
  562. MY_USERNAME="$SELECTED_USERNAME"
  563. fi
  564. fi
  565. if [ ! $MY_USERNAME ]; then
  566. echo $'No user account was selected'
  567. exit 64398
  568. fi
  569. if [[ $MY_USERNAME == '-f' ]]; then
  570. echo $'No user account was selected'
  571. exit 8347
  572. fi
  573. if [[ $MY_USERNAME == 'debian' || $MY_USERNAME == 'fbone' ]]; then
  574. echo $"Don't use the default user account"
  575. exit 9341
  576. fi
  577. if [ ! -d /home/$MY_USERNAME ]; then
  578. echo $"The directory /home/$MY_USERNAME does not exist"
  579. exit 6437
  580. fi
  581. save_configuration_values
  582. }
  583. function choose_full_name {
  584. valid_name=
  585. while [ ! $valid_name ]
  586. do
  587. data=$(tempfile 2>/dev/null)
  588. trap "rm -f $data" 0 1 2 5 15
  589. dialog --backtitle $"Freedombone Configuration" \
  590. --inputbox $"Your full name (or nick)" 10 30 "$(grep 'MY_NAME' temp.cfg | awk -F '=' '{print $2}')" 2> $data
  591. sel=$?
  592. case $sel in
  593. 0) possible_name=$(cat $data)
  594. if [ "$possible_name" ]; then
  595. if [ ${#possible_name} -gt 1 ]; then
  596. valid_name="$possible_name"
  597. MY_NAME="$possible_name"
  598. break;
  599. fi
  600. fi
  601. ;;
  602. 1) exit 1;;
  603. 255) exit 1;;
  604. esac
  605. done
  606. save_configuration_values
  607. }
  608. function choose_system_variant {
  609. available_variants_list=()
  610. available_system_variants
  611. varslist=""
  612. n=1
  613. for a in "${available_variants_list[@]}"
  614. do
  615. varstate='off'
  616. if [[ "$a" == $'full' || "$a" == $'Full' ]]; then
  617. varstate='on'
  618. fi
  619. varslist="$varslist $n $a $varstate"
  620. n=$[n+1]
  621. done
  622. variant_choice=$(dialog --stdout --backtitle $"Freedombone Configuration" \
  623. --title $"Type of Installation" \
  624. --radiolist $'Choose:' \
  625. 27 40 20 $varslist)
  626. if [ $? -eq 0 ]; then
  627. variant_choice=$[variant_choice-1]
  628. SYSTEM_TYPE=${available_variants_list[$variant_choice]}
  629. save_configuration_values
  630. fi
  631. }
  632. function validate_freedns_code {
  633. freedns_code="$1"
  634. FREEDNS_MESSAGE=$"Please enter the FreeDNS code for this domain.\n\nThe code can be found by going to https://freedns.afraid.org, selecting 'Dynamic DNS' and then opening 'Wget example'. The code will consist of letters and numbers and be between the ? and = characters."
  635. if [[ "$freedns_code" == *"."* || "$freedns_code" == "http"* || "$freedns_code" == *"wget "* || "$freedns_code" == *" "* ]]; then
  636. dialog --title $"Invalid FreeDNS Code" --msgbox "$FREEDNS_MESSAGE" 10 70
  637. VALID_CODE=
  638. fi
  639. if [ ${#freedns_code} -lt 30 ]; then
  640. dialog --title $"Invalid FreeDNS Code" --msgbox $'FreeDNS code is too short. Did you enter the entire code?' 6 70
  641. VALID_CODE=
  642. fi
  643. VALID_CODE='yes'
  644. }
  645. # Get the commandline options
  646. while [[ $# > 1 ]]
  647. do
  648. key="$1"
  649. case $key in
  650. -h|--help)
  651. show_help
  652. ;;
  653. # Configuration filename
  654. -f|--filename)
  655. shift
  656. CONFIGURATION_FILE="$1"
  657. ;;
  658. # Minimum password length
  659. -m|--min)
  660. shift
  661. MINIMUM_PASSWORD_LENGTH="$1"
  662. ;;
  663. # Freedombone website
  664. -w|--www)
  665. shift
  666. FREEDOMBONE_WEBSITE="$1"
  667. ;;
  668. --minimal)
  669. shift
  670. MINIMAL_INSTALL="$1"
  671. ;;
  672. -o|--onion)
  673. shift
  674. ONION_ONLY="$1"
  675. ;;
  676. *)
  677. # unknown option
  678. ;;
  679. esac
  680. shift
  681. done
  682. function set_main_repo {
  683. data=$(tempfile 2>/dev/null)
  684. trap "rm -f $data" 0 1 2 5 15
  685. dialog --backtitle $"Freedombone Control Panel" \
  686. --title $"Main Repository (Mirrors)" \
  687. --form $"If you don't know what this means then just select Ok.\n\nIf you don't wish to use the default repositories they can be obtained from mirrored repos on another ${PROJECT_NAME} system.\n\nThe repositories are for applications which are not yet packaged for Debian." 18 65 4 \
  688. $"URL:" 1 1 "$FRIENDS_MIRRORS_SERVER" 1 18 40 18 \
  689. $"SSH Port:" 2 1 "$FRIENDS_MIRRORS_SSH_PORT" 2 18 10 10000 \
  690. $"Password:" 3 1 "$FRIENDS_MIRRORS_PASSWORD" 3 18 40 10000 \
  691. 2> $data
  692. sel=$?
  693. case $sel in
  694. 1) return;;
  695. 255) return;;
  696. esac
  697. new_mirrors_url=$(cat $data | sed -n 1p)
  698. new_mirrors_ssh_port=$(cat $data | sed -n 2p)
  699. new_mirrors_password=$(cat $data | sed -n 3p)
  700. if [ ${#new_mirrors_url} -lt 2 ]; then
  701. return
  702. fi
  703. if [ ${#new_mirrors_ssh_port} -lt 1 ]; then
  704. return
  705. fi
  706. if [ ${#new_mirrors_password} -lt 10 ]; then
  707. dialog --title $"Main Repository" \
  708. --msgbox $'Mirrors password was too short. Should be at least 10 characters.' 6 40
  709. return
  710. fi
  711. if [[ $new_mirrors_url == *"."* ]]; then
  712. FRIENDS_MIRRORS_SERVER=$new_mirrors_url
  713. FRIENDS_MIRRORS_SSH_PORT=$new_mirrors_ssh_port
  714. FRIENDS_MIRRORS_PASSWORD=$new_mirrors_password
  715. dialog --title $"Main Repository" \
  716. --msgbox $"Main repository set to $FRIENDS_MIRRORS_SERVER" 6 60
  717. fi
  718. save_configuration_values
  719. }
  720. function interactive_select_language {
  721. data=$(tempfile 2>/dev/null)
  722. trap "rm -f $data" 0 1 2 5 15
  723. dialog --backtitle $"Freedombone Configuration" \
  724. --radiolist $"Select your language:" 26 40 24 \
  725. 1 $"Afrikaans" off \
  726. 2 $"Albanian" off \
  727. 3 $"Arabic" off \
  728. 4 $"Basque" off \
  729. 5 $"Belarusian" off \
  730. 6 $"Bosnian" off \
  731. 7 $"Bulgarian" off \
  732. 8 $"Catalan" off \
  733. 9 $"Croatian" off \
  734. 10 $"Chinese (Simplified)" off \
  735. 11 $"Chinese (Traditional)" off \
  736. 12 $"Czech" off \
  737. 13 $"Danish" off \
  738. 14 $"Dutch" off \
  739. 15 $"English" on \
  740. 16 $"English (US)" off \
  741. 17 $"Estonian" off \
  742. 18 $"Farsi" off \
  743. 19 $"Filipino" off \
  744. 20 $"Finnish" off \
  745. 21 $"French" off \
  746. 22 $"French (Canada)" off \
  747. 23 $"Gaelic" off \
  748. 24 $"Gallego" off \
  749. 25 $"Georgian" off \
  750. 26 $"German" off \
  751. 27 $"German (Personal)" off \
  752. 28 $"Greek" off \
  753. 29 $"Gujarati" off \
  754. 30 $"Hebrew" off \
  755. 31 $"Hindi" off \
  756. 32 $"Hungarian" off \
  757. 33 $"Icelandic" off \
  758. 34 $"Indonesian" off \
  759. 35 $"Italian" off \
  760. 36 $"Japanese" off \
  761. 37 $"Kannada" off \
  762. 38 $"Khmer" off \
  763. 39 $"Korean" off \
  764. 40 $"Lao" off \
  765. 41 $"Lithuanian" off \
  766. 42 $"Latvian" off \
  767. 43 $"Malayalam" off \
  768. 44 $"Malaysian" off \
  769. 45 $"Maori (Ngai Tahu)" off \
  770. 46 $"Maori (Waikoto Uni)" off \
  771. 47 $"Mongolian" off \
  772. 48 $"Norwegian" off \
  773. 49 $"Norwegian (Primary)" off \
  774. 50 $"Nynorsk" off \
  775. 51 $"Polish" off \
  776. 52 $"Portuguese" off \
  777. 53 $"Portuguese (Brazil)" off \
  778. 54 $"Romanian" off \
  779. 55 $"Russian" off \
  780. 56 $"Samoan" off \
  781. 57 $"Serbian" off \
  782. 58 $"Slovak" off \
  783. 59 $"Slovenian" off \
  784. 60 $"Somali" off \
  785. 61 $"Spanish (International)" off \
  786. 62 $"Swedish" off \
  787. 63 $"Tagalog" off \
  788. 64 $"Tamil" off \
  789. 65 $"Thai" off \
  790. 66 $"Turkish" off \
  791. 67 $"Ukrainian" off \
  792. 68 $"Vietnamese" off 2> $data
  793. sel=$?
  794. case $sel in
  795. 1) exit 1;;
  796. 255) exit 1;;
  797. esac
  798. case $(cat $data) in
  799. 1) DEFAULT_LANGUAGE='af_ZA.UTF-8';;
  800. 2) DEFAULT_LANGUAGE='sq_AL.UTF-8';;
  801. 3) DEFAULT_LANGUAGE='ar_SA.UTF-8';;
  802. 4) DEFAULT_LANGUAGE='eu_ES.UTF-8';;
  803. 5) DEFAULT_LANGUAGE='be_BY.UTF-8';;
  804. 6) DEFAULT_LANGUAGE='bs_BA.UTF-8';;
  805. 7) DEFAULT_LANGUAGE='bg_BG.UTF-8';;
  806. 8) DEFAULT_LANGUAGE='ca_ES.UTF-8';;
  807. 9) DEFAULT_LANGUAGE='hr_HR.UTF-8';;
  808. 10) DEFAULT_LANGUAGE='zh_CN.UTF-8';;
  809. 11) DEFAULT_LANGUAGE='zh_TW.UTF-8';;
  810. 12) DEFAULT_LANGUAGE='cs_CZ.UTF-8';;
  811. 13) DEFAULT_LANGUAGE='da_DK.UTF-8';;
  812. 14) DEFAULT_LANGUAGE='nl_NL.UTF-8';;
  813. 15) DEFAULT_LANGUAGE='en_GB.UTF-8';;
  814. 16) DEFAULT_LANGUAGE='en_US.UTF-8';;
  815. 17) DEFAULT_LANGUAGE='et_EE.UTF-8';;
  816. 18) DEFAULT_LANGUAGE='fa_IR.UTF-8';;
  817. 19) DEFAULT_LANGUAGE='ph_PH.UTF-8';;
  818. 20) DEFAULT_LANGUAGE='fi_FI.UTF-8';;
  819. 21) DEFAULT_LANGUAGE='fr_FR.UTF-8';;
  820. 22) DEFAULT_LANGUAGE='fr_CA.UTF-8';;
  821. 23) DEFAULT_LANGUAGE='ga.UTF-8';;
  822. 24) DEFAULT_LANGUAGE='l_ES.UTF-8';;
  823. 25) DEFAULT_LANGUAGE='ka_GE.UTF-8';;
  824. 26) DEFAULT_LANGUAGE='de_DE.UTF-8';;
  825. 27) DEFAULT_LANGUAGE='de_DE.UTF-8';;
  826. 28) DEFAULT_LANGUAGE='el_GR.UTF-8';;
  827. 29) DEFAULT_LANGUAGE='gu.UTF-8';;
  828. 30) DEFAULT_LANGUAGE='he_IL.utf8';;
  829. 31) DEFAULT_LANGUAGE='hi_IN.UTF-8';;
  830. 32) DEFAULT_LANGUAGE='hu.UTF-8';;
  831. 33) DEFAULT_LANGUAGE='is_IS.UTF-8';;
  832. 34) DEFAULT_LANGUAGE='id_ID.UTF-8';;
  833. 35) DEFAULT_LANGUAGE='it_IT.UTF-8';;
  834. 36) DEFAULT_LANGUAGE='ja_JP.UTF-8';;
  835. 37) DEFAULT_LANGUAGE='kn_IN.UTF-8';;
  836. 38) DEFAULT_LANGUAGE='km_KH.UTF-8';;
  837. 39) DEFAULT_LANGUAGE='ko_KR.UTF-8';;
  838. 40) DEFAULT_LANGUAGE='lo_LA.UTF-8';;
  839. 41) DEFAULT_LANGUAGE='lt_LT.UTF-8';;
  840. 42) DEFAULT_LANGUAGE='lat.UTF-8';;
  841. 43) DEFAULT_LANGUAGE='ml_IN.UTF-8';;
  842. 44) DEFAULT_LANGUAGE='ms_MY.UTF-8';;
  843. 45) DEFAULT_LANGUAGE='mi_NZ.UTF-8';;
  844. 46) DEFAULT_LANGUAGE='mi_NZ.UTF-8';;
  845. 47) DEFAULT_LANGUAGE='mn.UTF-8';;
  846. 48) DEFAULT_LANGUAGE='no_NO.UTF-8';;
  847. 49) DEFAULT_LANGUAGE='no_NO.UTF-8';;
  848. 50) DEFAULT_LANGUAGE='nn_NO.UTF-8';;
  849. 51) DEFAULT_LANGUAGE='pl.UTF-8';;
  850. 52) DEFAULT_LANGUAGE='pt_PT.UTF-8';;
  851. 53) DEFAULT_LANGUAGE='pt_BR.UTF-8';;
  852. 54) DEFAULT_LANGUAGE='ro_RO.UTF-8';;
  853. 55) DEFAULT_LANGUAGE='ru_RU.UTF-8';;
  854. 56) DEFAULT_LANGUAGE='mi_NZ.UTF-8';;
  855. 57) DEFAULT_LANGUAGE='sr_CS.UTF-8';;
  856. 58) DEFAULT_LANGUAGE='sk_SK.UTF-8';;
  857. 59) DEFAULT_LANGUAGE='sl_SI.UTF-8';;
  858. 60) DEFAULT_LANGUAGE='so_SO.UTF-8';;
  859. 61) DEFAULT_LANGUAGE='es_ES.UTF-8';;
  860. 62) DEFAULT_LANGUAGE='sv_SE.UTF-8';;
  861. 63) DEFAULT_LANGUAGE='tl.UTF-8';;
  862. 64) DEFAULT_LANGUAGE='ta_IN.UTF-8';;
  863. 65) DEFAULT_LANGUAGE='th_TH.UTF-8';;
  864. 66) DEFAULT_LANGUAGE='tr_TR.UTF-8';;
  865. 67) DEFAULT_LANGUAGE='uk_UA.UTF-8';;
  866. 68) DEFAULT_LANGUAGE='vi_VN.UTF-8';;
  867. esac
  868. save_configuration_values
  869. locale-gen "${DEFAULT_LANGUAGE}"
  870. update-locale LANG=${DEFAULT_LANGUAGE}
  871. update-locale LANGUAGE=${DEFAULT_LANGUAGE}
  872. update-locale LC_MESSAGES=${DEFAULT_LANGUAGE}
  873. update-locale LC_ALL=${DEFAULT_LANGUAGE}
  874. update-locale LC_CTYPE=${DEFAULT_LANGUAGE}
  875. }
  876. function select_user {
  877. SELECTED_USERNAME=
  878. users_array=($(ls /home))
  879. delete=(mirrors git)
  880. for del in ${delete[@]}
  881. do
  882. users_array=(${users_array[@]/$del})
  883. done
  884. i=0
  885. W=()
  886. name=()
  887. for u in ${users_array[@]}
  888. do
  889. if [[ $(is_valid_user "$u") == "1" ]]; then
  890. i=$((i+1))
  891. W+=($i "$u")
  892. name+=("$u")
  893. fi
  894. done
  895. if [ $i -eq 1 ]; then
  896. SELECTED_USERNAME="${name[0]}"
  897. else
  898. user_index=$(dialog --backtitle $"Freedombone Configuration" --title $"Select User" --menu $"Select one of the following:" 24 40 17 "${W[@]}" 3>&2 2>&1 1>&3)
  899. if [ $? -eq 0 ]; then
  900. SELECTED_USERNAME="${name[$((user_index-1))]}"
  901. fi
  902. fi
  903. }
  904. function interactive_config {
  905. # create a temporary copy of the configuration file
  906. # which can be used to pre-populate selections
  907. if [ -f $CONFIGURATION_FILE ]; then
  908. cp $CONFIGURATION_FILE temp.cfg
  909. fi
  910. interactive_select_language
  911. if [[ $ONION_ONLY == "no" ]]; then
  912. 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."
  913. else
  914. 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."
  915. fi
  916. dialog --title $"Freedombone" --msgbox "$INITIAL_MESSAGE" 15 50
  917. #choose_system_variant
  918. set_main_repo
  919. choose_username
  920. choose_full_name
  921. choose_social_key_management
  922. choose_rng
  923. choose_debian_repo
  924. ${PROJECT_NAME}-wifi --networksinteractive $WIFI_NETWORKS_FILE
  925. choose_dynamic_dns
  926. choose_default_domain_name
  927. choose_email_address
  928. interactive_key_recovery
  929. # delete the temporary configuration file
  930. if [ -f temp.cfg ]; then
  931. shred -zu temp.cfg
  932. fi
  933. # This file indicates that the configuration happened successfully
  934. touch $HOME/.${PROJECT_NAME}-interactive
  935. }
  936. function show_result {
  937. #clear
  938. echo ''
  939. echo -n $"Configuration filename:"
  940. echo " $CONFIGURATION_FILE"
  941. echo ''
  942. echo $'Contents:'
  943. echo ''
  944. cat $CONFIGURATION_FILE
  945. echo ''
  946. }
  947. if [ ! $CONFIGURATION_FILE ]; then
  948. CONFIGURATION_FILE=$HOME/${PROJECT_NAME}.cfg
  949. fi
  950. read_configuration_values
  951. interactive_config
  952. #show_result
  953. exit 0