Merge pull request #13 from cure/add-Makefile
Add a Makefile with a few targets.
This commit is contained in:
commit
031c91a545
4 changed files with 67 additions and 4 deletions
24
Makefile
Normal file
24
Makefile
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
# Calculate version
|
||||||
|
version = $(shell ./scripts/version-at-commit.sh)
|
||||||
|
|
||||||
|
build:
|
||||||
|
go build -ldflags "-s -w -X main.version=$(version)" cmd/headscale/headscale.go
|
||||||
|
|
||||||
|
dev: lint test build
|
||||||
|
|
||||||
|
test:
|
||||||
|
go test -coverprofile=coverage.out
|
||||||
|
|
||||||
|
coverprofile_func:
|
||||||
|
go tool cover -func=coverage.out
|
||||||
|
|
||||||
|
coverprofile_html:
|
||||||
|
go tool cover -html=coverage.out
|
||||||
|
|
||||||
|
lint:
|
||||||
|
golint
|
||||||
|
golangci-lint run
|
||||||
|
|
||||||
|
compress: build
|
||||||
|
upx --brute cmd/headscale/headscale
|
||||||
|
|
|
@ -42,17 +42,17 @@ Suggestions/PRs welcomed!
|
||||||
|
|
||||||
1. Compile the headscale binary
|
1. Compile the headscale binary
|
||||||
```shell
|
```shell
|
||||||
go build cmd/headscale/headscale.go
|
make
|
||||||
```
|
```
|
||||||
|
|
||||||
2. Get youself a PostgreSQL DB running (yes, [I know](https://tailscale.com/blog/an-unlikely-database-migration/))
|
2. Get yourself a PostgreSQL DB running (yes, [I know](https://tailscale.com/blog/an-unlikely-database-migration/))
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
docker run --name headscale -e POSTGRES_DB=headscale -e \
|
docker run --name headscale -e POSTGRES_DB=headscale -e \
|
||||||
POSTGRES_USER=foo -e POSTGRES_PASSWORD=bar -p 5432:5432 -d postgres
|
POSTGRES_USER=foo -e POSTGRES_PASSWORD=bar -p 5432:5432 -d postgres
|
||||||
```
|
```
|
||||||
|
|
||||||
3. Sort some stuff up (headscale Wireguard keys & the config.json file)
|
3. Set some stuff up (headscale Wireguard keys & the config.json file)
|
||||||
```shell
|
```shell
|
||||||
wg genkey > private.key
|
wg genkey > private.key
|
||||||
wg pubkey < private.key > public.key # not needed
|
wg pubkey < private.key > public.key # not needed
|
||||||
|
|
|
@ -17,7 +17,7 @@ import (
|
||||||
"tailscale.com/tailcfg"
|
"tailscale.com/tailcfg"
|
||||||
)
|
)
|
||||||
|
|
||||||
const version = "0.1"
|
var version = "dev"
|
||||||
|
|
||||||
var versionCmd = &cobra.Command{
|
var versionCmd = &cobra.Command{
|
||||||
Use: "version",
|
Use: "version",
|
||||||
|
|
39
scripts/version-at-commit.sh
Executable file
39
scripts/version-at-commit.sh
Executable file
|
@ -0,0 +1,39 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e -o pipefail
|
||||||
|
commit="$1"
|
||||||
|
versionglob="v[0-9].[0-9]*.[0-9]*"
|
||||||
|
devsuffix=".dev"
|
||||||
|
if [ -z "$commit" ]; then
|
||||||
|
commit=`git log -n1 --first-parent "--format=format:%h"`
|
||||||
|
fi
|
||||||
|
|
||||||
|
# automatically assign version
|
||||||
|
#
|
||||||
|
# handles the following cases:
|
||||||
|
#
|
||||||
|
# 0. no tags on the repository. Print "dev".
|
||||||
|
#
|
||||||
|
# 1. no local modifications and commit is directly tagged. Print tag.
|
||||||
|
#
|
||||||
|
# 2. no local modifications and commit is not tagged. Take greatest version tag in repo X.Y.Z and assign X.Y.(Z+1). Print that + $devsuffix + $timestamp.
|
||||||
|
#
|
||||||
|
# 3. local modifications. Print "dev".
|
||||||
|
|
||||||
|
tags=$(git tag)
|
||||||
|
if [[ -z "$tags" ]]; then
|
||||||
|
echo "dev"
|
||||||
|
elif `git diff --quiet 2>/dev/null`; then
|
||||||
|
tagged=$(git tag --points-at "$commit")
|
||||||
|
if [[ -n "$tagged" ]] ; then
|
||||||
|
echo $tagged
|
||||||
|
else
|
||||||
|
nearest_tag=$(git describe --tags --abbrev=0 --match "$versionglob" "$commit")
|
||||||
|
v=$(echo $nearest_tag | perl -pe 's/(\d+)$/$1+1/e')
|
||||||
|
isodate=$(TZ=UTC git log -n1 --format=%cd --date=iso "$commit")
|
||||||
|
ts=$(TZ=UTC date --date="$isodate" "+%Y%m%d%H%M%S")
|
||||||
|
echo "${v}${devsuffix}${ts}"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "dev"
|
||||||
|
fi
|
Loading…
Reference in a new issue