include ../../metadata.mk
include ../../lib.Makefile

# We only ever release from the tip of a release branch.
GIT_BRANCH?=$(git rev-parse HEAD)

# Build a release from the currently checked out commit.
# Uses SSH to run commands on the remote builder.
release: .vm.created
	./remote-execute.sh "cd calico && git fetch --tags && git checkout $(GIT_BRANCH)"
	./remote-execute.sh "cd calico && make release"

git-fetch-remote: .vm.created
	./remote-execute.sh "cd calico && git fetch --tags && git checkout $(GIT_BRANCH)"

update-versions-remote: .vm.created
	./remote-execute.sh "cd calico && make update-versions"

generate-manifests-remote:
	./remote-execute.sh "cd calico && make generate"

commit-versions-remote: .vm.created
	./remote-execute.sh "cd calico && make commit-versions-manifests"

build-release-remote: .vm.created
	./remote-execute.sh "cd calico && make release"

# Expects that a release has already been created on the remote VM via the "release" target.
release-publish: .vm.created
	./remote-execute.sh "cd calico && make release-publish"

# Create a VM using the given vars.
VAR_FILE ?= terraform.tfvars
apply:  .vm.created
.vm.created: .terraform.init
	./bin/terraform apply --auto-approve -var-file=$(VAR_FILE) && touch $@

# Destroy the VM.
destroy:
	./bin/terraform destroy --auto-approve -var-file=$(VAR_FILE)
	rm -f .vm.created

# Tear down any existing VM, and create a new one.
rebuild:
	$(MAKE) destroy apply

# Initialize the terraform install.
.terraform.init: bin/terraform
	./bin/terraform init && touch $@

# Install the terraform binary.
bin/terraform: bin/terraform.zip
	unzip bin/terraform.zip -d bin && touch $@
bin/terraform.zip:
	mkdir -p bin
	wget https://releases.hashicorp.com/terraform/1.1.7/terraform_1.1.7_linux_amd64.zip -O $@
