|
- #!/bin/bash
-
- if [ "$IN_CHROOT" != "1" ] ; then
- echo This is supposed to run inside the chroot, oops
- exit 1
- fi
-
- set -e
- set -x
-
- # Set up live username and hostname
- cat >/etc/casper.conf <<"EOF"
- export USERNAME="nilm"
- export USERFULLNAME="NILM User"
- export HOST="nilmbuntu"
- export BUILD_SYSTEM="Ubuntu"
- export FLAVOUR="NILMbuntu"
-
- # Do the inital user setup even though UID 1000 already exists.
- # This also needs to be set in /etc/environment, for ubiquity,
- # but we do that in preseed/early_command so that it only shows
- # up in the LiveCD image.
- export OVERRIDE_SYSTEM_USER=true
- EOF
-
- # Set up NILM-specific stuff to get added to /etc/hosts after installation
- cat >/etc/hosts.nilm <<"EOF"
- 127.0.2.1 nilm.primary
- 127.0.2.2 nilm.secondary
- EOF
- # And copy it for now (although it will get overwritten at boot)
- cat /etc/hosts.nilm >> /etc/hosts
-
- # Upgrade packages and remove old kernels
- apt update
- apt -y dist-upgrade
- apt -y --purge autoremove
- for VER in $(ls --sort=version /lib/modules/ | head -n -1) ; do
- apt -y --purge remove "linux-.*$VER"
- done
-
- # Disable upgrade popups
- sed -i -s -e 's/Prompt=.*/Prompt=never/g' \
- /etc/update-manager/release-upgrades || true
-
- # Set up & install postfix for local mail delivery
- debconf-set-selections <<"EOF"
- postfix postfix/mailname string localdomain
- postfix postfix/main_mailer_type select Local only
- EOF
- apt -y install postfix
-
- # Required packages
- apt -y install \
- python3 \
- python2.7 \
- python2.7-dev \
- python-setuptools \
- python-pip \
- cython \
- git \
- build-essential \
- python-cherrypy3 \
- python-decorator \
- python-simplejson \
- python-requests \
- python-dateutil \
- python-tz \
- python-progressbar \
- python-psutil \
- python-numpy \
- python-nose \
- python-coverage \
- apache2 \
- libapache2-mod-wsgi \
- python-scipy \
- python-daemon
-
- # Install other useful stuff
- apt -y install \
- adb \
- avrdude \
- chromium-browser \
- curl \
- debconf-utils \
- devscripts \
- dfu-programmer \
- dlocate \
- emacs \
- emacs-goodies-el \
- esptool \
- flashrom \
- gcc-arm-none-eabi \
- gcc-avr \
- gdb-arm-none-eabi \
- gddrescue \
- gnuplot \
- help2man \
- ipython \
- libnewlib-arm-none-eabi \
- libreoffice \
- libstdc++-arm-none-eabi-newlib \
- texlive \
- mailutils \
- moreutils \
- mutt \
- network-manager-openvpn-gnome \
- octave \
- octave-missing-functions \
- octave-signal \
- openocd \
- openssh-server \
- openssl \
- openvpn \
- python-matplotlib \
- screen \
- sigrok \
- silversearcher-ag \
- subversion \
- tcpdump \
- zip
-
- # Install the packages required for en_US language support
- # This avoids a prompt and package download at first install
- apt -y install $(/usr/bin/check-language-support -l en_US)
-
- # Set up timezone to America/New_York for the live CD
- ln -sf /usr/share/zoneinfo/America/New_York /etc/localtime
- dpkg-reconfigure -f noninteractive tzdata
-
- # Put some default desktop shortcuts in place
- DESKTOP=/etc/skel/Desktop
- mkdir -p $DESKTOP
- cp /usr/share/applications/exo-terminal-emulator.desktop $DESKTOP || true
- cp /usr/share/applications/exo-web-browser.desktop $DESKTOP || true
- chmod +x $DESKTOP/*
-
- # Custom background image (which was already copied in by customize.sh)
- XML=/etc/xdg/xdg-xubuntu/xfce4/xfconf/xfce-perchannel-xml/xfce4-desktop.xml
- BG=/usr/share/xfce4/backdrops/nilmbuntu.png
- apt -y install xmlstarlet
- xmlstarlet ed -L -u "//property[@name='image-path']/@value" -v "$BG" $XML
- xmlstarlet ed -L -u "//property[@name='image-style']/@value" -v "3" $XML
-
- # Configure Firefox with our default homepage
- HOMEPAGE="http://www.wattsworth.net/"
- cat >/etc/firefox/syspref.js <<EOF
- pref("browser.startup.homepage", "${HOMEPAGE}");
- pref("extensions.ubufox@ubuntu.com.custom_homepage", "${HOMEPAGE}");
- pref("browser.startup.homepage_override.mstone", "ignore");
- EOF
-
- # NilmDB setup below...
-
- # # Create nilmdb user to run the database
- # adduser --system --group --shell /bin/bash --disabled-password nilmdb
- # cp -rv /etc/skel/.??* /home/nilmdb
- # chown -R nilmdb:nilmdb /home/nilmdb
-
- # # Create WSGI scripts
- # cat > /home/nilmdb/nilmdb.wsgi <<"EOF"
- # import nilmdb.server
- # application = nilmdb.server.wsgi_application("/home/nilmdb/db","/nilmdb")
- # EOF
- # cat > /home/nilmdb/nilmrun.wsgi <<"EOF"
- # import nilmrun.server
- # application = nilmrun.server.wsgi_application("/nilmrun")
- # EOF
-
- # #### Edit apache config
-
- # # Create apache config by hacking up the default one. Might be a better way
- # # to do this, and it'll probably break on new versions, but...
-
- # APACHE_VER=$(dpkg -s apache2 | grep ^Version | cut -d ' ' -f 2)
- # if dpkg --compare-versions $APACHE_VER ge 2.4 ; then
- # DEF=/etc/apache2/sites-available/000-default.conf
- # NEED_PERMISSIONS=1
- # else
- # DEF=/etc/apache2/sites-available/default
- # NEED_PERMISSIONS=0
- # fi
-
- # # Cut out any existing NilmDB stuff
- # perl -ne 'print unless /## NilmDB start/../## NilmDB end/' $DEF > $DEF.orig
-
- # # Copy everything up to the first </VirtualHost> line
- # perl -ne 'print unless m-^[^#]*</VirtualHost>-..1' $DEF.orig > $DEF
-
- # # Add the NilmDB config
- # cat >>$DEF <<"EOF"
- # ## NilmDB start
- # WSGIScriptAlias /nilmdb /home/nilmdb/nilmdb.wsgi
- # WSGIDaemonProcess nilmdb-procgroup threads=32 user=nilmdb group=nilmdb
- # <Location /nilmdb>
- # WSGIProcessGroup nilmdb-procgroup
- # WSGIApplicationGroup nilmdb-appgroup
- # </Location>
-
- # WSGIScriptAlias /nilmrun /home/nilmdb/nilmrun.wsgi
- # WSGIDaemonProcess nilmrun-procgroup threads=32 user=nilmdb group=nilmdb
- # <Location /nilmrun>
- # WSGIProcessGroup nilmrun-procgroup
- # WSGIApplicationGroup nilmrun-appgroup
- # </Location>
- # EOF
- # if [ $NEED_PERMISSIONS == 1 ] ; then
- # cat >>$DEF <<"EOF"
-
- # <Directory /home/nilmdb>
- # Options All
- # AllowOverride All
- # Require all granted
- # </Directory>
- # EOF
- # fi
- # cat >>$DEF <<"EOF"
- # ## NilmDB end
- # EOF
-
- # # Copy everything including and after the first </VirtualHost> line
- # perl -ne 'print if m-^[^#]*</VirtualHost>-..1' $DEF.orig >> $DEF
-
- # #### Done editing apache config
-
- # # Create nilmdb capture, processing, and cleanup files
- # cat > /home/nilmdb/capture.sh <<"EOF"
- # #!/bin/bash -e
-
- # # Don't run capture if we're running off a live CD
- # if grep -q boot=casper /proc/cmdline ; then
- # echo "Skipping capture, because this is a live CD."
- # exit 0
- # fi
-
- # echo "Starting capture in background..."
- # nilm-pipewatch --daemon --lock "/tmp/nilmdb-capture.lock" --timeout 30 \
- # "ethstream -a 192.168.1.209 -n 6 -r 8000" \
- # "nilm-insert -m 10 -r 8000 --live /data/raw"
- # EOF
- # cat > /home/nilmdb/process.sh <<"EOF"
- # #!/bin/bash -e
-
- # # Ensure only one copy of this code runs at a time:
- # LOCKFILE="/tmp/nilmdb-process.lock"
- # exec 99>"$LOCKFILE"
- # flock -n -x 99 || exit 0
- # trap 'rm -f "$LOCKFILE"' 0
-
- # nilm-sinefit -c 4 /data/raw /data/sinefit
- # nilm-prep -c 1 -r 0 /data/raw /data/sinefit /data/prep-a
- # nilm-prep -c 2 -r 120 /data/raw /data/sinefit /data/prep-b
- # nilm-prep -c 3 -r 240 /data/raw /data/sinefit /data/prep-c
- # nilm-decimate-auto /data/raw "/data/prep*"
- # nilm-cleanup --yes /home/nilmdb/cleanup.cfg
- # EOF
- # cat > /home/nilmdb/cleanup.cfg <<"EOF"
- # [/data/prep-*]
- # keep = 1y
-
- # [/data/raw]
- # keep = 2w
-
- # [/data/sinefit]
- # keep = 1y
- # decimated = false
- # EOF
-
- # # Set up crontab
- # cat > /home/nilmdb/crontab <<"EOF"
- # SHELL=/bin/bash
- # PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
-
- # # Run capture and processing scripts every 5 minutes
- # */5 * * * * chronic /home/nilmdb/capture.sh
- # */5 * * * * chronic /home/nilmdb/process.sh
-
- # # Try to run nilmdb-fsck on boot. It should hopefully run before
- # # apache opens the database, and apache will return errors to clients
- # # until nilmdb-fsck is done.
- # @reboot chronic nilmdb-fsck --fix --no-data /home/nilmdb/db
- # EOF
- # crontab -u nilmdb /home/nilmdb/crontab
-
- # # Fix permissions
- # chown -R nilmdb:nilmdb /home/nilmdb
- # chmod +x /home/nilmdb/{capture,process}.sh
-
- # # Fetch and build everything. Put it in the nilmdb dir
- # echo "machine git.jim.sh login nilm password nilm" > /home/nilmdb/.netrc
- # GIT=https://git.jim.sh/jim/lees
- # rm -rf /home/nilmdb/git
- # mkdir /home/nilmdb/git
- # chown nilmdb:nilmdb /home/nilmdb/.netrc /home/nilmdb/git
- # REPOS="nilmdb nilmtools nilmrun ethstream"
-
- # # check it out as nilmdb, so the .netrc gets used
- # for repo in $REPOS; do
- # sudo -i -u nilmdb git clone $GIT/$repo.git git/$repo
- # done
-
- # Create NILM user. This should happen after anything that we put in
- # /etc/skel, since files get copied from there. Note that this user
- # is the same as what we have in the preseed file and casper.conf
- adduser --gecos "NILM User" --disabled-password nilm
-
- # # fix up all permissions in git dir, so nilmdb user can play with it later
- # chown -R nilmdb:nilmdb /home/nilmdb/git
-
- # Make sure initramfs was regenerated with casper changes
- update-initramfs
|