MAKEFLAGS += --no-builtin-rules --no-builtin-variables --warn-undefined-variables
unexport MAKEFLAGS
.DEFAULT_GOAL := all
.DELETE_ON_ERROR:
.SUFFIXES:
SHELL := bash
.SHELLFLAGS := -eu -o pipefail -c
escape = $(subst ','\'',$(1))
define noexpand
ifeq ($$(origin $(1)),environment)
$(1) := $$(value $(1))
endif
ifeq ($$(origin $(1)),environment override)
$(1) := $$(value $(1))
endif
ifeq ($$(origin $(1)),command line)
override $(1) := $$(value $(1))
endif
endef
.PHONY: DO
DO:
PROJECT := fr24feed
# Target platforms (used by buildx):
PLATFORMS := linux/i386,linux/amd64,linux/armhf
# Docker Hub credentials:
DOCKER_USERNAME := egortensin
# Use BuildKit, which is required (i.e. for using variables in FROM):
export DOCKER_BUILDKIT := 1
ifdef DOCKER_PASSWORD
$(eval $(call noexpand,DOCKER_PASSWORD))
endif
.PHONY: all
all: build
.PHONY: login
login:
ifndef DOCKER_PASSWORD
$(error Please define DOCKER_PASSWORD)
endif
@echo '$(call escape,$(DOCKER_PASSWORD))' | docker login --username '$(call escape,$(DOCKER_USERNAME))' --password-stdin
.PHONY: build
# Build natively by default.
build: compose/build
.PHONY: clean
clean:
docker system prune --all --force --volumes
.PHONY: push
# Push multi-arch images by default.
push: buildx/push
.PHONY: pull
pull:
docker-compose pull
.PHONY: up
up:
docker-compose up -d
.PHONY: down
down:
docker-compose down --volumes
.PHONY: check-build
check-build:
ifndef FORCE
$(warning Going to build natively; consider `docker buildx build` instead)
endif
.PHONY: check-push
check-push:
ifndef FORCE
$(error Please use `docker buildx build --push` instead)
endif
# `docker build` has week support for multiarch repos (you need to use multiple
# Dockerfile's, create a manifest manually, etc.), so it's only here for
# testing purposes, and native builds.
docker/build/%: DO check-build
docker build -t '$(call escape,$(DOCKER_USERNAME))/$*' '$*/'
.PHONY: docker/build
docker/build: docker/build/dump1090 docker/build/fr24feed
# `docker push` would replace the multiarch repo with a single image by default
# (you'd have to create a manifest and push it instead), so it's only here for
# testing purposes.
docker/push/%: DO check-push docker/build/%
docker push '$(call escape,$(DOCKER_USERNAME))/$*'
.PHONY: docker/push
docker/push: check-push docker/push/dump1090 docker/push/fr24feed
.PHONY: compose/build
# `docker-compose build` has the same problems as `docker build`.
compose/build: check-build
docker-compose build
.PHONY: compose/push
# `docker-compose push` has the same problems as `docker push`.
compose/push: check-push compose/build
docker-compose push
.PHONY: buildx/create
buildx/create:
docker buildx create --use --name '$(call escape,$(PROJECT))_builder'
.PHONY: buildx/rm
buildx/rm:
docker buildx rm '$(call escape,$(PROJECT))_builder'
buildx/build/%: DO
docker buildx build -t '$(call escape,$(DOCKER_USERNAME))/$*' --platform '$(call escape,$(PLATFORMS))' '$*/'
.PHONY: buildx/build
buildx/build: buildx/build/dump1090 buildx/build/fr24feed
buildx/push/%: DO
docker buildx build -t '$(call escape,$(DOCKER_USERNAME))/$*' --platform '$(call escape,$(PLATFORMS))' --push '$*/'
.PHONY: buildx/push
buildx/push: buildx/push/dump1090 buildx/push/fr24feed