mirror of
https://github.com/empayre/fleet.git
synced 2024-11-06 17:05:18 +00:00
796e0af8be
This PR implements a program called `fleetctl` which scaffolds a high level CLI interface which can be used to manage a Fleet server. Configuration is articulated using an intent-based API that resembles the API that is used to configure Kubernetes clusters. The idea here is to use the Kubernetes file format as a pattern to reduce the need for operators to become too intimately familiar with dramatically different file formats. (#1578)
211 lines
6.0 KiB
Makefile
211 lines
6.0 KiB
Makefile
.PHONY: build
|
|
|
|
PATH := $(GOPATH)/bin:$(shell npm bin):$(PATH)
|
|
VERSION = $(shell git describe --tags --always --dirty)
|
|
BRANCH = $(shell git rev-parse --abbrev-ref HEAD)
|
|
REVISION = $(shell git rev-parse HEAD)
|
|
REVSHORT = $(shell git rev-parse --short HEAD)
|
|
USER = $(shell whoami)
|
|
DOCKER_IMAGE_NAME = kolide/fleet
|
|
|
|
ifneq ($(OS), Windows_NT)
|
|
# If on macOS, set the shell to bash explicitly
|
|
ifeq ($(shell uname), Darwin)
|
|
SHELL := /bin/bash
|
|
endif
|
|
|
|
# The output binary name is different on Windows, so we're explicit here
|
|
OUTPUT = fleet
|
|
|
|
# To populate version metadata, we use unix tools to get certain data
|
|
GOVERSION = $(shell go version | awk '{print $$3}')
|
|
NOW = $(shell date -u +"%Y-%m-%dT%H:%M:%SZ")
|
|
else
|
|
# The output binary name is different on Windows, so we're explicit here
|
|
OUTPUT = fleet.exe
|
|
|
|
# To populate version metadata, we use windows tools to get the certain data
|
|
GOVERSION_CMD = "(go version).Split()[2]"
|
|
GOVERSION = $(shell powershell $(GOVERSION_CMD))
|
|
NOW = $(shell powershell Get-Date -format s)
|
|
endif
|
|
|
|
ifndef CIRCLE_PR_NUMBER
|
|
DOCKER_IMAGE_TAG = ${REVSHORT}
|
|
else
|
|
DOCKER_IMAGE_TAG = dev-${CIRCLE_PR_NUMBER}-${REVSHORT}
|
|
endif
|
|
|
|
ifdef CIRCLE_TAG
|
|
DOCKER_IMAGE_TAG = ${CIRCLE_TAG}
|
|
endif
|
|
|
|
ifndef MYSQL_PORT_3306_TCP_ADDR
|
|
MYSQL_PORT_3306_TCP_ADDR = 127.0.0.1
|
|
endif
|
|
|
|
KIT_VERSION = "\
|
|
-X github.com/kolide/fleet/vendor/github.com/kolide/kit/version.appName=${APP_NAME} \
|
|
-X github.com/kolide/fleet/vendor/github.com/kolide/kit/version.version=${VERSION} \
|
|
-X github.com/kolide/fleet/vendor/github.com/kolide/kit/version.branch=${BRANCH} \
|
|
-X github.com/kolide/fleet/vendor/github.com/kolide/kit/version.revision=${REVISION} \
|
|
-X github.com/kolide/fleet/vendor/github.com/kolide/kit/version.buildDate=${NOW} \
|
|
-X github.com/kolide/fleet/vendor/github.com/kolide/kit/version.buildUser=${USER} \
|
|
-X github.com/kolide/fleet/vendor/github.com/kolide/kit/version.goVersion=${GOVERSION}"
|
|
|
|
all: build
|
|
|
|
define HELP_TEXT
|
|
|
|
Makefile commands
|
|
|
|
make deps - Install depedent programs and libraries
|
|
make generate - Generate and bundle required code
|
|
make generate-dev - Generate and bundle required code in a watch loop
|
|
make distclean - Delete all build artifacts
|
|
|
|
make build - Build the code
|
|
make package - Build rpm and deb packages for linux
|
|
|
|
make test - Run the full test suite
|
|
make test-go - Run the Go tests
|
|
make test-js - Run the JavaScript tests
|
|
|
|
make lint - Run all linters
|
|
make lint-go - Run the Go linters
|
|
make lint-js - Run the JavaScript linters
|
|
make lint-scss - Run the SCSS linters
|
|
make lint-ts - Run the TypeScript linters
|
|
|
|
endef
|
|
|
|
help:
|
|
$(info $(HELP_TEXT))
|
|
|
|
.prefix:
|
|
ifeq ($(OS), Windows_NT)
|
|
if not exist build mkdir build
|
|
else
|
|
mkdir -p build/linux
|
|
mkdir -p build/darwin
|
|
endif
|
|
|
|
.pre-build:
|
|
$(eval GOGC = off)
|
|
$(eval CGO_ENABLED = 0)
|
|
|
|
.pre-fleet:
|
|
$(eval APP_NAME = fleet)
|
|
|
|
.pre-fleetctl:
|
|
$(eval APP_NAME = fleetctl)
|
|
|
|
build: fleet
|
|
|
|
fleet: .prefix .pre-build .pre-fleet
|
|
go build -i -o build/${OUTPUT} -ldflags ${KIT_VERSION} ./cmd/fleet
|
|
|
|
fleetctl: .prefix .pre-build .pre-fleetctl
|
|
go build -i -o build/fleetctl -ldflags ${KIT_VERSION} ./cmd/fleetctl
|
|
|
|
lint-js:
|
|
eslint frontend --ext .js,.jsx
|
|
|
|
lint-ts:
|
|
tslint frontend/**/*.tsx frontend/**/*.ts
|
|
|
|
lint-scss:
|
|
sass-lint --verbose
|
|
|
|
lint-go:
|
|
go vet ./...
|
|
|
|
lint: lint-go lint-js lint-scss lint-ts
|
|
|
|
test-go:
|
|
go test ./...
|
|
|
|
analyze-go:
|
|
go test -race -cover ./...
|
|
|
|
|
|
test-js: export NODE_PATH = ./frontend
|
|
test-js:
|
|
_mocha --compilers js:babel-core/register,tsx:typescript-require \
|
|
--recursive "frontend/**/*.tests.js*" \
|
|
--require ignore-styles \
|
|
--require "frontend/.test.setup.js" \
|
|
--require "frontend/test/loaderMock.js"
|
|
|
|
test: lint test-go test-js
|
|
|
|
generate: .prefix
|
|
NODE_ENV=production webpack --progress --colors
|
|
go-bindata -pkg=service \
|
|
-o=server/service/bindata.go \
|
|
frontend/templates/ assets/...
|
|
go-bindata -pkg=kolide -o=server/kolide/bindata.go server/mail/templates
|
|
|
|
|
|
# we first generate the webpack bundle so that bindata knows to watch the
|
|
# output bundle file. then, generate debug bindata source file. finally, we
|
|
# run webpack in watch mode to continuously re-generate the bundle
|
|
generate-dev: .prefix
|
|
webpack --progress --colors
|
|
go-bindata -debug -pkg=service \
|
|
-o=server/service/bindata.go \
|
|
frontend/templates/ assets/...
|
|
go-bindata -pkg=kolide -o=server/kolide/bindata.go server/mail/templates
|
|
webpack --progress --colors --watch
|
|
|
|
deps:
|
|
yarn
|
|
go get -u \
|
|
github.com/jteeuwen/go-bindata/... \
|
|
github.com/golang/dep/cmd/dep \
|
|
github.com/groob/mockimpl
|
|
dep ensure -vendor-only
|
|
|
|
distclean:
|
|
ifeq ($(OS), Windows_NT)
|
|
if exist build rmdir /s/q build
|
|
if exist vendor rmdir /s/q vendor
|
|
if exist assets\bundle.js del assets\bundle.js
|
|
else
|
|
rm -rf build vendor
|
|
rm -f assets/bundle.js
|
|
endif
|
|
|
|
docker-build-release: .pre-fleet
|
|
GOOS=linux go build -i -o build/linux/${OUTPUT} -ldflags ${KIT_VERSION} ./cmd/fleet
|
|
docker build -t "${DOCKER_IMAGE_NAME}:${DOCKER_IMAGE_TAG}" .
|
|
docker tag "${DOCKER_IMAGE_NAME}:${DOCKER_IMAGE_TAG}" kolide/fleet:latest
|
|
docker push "${DOCKER_IMAGE_NAME}:${DOCKER_IMAGE_TAG}"
|
|
docker push kolide/fleet:latest
|
|
|
|
docker-build-circle:
|
|
@echo ">> building docker image"
|
|
GOOS=linux go build -i -o build/linux/${OUTPUT} -ldflags ${KIT_VERSION} ./cmd/fleet
|
|
docker build -t "${DOCKER_IMAGE_NAME}:${DOCKER_IMAGE_TAG}" .
|
|
docker push "${DOCKER_IMAGE_NAME}:${DOCKER_IMAGE_TAG}"
|
|
|
|
demo-dump:
|
|
mysqldump --extended-insert=FALSE --skip-dump-date \
|
|
-u kolide -p \
|
|
-h ${MYSQL_PORT_3306_TCP_ADDR} kolide \
|
|
> ./tools/app/demo.sql
|
|
|
|
demo-restore:
|
|
mysql --binary-mode -u kolide -p \
|
|
-h ${MYSQL_PORT_3306_TCP_ADDR} kolide \
|
|
< ./tools/app/demo.sql
|
|
|
|
binary-bundle:
|
|
rm -rf build/binary-bundle
|
|
mkdir -p build/binary-bundle/linux
|
|
mkdir -p build/binary-bundle/darwin
|
|
GOOS=linux go build -i -o build/binary-bundle/linux/${OUTPUT}_linux_amd64 -ldflags ${KIT_VERSION} ./cmd/fleet
|
|
GOOS=darwin go build -i -o build/binary-bundle/darwin/${OUTPUT}_darwin_amd64 -ldflags ${KIT_VERSION} ./cmd/fleet
|
|
cd build/binary-bundle && zip -r "fleet_${VERSION}.zip" darwin/ linux/
|
|
cp build/binary-bundle/fleet_${VERSION}.zip build/binary-bundle/fleet_lastest.zip
|