--- misc/xoa-installer/xoa-installer.sh 2016/12/20 14:28:51 3176 +++ misc/xoa-installer/xoa-installer.sh 2017/03/21 13:45:27 3195 @@ -5,7 +5,8 @@ # # If running on a raspberry 1(A/B) raspian/wheezy - downgrade node.js to 5.4.0 # Please note that raspian/wheezy for arm defaults to gcc 4.6 -# gcc 4.7 is needed for compiling node-js modules +# gcc 4.7 is needed for compiling node-js modules +# 2017-01-03 gcc 4.8 is required BRANCH=stable @@ -19,24 +20,24 @@ -function restartxo { - killall -9 node - rm -f /root/forever.log - forever start -l /root/forever.log /root/xo-server/bin/xo-server -} - -if [ "$1" == "restart" ] ; then - restartxo +phymem=$(free -m|awk '/^Mem:/{print $2}') +swapmem=$(free -m|awk '/^Swap:/{print $2}') +total=$(expr $phymem + $swapmem) +if [ $total -le 1536 ] ; then + echo not enough memory: $total exit fi if [ "$1" == "clean" ] ; then + echo cleaning global npm packages + npm uninstall -g gulp + npm uninstall -g node-gyp + npm uninstall -g bcrypt + npm uninstall -g yarn + echo cleaning xo-web rm -rf xo-web -# echo cleaning xo-web-v4 -# rm -rf xo-web-v4 - echo cleaning xo-server rm -rf xo-server @@ -49,11 +50,6 @@ echo cleaning .cache rm -rf .cache - echo cleaning .forever - rm -rf .forever - rm -rf forever.log - - echo done exit fi @@ -93,7 +89,7 @@ if [ ! -x "/usr/local/bin/node" ] ; then echo "installing node.js" - n stable || exit + n lts || exit fi if [ ! -x "/usr/local/bin/gulp" ] ; then @@ -101,11 +97,12 @@ npm install -g gulp || exit fi -if [ ! -x "/usr/local/bin/forever" ] ; then - echo "installing forever" - npm install -g forever || exit +if [ ! -x "/usr/local/bin/yarn" ] ; then + echo "installing yarn" + npm install -g yarn || exit fi + if [ ! -x "/usr/local/bin/node-gyp" ] ; then echo "installing node-gyp" npm install -g node-gyp || exit @@ -113,7 +110,7 @@ if [ ! -d "/usr/local/lib/node_modules/bcrypt" ] ; then echo "installing bcrypt" - npm install -g bcrypt || exit + npm install -g --unsafe-perm bcrypt || exit fi if [ ! -d "xo-web" ] ; then @@ -124,12 +121,6 @@ cd .. fi -#if [ ! -d "xo-web-v4" ] ; then -# git clone -b $BRANCH https://github.com/vatesfr/xo-web.git xo-web-v4 -# cd xo-web-v4 -# git checkout tags/v4.16.0 -# cd .. -#fi if [ ! -d "xo-server" ] ; then git clone -b $BRANCH https://github.com/vatesfr/xo-server.git @@ -143,16 +134,7 @@ # xo-server echo "building xo-server" cd xo-server - npm install || exit - npm run build || exit - - #for some reasone leveldown fails occasionally on arm/raspberry pi - if [ ! -d "/root/xo-server/node_modules/leveldown/build" ] ; then - pushd node_modules/leveldown - node-gyp configure || exit - node-gyp build || exit - popd - fi + yarn cd .. @@ -160,41 +142,24 @@ #xo-web echo "building xo-web" cd xo-web - #npm install --unsafe-perm || exit - npm install || exit - npm run build || exit + yarn cd .. -##xo-web-v4 -#echo "building xo-web-v4" -#cd xo-web-v4 -# npm install || exit -# npm run build || exit -#cd .. - - - -#if [ ! -f xo-web/dist/styles/main.css ] ; then -# mkdir xo-web/dist/styles -# mkdir xo-web/dist/images -# -# cp xo-web-v4/dist/styles/main.css xo-web/dist/styles/main.css -# cp xo-web-v4/dist/images/logo_small.png xo-web/dist/images/logo_small.png -#fi +dir=`dirname $0` if [ ! -f "/etc/xo-server/config.yaml" ] ; then if [ ! -d "/etc/xo-server" ] ; then mkdir /etc/xo-server fi - - echo "please setup /etc/xo-server/config.yaml" - exit + copy $dir/config.yaml /etc/xo-server/config.yaml fi echo Installing plugins npm install --global xo-server-transport-email npm install --global xo-server-transport-xmpp +npm install --global xo-server-backup-reports + #npm install --save xo-server-usage-report