BIN = $(GOPATH)/bin
BASE = $(GOPATH)/src/$(PACKAGE)
PKGS = go list ./... | grep -v "^vendor/"

#Tools
DEP = $(BIN)/dep
$(BIN)/dep:
	go get -u github.com/golang/dep/cmd/dep

GINKGO = $(BIN)/ginkgo
$(BIN)/ginkgo:
	go get -u github.com/onsi/ginkgo/ginkgo

MIGRATE = $(BIN)/migrate
$(BIN)/migrate:
	go get -u -d github.com/mattes/migrate/cli github.com/lib/pq
	go build -tags 'postgres' -o $(BIN)/migrate github.com/mattes/migrate/cli

LINT = $(BIN)/golint
$(BIN)/golint:
	go get -u golang.org/x/lint/golint

METALINT = $(BIN)/gometalinter.v2
$(BIN)/gometalinter.v2:
	go get -u gopkg.in/alecthomas/gometalinter.v2
	$(METALINT) --install

.PHONY: installtools
installtools: | $(LINT) $(MIGRATE) $(GINKGO) $(DEP)
	echo "Installing tools"

.PHONY: metalint
metalint: | $(METALINT)
	$(METALINT) ./... --vendor \
	--fast \
	--exclude="exported (function)|(var)|(method)|(type).*should have comment or be unexported" \
	--format="{{.Path.Abs}}:{{.Line}}:{{if .Col}}{{.Col}}{{end}}:{{.Severity}}: {{.Message}} ({{.Linter}})"

.PHONY: lint
lint:
	$(LINT) $$($(PKGS)) | grep -v -E "exported (function)|(var)|(method)|(type).*should have comment or be unexported"

.PHONY: test
test: | $(GINKGO) $(LINT)
	go vet ./...
	go fmt ./...
	$(GINKGO) -r --skipPackage=integration_tests,integration

.PHONY: integrationtest
integrationtest: | $(GINKGO) $(LINT)
	go vet ./...
	go fmt ./...
	$(GINKGO) -r pkg/transformers/integration_tests/ integration_test/

.PHONY: dep
dep: | $(DEP)
	$(DEP) ensure

build: dep
	go fmt ./...
	go build

#Database
HOST_NAME = localhost
PORT = 5432
NAME =
CONNECT_STRING=postgresql://$(HOST_NAME):$(PORT)/$(NAME)?sslmode=disable

.PHONY: checkdbvars
checkdbvars:
	test -n "$(HOST_NAME)" # $$HOST_NAME 
	test -n "$(PORT)" # $$PORT
	test -n "$(NAME)" # $$NAME
	@echo $(CONNECT_STRING)


.PHONY: rollback
rollback: $(MIGRATE) checkdbvars
	$(MIGRATE) -database $(CONNECT_STRING) -path ./db/migrations down 1
	pg_dump -O -s $(CONNECT_STRING) > db/schema.sql

.PHONY: migrate
migrate: $(MIGRATE) checkdbvars
	$(MIGRATE) -database $(CONNECT_STRING) -path ./db/migrations up
	pg_dump -O -s $(CONNECT_STRING) > db/schema.sql

.PHONY: import
import:
	test -n "$(NAME)" # $$NAME
	psql $(NAME) < db/schema.sql

#Rinkeby docker environment
RINKEBY_COMPOSE_FILE=dockerfiles/rinkeby/docker-compose.yml

.PHONY: rinkeby_env_up
rinkeby_env_up:
	docker-compose -f $(RINKEBY_COMPOSE_FILE) up -d geth
	docker-compose -f $(RINKEBY_COMPOSE_FILE) up --build migrations
	docker-compose -f $(RINKEBY_COMPOSE_FILE) up -d --build vulcanizedb

.PHONY: rinkeby_env_deploy
rinkeby_env_deploy:
	docker-compose -f $(RINKEBY_COMPOSE_FILE) up -d --build vulcanizedb

.PHONY: dev_env_migrate
rinkeby_env_migrate:
	docker-compose -f $(RINKEBY_COMPOSE_FILE) up --build migrations

.PHONY: rinkeby_env_down
rinkeby_env_down:
	docker-compose -f $(RINKEBY_COMPOSE_FILE) down