GIT_ROOT = $(shell git rev-parse --show-toplevel) RED := $(shell tput -Txterm setaf 1) GRN := $(shell tput -Txterm setaf 2) YLW := $(shell tput -Txterm setaf 3) RST := $(shell tput -Txterm sgr0) BLD := $(shell tput bold) UID = $(shell id -u) GID = $(shell id -g) # Settings export LOG_LEVEL ?= 3 export LISTEN_PORT ?= 30301 export API_MODULES ?= eth,net,web3,admin export CONTAINER_NAME ?= status-go-bootnode export CONTAINER_IMAGE ?= statusteam/bootnode:latest # Necessary to make bootnode available publicly export PUBLIC_IP ?= $(shell curl -s https://ipecho.net/plain) all: checks start show info enode checks: ifeq (, $(shell which docker)) $(error $(RED)No 'docker' in your $$PATH. Please install it$(RST)) endif ifeq (, $(shell docker version | grep Server)) $(error $(RED)No permissions to run 'docker'. Add yourself to docker group$(RST)) endif ifeq (, $(shell which docker-compose)) $(error $(RED)No 'docker-compose' in your $$PATH. Please install it$(RST)) endif ifeq (, $(shell which jq)) $(error $(RED)No 'jq' in your $$PATH. Please install it$(RST)) endif ifndef PUBLIC_IP $(error $(RED)$$PUBLIC_IP not set! Export it as environment variable$(RST)) endif ifndef CONTAINER_NAME $(error $(RED)$$CONTAINER_NAME not set! Export it as environment variable$(RST)) endif start: keys/nodekey keys/nodeaddr docker-compose up -d stop: docker-compose down logs: docker-compose logs -f -t --tail=100 enode: keys/nodeaddr @echo "enode://$(shell cat keys/nodeaddr)@$(PUBLIC_IP):$(LISTEN_PORT)" info: @echo "$(GRN)Your bootnode is listening on:$(RST) $(BLD)$(PUBLIC_IP):$(LISTEN_PORT)$(RST)" @echo "$(YLW)Make sure that address and UDP port are available from the internet!$(RST)" @echo "$(GRN)Your enode address is:$(RST)" keys: @mkdir -p keys keys/nodekey: keys ##@ Generate a node key @docker run --rm \ -u $(UID):$(GID) \ --entrypoint=bootnode \ -v $(PWD)/keys:/keys:rw \ $(CONTAINER_IMAGE) \ -genkey=/keys/nodekey @echo "$(GRN)Created key for Bootnode: keys/nodekey$(RST)" keys/nodeaddr: keys ##@ Save node address for given key @docker run --rm \ -u $(UID):$(GID) \ --entrypoint=sh \ -v $(PWD)/keys:/keys:rw \ $(CONTAINER_IMAGE) \ -c 'bootnode -writeaddress -nodekey=/keys/nodekey > /keys/nodeaddr' show: @docker ps --filter='name=$(CONTAINER_NAME)' --format="table {{.ID}}\t{{.Names}}\t{{.Status}}\t{{.Ports}}" clean: docker-compose rm -s -f