123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- SERVICE=Wechat
- SERVICE_STYLE=wechat
- SERVICE_LOWER=wechat
- SERVICE_SNAKE=wechat
- SERVICE_DASH=wechat
- VERSION=$(shell git describe --tags --always)
- PROJECT_STYLE=go_zero
- PROJECT_I18N=false
- PROJECT_BUILD_SUFFIX=api
- SWAGGER_TYPE=json
- ENT_FEATURE=sql/execquery,sql/upsert,intercept
- AUTO_API_INIT_DATA=true
- GOARCH=amd64
- GO ?= go
- GOFMT ?= gofmt "-s"
- GOFILES := $(shell find . -name "*.go")
- LDFLAGS := -s -w
- .PHONY: test
- test: # Run test for the project | 运行项目测试
- go test -v --cover ./internal/..
- .PHONY: fmt
- fmt: # Format the codes | 格式化代码
- $(GOFMT) -w $(GOFILES)
- .PHONY: lint
- lint: # Run go linter | 运行代码错误分析
- golangci-lint run -D staticcheck
- .PHONY: tools
- tools: # Install the necessary tools | 安装必要的工具
- $(GO) install github.com/golangci/golangci-lint/cmd/golangci-lint@latest;
- $(GO) install github.com/go-swagger/go-swagger/cmd/swagger@latest
- .PHONY: docker
- docker: # Build the docker image | 构建 docker 镜像
- docker build -f Dockerfile -t ${DOCKER_USERNAME}/$(SERVICE_DASH)-$(PROJECT_BUILD_SUFFIX):${VERSION} .
- @echo "Build docker successfully"
- .PHONY: publish-docker
- publish-docker: # Publish docker image | 发布 docker 镜像
- echo "${DOCKER_PASSWORD}" | docker login --username ${DOCKER_USERNAME} --password-stdin https://${REPO}
- docker push ${DOCKER_USERNAME}/$(SERVICE_DASH)-$(PROJECT_BUILD_SUFFIX):${VERSION}
- @echo "Publish docker successfully"
- .PHONY: gen-swagger
- gen-swagger: # Generate swagger file | 生成 swagger 文件
- swagger generate spec --output=./$(SERVICE_STYLE).$(SWAGGER_TYPE) --scan-models
- @echo "Generate swagger successfully"
- .PHONY: serve-swagger
- serve-swagger: # Run the swagger server | 运行 swagger 服务
- lsof -i:36666 | awk 'NR!=1 {print $2}' | xargs killall -9 || true
- swagger serve -F=swagger --port 36666 $(SERVICE_STYLE).$(SWAGGER_TYPE)
- @echo "Serve swagger-ui successfully"
- .PHONY: gen-api
- gen-api: # Generate API files | 生成 API 的代码
- goctls api go --api ./desc/all.api --dir ./ --trans_err=false --style=$(PROJECT_STYLE)
- @echo "Generate API codes successfully"
- .PHONY: gen-ent
- gen-ent: # Generate Ent codes | 生成 Ent 的代码
- go run -mod=mod entgo.io/ent/cmd/ent generate --template glob="./ent/template/*.tmpl" ./ent/schema --feature $(ENT_FEATURE)
- @echo "Generate Ent codes successfully"
- .PHONY: gen-api-ent-logic
- gen-api-ent-logic: # Generate CRUD logic from Ent, need to set model and group | 根据 Ent 生成 CRUD 代码,需要设置 model 和 group
- goctls api ent --schema=./ent/schema --style=$(PROJECT_STYLE) --api_service_name=$(SERVICE) --output=./ --model=$(model) --group=$(group) --i18n=$(PROJECT_I18N) --overwrite=true --api_data=$(AUTO_API_INIT_DATA)
- @echo "Generate CRUD codes from Ent successfully"
- .PHONY: build-win
- build-win: # Build project for Windows | 构建Windows下的可执行文件
- env CGO_ENABLED=0 GOOS=windows GOARCH=$(GOARCH) go build -ldflags "$(LDFLAGS)" -trimpath -o $(SERVICE_STYLE)_$(PROJECT_BUILD_SUFFIX).exe $(SERVICE_STYLE).go
- @echo "Build project for Windows successfully"
- .PHONY: build-mac
- build-mac: # Build project for MacOS | 构建MacOS下的可执行文件
- env CGO_ENABLED=0 GOOS=darwin GOARCH=$(GOARCH) go build -ldflags "$(LDFLAGS)" -trimpath -o $(SERVICE_STYLE)_$(PROJECT_BUILD_SUFFIX) $(SERVICE_STYLE).go
- @echo "Build project for MacOS successfully"
- .PHONY: build-linux
- build-linux: # Build project for Linux | 构建Linux下的可执行文件
- env CGO_ENABLED=0 GOOS=linux GOARCH=$(GOARCH) go build -ldflags "$(LDFLAGS)" -trimpath -o $(SERVICE_STYLE)_$(PROJECT_BUILD_SUFFIX) $(SERVICE_STYLE).go
- @echo "Build project for Linux successfully"
- .PHONY: help
- help: # Show help | 显示帮助
- @grep -E '^[a-zA-Z0-9 -]+:.*
|