fourier_install.sh 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. # version 1.0.2
  2. # install essential software
  3. # sudo apt-get update
  4. installer_version=1.0.3
  5. programspath=~/programs
  6. installerpath=$(pwd)
  7. configfile='/etc/fourier-config.json'
  8. gitbase="gogs@git.miralo.xyz:AudioValid"
  9. tunnel_user=rtunnel
  10. datapath='/var/fourier'
  11. serverhost='monitor.audiovalid.com'
  12. tunnelfile="$programspath/ssh-tunnel.sh"
  13. mysql_user=fourier
  14. mysql_passwd='Sup3rDuper!'
  15. mysql_db=fourier
  16. mount_point=/media/datadrive
  17. echo "Fourier installer $installer_version"
  18. echo "------------------------------------"
  19. if [[ "$OSTYPE" == darwin* ]]; then
  20. programspath=~/fourier
  21. fi
  22. clonerepo() {
  23. GIT_SSH_COMMAND="ssh -i $installerpath/repokey -o StrictHostKeychecking=no" \
  24. git clone $gitbase/$1 $2
  25. }
  26. [ ! -d "$programspath" ] && mkdir $programspath
  27. read -p "Whats this box port (last 3 numbers with zero for padding)? " PORT
  28. read -p "How many receivers has this box? " RECEIVERS_COUNT
  29. read -p "Box ID (or rolame url id): " BOX_ID
  30. curl -f -H "Accept: text/plain" "https://rola.me/$BOX_ID" \
  31. 1>/tmp/fourier-api \
  32. 2>/dev/null
  33. if [ "$?" -eq 0 ]; then
  34. IFS=':' read -ra APIDATA <<< "$(cat /tmp/fourier-api)"
  35. BOX_ID="${APIDATA[0]}"
  36. API_SECRET="${APIDATA[1]}"
  37. rm /tmp/fourier-api
  38. else
  39. read -p "API secret: " API_SECRET
  40. fi
  41. sudo apt-get install -y python python-pip
  42. findmnt "$mount_point"
  43. if [ "$?" -neq 0 ]; then
  44. echo -e 'Data drive is not mounted'
  45. fi
  46. if [[ "$OSTYPE" == darwin* ]]; then
  47. keyfile="$programspath/fourier.key"
  48. [ ! -f "$keyfile" ] && ssh-keygen -t rsa -b 2048 -f $keyfile
  49. else
  50. keyspath=~/.ssh
  51. keyfile="$keyspath/id_rsa"
  52. [ ! -d "$keyspath" ] && mkdir $keyspath
  53. ssh-keygen -t rsa -b 2048 -C "$HOSTNAME" -P "" -f $keyfile
  54. fi
  55. keycontent=$(cat $keyfile.pub)
  56. curl -X POST -F "key=$keycontent" \
  57. -H "Authorization: $BOX_ID $API_SECRET" \
  58. https://api.audiovalid.com/public-key
  59. if [[ "$OSTYPE" == darwin* ]]; then
  60. depend=( python gcc vim tmux autossh lame nodejs \
  61. ezstream libusb rtl-sdr portaudio )
  62. for dep in "${depend[@]}"
  63. do
  64. brew list $dep > /dev/null
  65. [ "$?" -eq 1 ] && brew install $dep
  66. done
  67. envpath="$programspath/env"
  68. [ ! -d "$envpath" ] && virtualenv $programspath/env
  69. source $envpath/bin/activate
  70. pip install -r $installerpath/requirements.txt
  71. else
  72. curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash -
  73. sudo apt-get install -y alsa-utils alsa-tools
  74. sudo apt-get install -y libudev-dev
  75. sudo apt-get install -y tmux
  76. sudo apt-get install -y vim
  77. sudo apt-get install -y autossh
  78. sudo apt-get install -y git-core
  79. sudo apt-get install -y build-essential
  80. sudo apt-get install -y nodejs
  81. sudo apt-get install -y python-dev
  82. sudo apt-get install -y lame
  83. sudo apt-get install -y ezstream
  84. sudo apt-get install -y cmake
  85. sudo apt-get install -y rtl-sdr
  86. sudo apt-get install -y sqlite3
  87. sudo apt-get install -y portaudio19-dev
  88. sudo pip install pyaudio pyusb pydub numpy requests \
  89. scipy python-firebase
  90. sudo apt-get install -y ffmpeg
  91. sudo apt-get install -y gfortran libopenblas-dev liblapack-dev
  92. sudo apt-get install -y python-matplotlib
  93. sudo apt-get install -y curl
  94. sudo pip install
  95. sudo npm install -g http-server
  96. cd tools
  97. sudo python ./setup.py install
  98. cd ..
  99. fi
  100. sudo chmod 0600 $installerpath/repokey
  101. cd $programspath
  102. clonerepo fourier-module.git module
  103. clonerepo fourier-common.git common
  104. clonerepo fourier-server.git server
  105. clonerepo fourier-fourier.git fourier
  106. clonerepo fourier-alt.git fourier-alt
  107. clonerepo fourier-monitor.git monitor
  108. clonerepo fourier-uploader.git uploader
  109. clonerepo fourier-ondemand.git ondemand
  110. cd $programspath/server
  111. npm install
  112. cd $programspath/monitor
  113. npm install
  114. cd $programspath/uploader
  115. npm install
  116. cd $programspath/module
  117. sudo python setup.py install
  118. cd $programspath/ondemand
  119. sudo python setup.py install
  120. sudo npm install -g pm2
  121. # build sdr lib
  122. if [[ "$OSTYPE" != darwin* ]]; then
  123. sudo apt-get install -y libusb-1.0-0-dev
  124. cd $programspath
  125. clonerepo rtl-sdr.git rtl-sdr
  126. cd $programspath/rtl-sdr
  127. mkdir build
  128. cd build
  129. cmake ../ -DINSTALL_UDEV_RULES=ON -DDETACH_KERNEL_DRIVER=ON
  130. make
  131. sudo cp ./src/rtl_fm /usr/bin/rtl_fm
  132. echo "SUBSYSTEMS=="usb", ATTRS{idVendor}=="0bda", ATTRS{idProduct}=="2838", MODE:="0666"" | sudo tee -a /etc/udev/rules.d/rtl-sdr.rules
  133. fi
  134. [ ! -f "$configfile" ] && \
  135. sudo python $installerpath/configure.py \
  136. $installerpath/fourier-config.json \
  137. $configfile \
  138. -programs "$programspath" \
  139. -receivers $RECEIVERS_COUNT \
  140. -api-secret $API_SECRET \
  141. -box-id "$BOX_ID"
  142. if [ "$?" -eq 0 ]; then
  143. cd "$programspath"
  144. pm2 start server
  145. pm2 start monitor
  146. pm2 start uploader
  147. pm2 start ondemand/ondemand/service.py \
  148. --interpreter=python \
  149. --name=ondemand
  150. pm2 start http-server
  151. pm2 save
  152. pm2 startup
  153. sudo env PATH=$PATH:/usr/bin \
  154. /usr/lib/node_modules/pm2/bin/pm2 \
  155. startup systemd -u fourier \
  156. --hp ~/
  157. fi
  158. if [ ! -f "/etc/systemd/system/ssh-tunnel.service" ]; then
  159. echo "/usr/bin/autossh -N -f -M 7$PORT -oPubkeyAuthentication=yes -oPasswordAuthentication=no -oLogLevel=error -oUserKnownHostsFile=/dev/null -oStrictHostKeyChecking=no -i $keyfile -R 6$PORT:localhost:22 $tunnel_user@$serverhost -p 22" > $tunnelfile
  160. sudo mv $installerpath/ssh-tunnel.service \
  161. /etc/systemd/system/ssh-tunnel.service
  162. sudo systemctl enable ssh-tunnel
  163. sudo systemctl start ssh-tunnel
  164. fi
  165. if [[ "$OSTYPE" != darwin* ]]; then
  166. sudo mysql -u root -e "create database $mysql_db;"
  167. sudo mysql -u root -e "create user '$mysql_user'@'localhost' identified by '$mysql_passwd';"
  168. sudo mysql -u root -e "grant all privileges on $mysql_db.* to '$mysql_user'@'localhost';flush privileges;"
  169. cd ~
  170. sudo mysql -u root -h localhost $mysql_db < $installerpath/fourier.sql
  171. sudo cp $installerpath/fourier-key.json /etc/Fourier-key.json
  172. fi