2021-05-26 12:45:33 +02:00
|
|
|
# Build Flags
|
|
|
|
BUILD_NUMBER ?= $(BUILD_NUMBER:)
|
|
|
|
BUILD_DATE = $(shell date -u)
|
|
|
|
BUILD_HASH = $(shell git rev-parse HEAD)
|
|
|
|
# If we don't set the build number it defaults to dev
|
|
|
|
ifeq ($(BUILD_NUMBER),)
|
|
|
|
BUILD_NUMBER := dev
|
|
|
|
endif
|
|
|
|
|
|
|
|
LDFLAGS += -X "github.com/mattermost/focalboard/server/model.BuildNumber=$(BUILD_NUMBER)"
|
|
|
|
LDFLAGS += -X "github.com/mattermost/focalboard/server/model.BuildDate=$(BUILD_DATE)"
|
|
|
|
LDFLAGS += -X "github.com/mattermost/focalboard/server/model.BuildHash=$(BUILD_HASH)"
|
|
|
|
LDFLAGS += -X "github.com/mattermost/focalboard/server/model.Edition=plugin"
|
|
|
|
|
2021-05-24 19:06:11 +02:00
|
|
|
GO ?= $(shell command -v go 2> /dev/null)
|
|
|
|
NPM ?= $(shell command -v npm 2> /dev/null)
|
|
|
|
CURL ?= $(shell command -v curl 2> /dev/null)
|
|
|
|
MM_DEBUG ?=
|
|
|
|
MANIFEST_FILE ?= plugin.json
|
|
|
|
GOPATH ?= $(shell go env GOPATH)
|
|
|
|
GO_TEST_FLAGS ?= -race
|
2021-05-26 12:45:33 +02:00
|
|
|
GO_BUILD_FLAGS ?= -ldflags '$(LDFLAGS)'
|
2021-05-24 19:06:11 +02:00
|
|
|
MM_UTILITIES_DIR ?= ../mattermost-utilities
|
|
|
|
DLV_DEBUG_PORT := 2346
|
|
|
|
|
|
|
|
export GO111MODULE=on
|
|
|
|
|
|
|
|
# You can include assets this directory into the bundle. This can be e.g. used to include profile pictures.
|
|
|
|
ASSETS_DIR ?= assets
|
|
|
|
|
|
|
|
## Define the default target (make all)
|
|
|
|
.PHONY: default
|
|
|
|
default: all
|
|
|
|
|
|
|
|
# Verify environment, and define PLUGIN_ID, PLUGIN_VERSION, HAS_SERVER and HAS_WEBAPP as needed.
|
|
|
|
include build/setup.mk
|
|
|
|
|
|
|
|
BUNDLE_NAME ?= $(PLUGIN_ID)-$(PLUGIN_VERSION).tar.gz
|
|
|
|
|
|
|
|
# Include custom makefile, if present
|
|
|
|
ifneq ($(wildcard build/custom.mk),)
|
|
|
|
include build/custom.mk
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Checks the code style, tests, builds and bundles the plugin.
|
|
|
|
.PHONY: all
|
|
|
|
all: check-style test dist
|
|
|
|
|
|
|
|
## Propagates plugin manifest information into the server/ and webapp/ folders.
|
|
|
|
.PHONY: apply
|
|
|
|
apply:
|
|
|
|
./build/bin/manifest apply
|
|
|
|
|
|
|
|
## Runs eslint and golangci-lint
|
|
|
|
.PHONY: check-style
|
|
|
|
check-style: webapp/node_modules
|
|
|
|
@echo Checking for style guide compliance
|
|
|
|
|
|
|
|
ifneq ($(HAS_WEBAPP),)
|
|
|
|
cd webapp && npm run lint
|
|
|
|
cd webapp && npm run check-types
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq ($(HAS_SERVER),)
|
|
|
|
@if ! [ -x "$$(command -v golangci-lint)" ]; then \
|
|
|
|
echo "golangci-lint is not installed. Please see https://github.com/golangci/golangci-lint#install for installation instructions."; \
|
|
|
|
exit 1; \
|
|
|
|
fi; \
|
|
|
|
|
|
|
|
@echo Running golangci-lint
|
|
|
|
golangci-lint run ./...
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Builds the server, if it exists, for all supported architectures.
|
|
|
|
.PHONY: server
|
|
|
|
server:
|
|
|
|
ifneq ($(HAS_SERVER),)
|
|
|
|
mkdir -p server/dist;
|
|
|
|
ifeq ($(MM_DEBUG),)
|
2021-06-11 14:41:15 +02:00
|
|
|
cd server && env CGO_ENABLED=0 GOOS=linux GOARCH=amd64 $(GO) build $(GO_BUILD_FLAGS) -o dist/plugin-linux-amd64;
|
|
|
|
cd server && env CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 $(GO) build $(GO_BUILD_FLAGS) -o dist/plugin-darwin-amd64;
|
|
|
|
cd server && env CGO_ENABLED=0 GOOS=windows GOARCH=amd64 $(GO) build $(GO_BUILD_FLAGS) -o dist/plugin-windows-amd64.exe;
|
2021-05-24 19:06:11 +02:00
|
|
|
else
|
|
|
|
$(info DEBUG mode is on; to disable, unset MM_DEBUG)
|
|
|
|
|
2021-06-11 14:41:15 +02:00
|
|
|
cd server && env CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 $(GO) build $(GO_BUILD_FLAGS) -gcflags "all=-N -l" -o dist/plugin-darwin-amd64;
|
|
|
|
cd server && env CGO_ENABLED=0 GOOS=linux GOARCH=amd64 $(GO) build $(GO_BUILD_FLAGS) -gcflags "all=-N -l" -o dist/plugin-linux-amd64;
|
|
|
|
cd server && env CGO_ENABLED=0 GOOS=windows GOARCH=amd64 $(GO) build $(GO_BUILD_FLAGS) -gcflags "all=-N -l" -o dist/plugin-windows-amd64.exe;
|
2021-05-24 19:06:11 +02:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Ensures NPM dependencies are installed without having to run this all the time.
|
|
|
|
webapp/node_modules: $(wildcard webapp/package.json)
|
|
|
|
ifneq ($(HAS_WEBAPP),)
|
|
|
|
cd webapp && $(NPM) install
|
|
|
|
touch $@
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Builds the webapp, if it exists.
|
|
|
|
.PHONY: webapp
|
|
|
|
webapp: webapp/node_modules
|
|
|
|
ifneq ($(HAS_WEBAPP),)
|
|
|
|
ifeq ($(MM_DEBUG),)
|
|
|
|
cd webapp && $(NPM) run build;
|
|
|
|
else
|
|
|
|
cd webapp && $(NPM) run debug;
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Generates a tar bundle of the plugin for install.
|
|
|
|
.PHONY: bundle
|
|
|
|
bundle:
|
|
|
|
rm -rf dist/
|
|
|
|
mkdir -p dist/$(PLUGIN_ID)
|
|
|
|
cp $(MANIFEST_FILE) dist/$(PLUGIN_ID)/
|
|
|
|
cp -r ../webapp/pack dist/$(PLUGIN_ID)/
|
|
|
|
ifneq ($(wildcard $(ASSETS_DIR)/.),)
|
|
|
|
cp -r $(ASSETS_DIR) dist/$(PLUGIN_ID)/
|
|
|
|
endif
|
|
|
|
ifneq ($(HAS_PUBLIC),)
|
|
|
|
cp -r public dist/$(PLUGIN_ID)/
|
|
|
|
endif
|
|
|
|
ifneq ($(HAS_SERVER),)
|
|
|
|
mkdir -p dist/$(PLUGIN_ID)/server
|
|
|
|
cp -r server/dist dist/$(PLUGIN_ID)/server/
|
|
|
|
endif
|
|
|
|
ifneq ($(HAS_WEBAPP),)
|
|
|
|
mkdir -p dist/$(PLUGIN_ID)/webapp
|
|
|
|
cp -r webapp/dist dist/$(PLUGIN_ID)/webapp/
|
|
|
|
endif
|
|
|
|
cd dist && tar -cvzf $(BUNDLE_NAME) $(PLUGIN_ID)
|
|
|
|
|
|
|
|
@echo plugin built at: dist/$(BUNDLE_NAME)
|
|
|
|
|
|
|
|
## Builds and bundles the plugin.
|
|
|
|
.PHONY: dist
|
|
|
|
dist: apply server webapp bundle
|
|
|
|
|
|
|
|
## Builds and installs the plugin to a server.
|
|
|
|
.PHONY: deploy
|
|
|
|
deploy: dist
|
|
|
|
./build/bin/pluginctl deploy $(PLUGIN_ID) dist/$(BUNDLE_NAME)
|
|
|
|
|
|
|
|
## Builds and installs the plugin to a server, updating the webapp automatically when changed.
|
|
|
|
.PHONY: watch
|
|
|
|
watch: apply server bundle
|
|
|
|
ifeq ($(MM_DEBUG),)
|
|
|
|
cd webapp && $(NPM) run build:watch
|
|
|
|
else
|
|
|
|
cd webapp && $(NPM) run debug:watch
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Installs a previous built plugin with updated webpack assets to a server.
|
|
|
|
.PHONY: deploy-from-watch
|
|
|
|
deploy-from-watch: bundle
|
|
|
|
./build/bin/pluginctl deploy $(PLUGIN_ID) dist/$(BUNDLE_NAME)
|
|
|
|
|
|
|
|
## Setup dlv for attaching, identifying the plugin PID for other targets.
|
|
|
|
.PHONY: setup-attach
|
|
|
|
setup-attach:
|
|
|
|
$(eval PLUGIN_PID := $(shell ps aux | grep "plugins/${PLUGIN_ID}" | grep -v "grep" | awk -F " " '{print $$2}'))
|
|
|
|
$(eval NUM_PID := $(shell echo -n ${PLUGIN_PID} | wc -w))
|
|
|
|
|
|
|
|
@if [ ${NUM_PID} -gt 2 ]; then \
|
|
|
|
echo "** There is more than 1 plugin process running. Run 'make kill reset' to restart just one."; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
## Check if setup-attach succeeded.
|
|
|
|
.PHONY: check-attach
|
|
|
|
check-attach:
|
|
|
|
@if [ -z ${PLUGIN_PID} ]; then \
|
|
|
|
echo "Could not find plugin PID; the plugin is not running. Exiting."; \
|
|
|
|
exit 1; \
|
|
|
|
else \
|
|
|
|
echo "Located Plugin running with PID: ${PLUGIN_PID}"; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
## Attach dlv to an existing plugin instance.
|
|
|
|
.PHONY: attach
|
|
|
|
attach: setup-attach check-attach
|
|
|
|
dlv attach ${PLUGIN_PID}
|
|
|
|
|
|
|
|
## Attach dlv to an existing plugin instance, exposing a headless instance on $DLV_DEBUG_PORT.
|
|
|
|
.PHONY: attach-headless
|
|
|
|
attach-headless: setup-attach check-attach
|
|
|
|
dlv attach ${PLUGIN_PID} --listen :$(DLV_DEBUG_PORT) --headless=true --api-version=2 --accept-multiclient
|
|
|
|
|
|
|
|
## Detach dlv from an existing plugin instance, if previously attached.
|
|
|
|
.PHONY: detach
|
|
|
|
detach: setup-attach
|
|
|
|
@DELVE_PID=$(shell ps aux | grep "dlv attach ${PLUGIN_PID}" | grep -v "grep" | awk -F " " '{print $$2}') && \
|
|
|
|
if [ "$$DELVE_PID" -gt 0 ] > /dev/null 2>&1 ; then \
|
|
|
|
echo "Located existing delve process running with PID: $$DELVE_PID. Killing." ; \
|
|
|
|
kill -9 $$DELVE_PID ; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
## Runs any lints and unit tests defined for the server and webapp, if they exist.
|
|
|
|
.PHONY: test
|
|
|
|
test: webapp/node_modules
|
|
|
|
ifneq ($(HAS_SERVER),)
|
|
|
|
$(GO) test -v $(GO_TEST_FLAGS) ./server/...
|
|
|
|
endif
|
|
|
|
ifneq ($(HAS_WEBAPP),)
|
|
|
|
cd webapp && $(NPM) run test;
|
|
|
|
endif
|
|
|
|
ifneq ($(wildcard ./build/sync/plan/.),)
|
|
|
|
cd ./build/sync && $(GO) test -v $(GO_TEST_FLAGS) ./...
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Creates a coverage report for the server code.
|
|
|
|
.PHONY: coverage
|
|
|
|
coverage: webapp/node_modules
|
|
|
|
ifneq ($(HAS_SERVER),)
|
|
|
|
$(GO) test $(GO_TEST_FLAGS) -coverprofile=server/coverage.txt ./server/...
|
|
|
|
$(GO) tool cover -html=server/coverage.txt
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Extract strings for translation from the source code.
|
|
|
|
.PHONY: i18n-extract
|
|
|
|
i18n-extract:
|
|
|
|
ifneq ($(HAS_WEBAPP),)
|
|
|
|
ifeq ($(HAS_MM_UTILITIES),)
|
|
|
|
@echo "You must clone github.com/mattermost/mattermost-utilities repo in .. to use this command"
|
|
|
|
else
|
|
|
|
cd $(MM_UTILITIES_DIR) && npm install && npm run babel && node mmjstool/build/index.js i18n extract-webapp --webapp-dir $(PWD)/webapp
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
## Disable the plugin.
|
|
|
|
.PHONY: disable
|
|
|
|
disable: detach
|
|
|
|
./build/bin/pluginctl disable $(PLUGIN_ID)
|
|
|
|
|
|
|
|
## Enable the plugin.
|
|
|
|
.PHONY: enable
|
|
|
|
enable:
|
|
|
|
./build/bin/pluginctl enable $(PLUGIN_ID)
|
|
|
|
|
|
|
|
## Reset the plugin, effectively disabling and re-enabling it on the server.
|
|
|
|
.PHONY: reset
|
|
|
|
reset: detach
|
|
|
|
./build/bin/pluginctl reset $(PLUGIN_ID)
|
|
|
|
|
|
|
|
## Kill all instances of the plugin, detaching any existing dlv instance.
|
|
|
|
.PHONY: kill
|
|
|
|
kill: detach
|
|
|
|
$(eval PLUGIN_PID := $(shell ps aux | grep "plugins/${PLUGIN_ID}" | grep -v "grep" | awk -F " " '{print $$2}'))
|
|
|
|
|
|
|
|
@for PID in ${PLUGIN_PID}; do \
|
|
|
|
echo "Killing plugin pid $$PID"; \
|
|
|
|
kill -9 $$PID; \
|
|
|
|
done; \
|
|
|
|
|
|
|
|
## Clean removes all build artifacts.
|
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
|
|
|
rm -fr dist/
|
|
|
|
ifneq ($(HAS_SERVER),)
|
|
|
|
rm -fr server/coverage.txt
|
|
|
|
rm -fr server/dist
|
|
|
|
endif
|
|
|
|
ifneq ($(HAS_WEBAPP),)
|
|
|
|
rm -fr webapp/junit.xml
|
|
|
|
rm -fr webapp/dist
|
|
|
|
rm -fr webapp/node_modules
|
|
|
|
endif
|
|
|
|
rm -fr build/bin/
|
|
|
|
|
|
|
|
## Sync directory with a starter template
|
|
|
|
sync:
|
|
|
|
ifndef STARTERTEMPLATE_PATH
|
|
|
|
@echo STARTERTEMPLATE_PATH is not set.
|
|
|
|
@echo Set STARTERTEMPLATE_PATH to a local clone of https://github.com/mattermost/mattermost-plugin-starter-template and retry.
|
|
|
|
@exit 1
|
|
|
|
endif
|
|
|
|
cd ${STARTERTEMPLATE_PATH} && go run ./build/sync/main.go ./build/sync/plan.yml $(PWD)
|
|
|
|
|
|
|
|
# Help documentation à la https://marmelab.com/blog/2016/02/29/auto-documented-makefile.html
|
|
|
|
help:
|
|
|
|
@cat Makefile build/*.mk | grep -v '\.PHONY' | grep -v '\help:' | grep -B1 -E '^[a-zA-Z0-9_.-]+:.*' | sed -e "s/:.*//" | sed -e "s/^## //" | grep -v '\-\-' | sed '1!G;h;$$!d' | awk 'NR%2{printf "\033[36m%-30s\033[0m",$$0;next;}1' | sort
|