CARGO_VERSION=$$(grep version Cargo.toml | head -1 | awk '{ print $$3 }' | sed 's/"//g') .
build: test
cargo build
test:
cargo test
test-integration: test
TOKEN=${TOKEN} NETWORK=${NETWORK} sudo -E bash -c "$$(which cargo) test -- --ignored"
generate: central service
central:
bash generate.sh central zerotier-central-api
service:
bash generate.sh service zerotier-one-api
docker-image:
docker build -t zerotier/zeronsd .
docker-image-package:
docker build --build-arg IS_LOCAL=1 -t zerotier/zeronsd:$(CARGO_VERSION)
packages:
make docker-image-package
docker build -f Dockerfile.packages -t zeronsd-packages .
docker run -it -v ${PWD}:/code -w /code --rm zeronsd-packages bash -c "cargo deb && cargo-generate-rpm"
make packages-out
packages-out:
@echo
@find target -name '*.deb' -o -name '*.rpm'
@echo docker image "zerotier/zeronsd:$(CARGO_VERSION)" was tagged
@echo
@echo "The files were written as root. Please ensure they fit your needed permissions manually."
@echo
clean:
@echo
@echo Running sudo to clean your target directory
@echo
sudo rm -rf target zerotier-central-api/target zerotier-one-api/target
cargo clean
test-packages: clean
make packages
docker run -v ${PWD}:/code --rm -it centos rpm -ivh /code/target/generate-rpm/\*.rpm
for image in debian ubuntu; do \
docker run -v ${PWD}:/code --rm -it $$image \
bash -c "apt update -qq && apt install libssl1.1 -y && dpkg -i /code/$$(find target -name '*.deb')"; \
done
docker run --rm zerotier/zeronsd:$(CARGO_VERSION) help 2>/dev/null
make packages-out
.PHONY: generate central service \
docker-image docker-image-package \
packages packages-out test-packages \
clean