diff --git a/Makefile b/Makefile index bc892a0a..ed62ff85 100644 --- a/Makefile +++ b/Makefile @@ -1,29 +1,6 @@ PACKER_VERSION=1.9.4 -WN_VERSION := $(shell cut -d"'" -f2 < pwnagotchi/_version.py) -PWN_RELEASE := pwnagotchi-raspios-lite-$(PWN_VERSION) - -MACHINE_TYPE := $(shell uname -m) -ifneq (,$(filter x86_64,$(MACHINE_TYPE))) -GOARCH := amd64 -else ifneq (,$(filter i686,$(MACHINE_TYPE))) -GOARCH := 386 -else ifneq (,$(filter arm64% aarch64%,$(MACHINE_TYPE))) -GOARCH := arm64 -else ifneq (,$(filter arm%,$(MACHINE_TYPE))) -GOARCH := arm -else -GOARCH := amd64 -$(warning Unable to detect CPU arch from machine type $(MACHINE_TYPE), assuming $(GOARCH)) -endif - -# The Ansible part of the build can inadvertently change the active hostname of -# the build machine while updating the permanent hostname of the build image. -# If the unshare command is available, use it to create a separate namespace -# so hostname changes won't affect the build machine. -UNSHARE := $(shell command -v unshare) -ifneq (,$(UNSHARE)) -UNSHARE := $(UNSHARE) --uts -endif +PWN_HOSTNAME=pwnagotchi +PWN_VERSION=2.0.1 all: clean install image @@ -31,45 +8,23 @@ langs: @for lang in pwnagotchi/locale/*/; do\ echo "compiling language: $$lang ..."; \ ./scripts/language.sh compile $$(basename $$lang); \ - done + done -PACKER := /tmp/pwnagotchi/packer -PACKER_URL := https://releases.hashicorp.com/packer/$(PACKER_VERSION)/packer_$(PACKER_VERSION)_linux_amd64.zip -$(PACKER): - mkdir -p $(@D) - curl -L "$(PACKER_URL)" -o $(PACKER).zip - unzip $(PACKER).zip -d $(@D) - rm $(PACKER).zip - chmod +x $@ +install: + curl https://releases.hashicorp.com/packer/$(PACKER_VERSION)/packer_$(PACKER_VERSION)_linux_amd64.zip -o /tmp/packer.zip + unzip /tmp/packer.zip -d /tmp + sudo mv /tmp/packer /usr/bin/packer + git clone https://github.com/solo-io/packer-plugin-arm-image /tmp/packer-plugin-arm-image + cd /tmp/packer-plugin-arm-image && go get -d ./... && go build -buildvcs=false + sudo cp /tmp/packer-plugin-arm-image/packer-plugin-arm-image /usr/bin -SDIST := dist/pwnagotchi-$(PWN_VERSION).tar.gz -$(SDIST): setup.py pwnagotchi - python3 setup.py sdist - -# Building the image requires packer, but don't rebuild the image just because packer updated. -$(PWN_RELEASE).img: | $(PACKER) - -# If the packer or ansible files are updated, rebuild the image. -$(PWN_RELEASE).img: $(SDIST) builder/pwnagotchi.json builder/pwnagotchi.yml $(shell find builder/data -type f) - sudo $(PACKER) plugins install github.com/solo-io/arm-image - cd builder && sudo $(UNSHARE) $(PACKER) build -var "pwn_hostname=$(PWN_HOSTNAME)" -var "pwn_version=$(PWN_VERSION)" pwnagotchi.json - sudo chown -R $$USER:$$USER builder/output-pwnagotchi - mv builder/output-pwnagotchi/image $@ - -# If any of these files are updated, rebuild the checksums. -$(PWN_RELEASE).sha256: $(PWN_RELEASE).img - sha256sum $^ > $@ - -# If any of the input files are updated, rebuild the archive. -$(PWN_RELEASE).zip: $(PWN_RELEASE).img $(PWN_RELEASE).sha256 - zip $(PWN_RELEASE).zip $^ - -.PHONY: image -image: $(PWN_RELEASE).zip +image: + cd builder && sudo /usr/bin/packer build -var "pwn_hostname=$(PWN_HOSTNAME)" -var "pwn_version=$(PWN_VERSION)" pwnagotchi.json + sudo mv builder/output-pwnagotchi/image pwnagotchi-rpi-os-lite-$(PWN_VERSION).img + sudo sha256sum pwnagotchi-rpi-os-lite-$(PWN_VERSION).img > pwnagotchi-rpi-os-lite-$(PWN_VERSION).sha256 + sudo zip pwnagotchi-rpi-os-lite-$(PWN_VERSION).zip pwnagotchi-rpi-os-lite-$(PWN_VERSION).sha256 pwnagotchi-rpi-os-lite-$(PWN_VERSION).img clean: - - python3 setup.py clean --all - - rm -rf dist pwnagotchi.egg-info - - rm -f $(PACKER) - - rm -f $(PWN_RELEASE).* - - sudo rm -rf builder/output-pwnagotchi builder/packer_cache \ No newline at end of file + rm -rf /tmp/packer-builder-arm-image + rm -f pwnagotchi-rpi-os-lite-*.zip pwnagotchi-rpi-os-lite-*.img pwnagotchi-rpi-os-lite-*.sha256 + rm -rf builder/output-pwnagotchi builder/packer_cache