mirror of https://bitbucket.org/ausocean/av.git
Merge branch 'treat-make' into force-mac-install
This commit is contained in:
commit
598b866909
|
@ -0,0 +1,84 @@
|
||||||
|
# Install files and directories required by treatment (speaker driver software).
|
||||||
|
# This can also create a dhcpcd.enter-hook for setting the MAC address.
|
||||||
|
# MA and DK can be passed to Make if it is for a hard (first-time) installation:
|
||||||
|
# sudo MA=mac DK=dk make install_hard
|
||||||
|
# NB: The default (soft) install does not override conf files or set the MAC address.
|
||||||
|
# USR can also be passsed to customise user under which the code is housed.
|
||||||
|
USER := $(shell whoami)
|
||||||
|
PATH := /usr/local/go/bin:$(PATH)
|
||||||
|
BIN_NAME := treatment
|
||||||
|
BIN_DIR := /src/bitbucket.org/ausocean/av/cmd/$(BIN_NAME)
|
||||||
|
|
||||||
|
.SILENT:make_dirs
|
||||||
|
.SILENT:hard_copy_files
|
||||||
|
.SILENT:set_mac
|
||||||
|
.SILENT:clean
|
||||||
|
|
||||||
|
install: as_root make_dirs hard_copy_files rebuild syncreboot
|
||||||
|
@echo "Install complete"
|
||||||
|
|
||||||
|
install_no_rebuild: as_root make_dirs hard_copy_files syncreboot
|
||||||
|
@echo "Install complete"
|
||||||
|
|
||||||
|
install_set_mac: as_root make_dirs hard_copy_files set_mac rebuild syncreboot
|
||||||
|
@echo "Install complete, MAC address set to $(MA)"
|
||||||
|
|
||||||
|
as_root:
|
||||||
|
ifneq ($(USER),root)
|
||||||
|
$(error Must run as superuser!)
|
||||||
|
endif
|
||||||
|
|
||||||
|
rebuild:
|
||||||
|
@chmod +x treatment_run.sh
|
||||||
|
@go build
|
||||||
|
|
||||||
|
make_dirs:
|
||||||
|
@if [ ! -d /var/netsender ] ; then \
|
||||||
|
mkdir /var/netsender; \
|
||||||
|
chmod guo+rwx /var/netsender; \
|
||||||
|
fi
|
||||||
|
@if [ ! -d /var/log/netsender ] ; then \
|
||||||
|
mkdir /var/log/netsender; \
|
||||||
|
chmod guo+rwx /var/log/netsender; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
hard_copy_files:
|
||||||
|
ifeq ($(MA),)
|
||||||
|
$(error "Must provide MAC using MA=")
|
||||||
|
endif
|
||||||
|
ifeq ($(DK),)
|
||||||
|
$(error "Must provide device key using DK=")
|
||||||
|
endif
|
||||||
|
@if [ -f /etc/systemd/system/$(BIN_NAME).service ] ; then \
|
||||||
|
echo "/etc/systemd/system/$(BIN_NAME).service overwritten" ; \
|
||||||
|
fi
|
||||||
|
@cp -f $(BIN_NAME).service /etc/systemd/system
|
||||||
|
@systemctl enable $(BIN_NAME).service
|
||||||
|
@if [ -f /etc/netsender.conf ] ; then \
|
||||||
|
echo "Backed up netsender.conf to /etc/netsender.conf.bak"; \
|
||||||
|
cp /etc/netsender.conf /etc/netsender.conf.bak ; \
|
||||||
|
fi
|
||||||
|
@printf "ma $(MA)\ndk $(DK)\n" > /etc/netsender.conf
|
||||||
|
@chown $(USER) /etc/netsender.conf
|
||||||
|
|
||||||
|
set_mac:
|
||||||
|
ifeq ($(MA),)
|
||||||
|
$(error "Must provide MAC using MA=")
|
||||||
|
endif
|
||||||
|
@printf "ip link set eth0 address $(MA)\n" > /etc/dhcpcd.enter-hook
|
||||||
|
@chmod guo+x /etc/dhcpcd.enter-hook
|
||||||
|
|
||||||
|
syncreboot:
|
||||||
|
@if [ -e ../../../utils ]; then \
|
||||||
|
cd ../../../utils; git checkout -f master; git pull; \
|
||||||
|
else \
|
||||||
|
cd ../../../; git clone https://bitbucket.org/ausocean/utils; \
|
||||||
|
fi
|
||||||
|
@cd ../../../utils/cmd/syncreboot; make; make install
|
||||||
|
|
||||||
|
clean: as_root
|
||||||
|
rm -rf /var/netsender
|
||||||
|
rm -rf /var/log/netsender
|
||||||
|
rm -rf /etc/systemd/system/$(BIN_NAME).service
|
||||||
|
rm -rf /etc/netsender.conf
|
||||||
|
@echo "Clean complete"
|
Loading…
Reference in New Issue