fix missing docs, add missing license
fix broken pre/post scripts for packages
This commit is contained in:
parent
66e897ace3
commit
a6673b4d42
|
|
@ -93,6 +93,7 @@ archives:
|
||||||
- unpoller_manual.html
|
- unpoller_manual.html
|
||||||
- rsrc_windows_*.syso
|
- rsrc_windows_*.syso
|
||||||
- examples/up.*.example
|
- examples/up.*.example
|
||||||
|
- init/windows/application.ico
|
||||||
|
|
||||||
dockers:
|
dockers:
|
||||||
- id: docker-linux-amd64
|
- id: docker-linux-amd64
|
||||||
|
|
@ -242,9 +243,10 @@ nfpms:
|
||||||
version_metadata: git
|
version_metadata: git
|
||||||
section: default
|
section: default
|
||||||
priority: extra
|
priority: extra
|
||||||
|
# provides defines the packages. The first one defines the package name.
|
||||||
provides:
|
provides:
|
||||||
- unifi-poller
|
|
||||||
- unpoller
|
- unpoller
|
||||||
|
- unifi-poller
|
||||||
|
|
||||||
# Contents to add to the package.
|
# Contents to add to the package.
|
||||||
# GoReleaser will automatically add the binaries.
|
# GoReleaser will automatically add the binaries.
|
||||||
|
|
@ -252,7 +254,11 @@ nfpms:
|
||||||
- dst: /etc/unpoller
|
- dst: /etc/unpoller
|
||||||
type: dir
|
type: dir
|
||||||
file_info:
|
file_info:
|
||||||
mode: 0700
|
mode: 0740
|
||||||
|
- dst: /usr/share/doc/unpoller
|
||||||
|
type: dir
|
||||||
|
file_info:
|
||||||
|
mode: 0755
|
||||||
|
|
||||||
# Example config files
|
# Example config files
|
||||||
- src: examples/up.conf.example
|
- src: examples/up.conf.example
|
||||||
|
|
@ -270,6 +276,59 @@ nfpms:
|
||||||
- src: "unpoller_manual.html"
|
- src: "unpoller_manual.html"
|
||||||
dst: /etc/unpoller/manual.html
|
dst: /etc/unpoller/manual.html
|
||||||
type: config
|
type: config
|
||||||
|
|
||||||
|
# man pages
|
||||||
|
- src: unpoller.1.gz
|
||||||
|
dst: /usr/share/man/man1/unpoller.1.gz
|
||||||
|
type: man
|
||||||
|
- src: LICENSE
|
||||||
|
dst: /usr/share/doc/unpoller/LICENSE
|
||||||
|
type: man
|
||||||
|
- src: unpoller_manual.html
|
||||||
|
dst: /usr/share/doc/unpoller/unpoller_manual.html
|
||||||
|
type: man
|
||||||
|
|
||||||
|
# systemd service
|
||||||
|
- src: init/systemd/unpoller.service
|
||||||
|
dst: /lib/systemd/service/unpoller.service
|
||||||
|
type: config
|
||||||
|
|
||||||
|
# freebsd rc service
|
||||||
|
- src: init/bsd/freebsd.rc.d
|
||||||
|
dst: /usr/local/etc/rc.d/unpoller
|
||||||
|
type: config
|
||||||
|
|
||||||
|
# web server statics
|
||||||
|
- dst: /usr/local/lib/unpoller/web/static/
|
||||||
|
type: dir
|
||||||
|
file_info:
|
||||||
|
mode: 0755
|
||||||
|
- dst: /usr/local/lib/unpoller/web/static/css
|
||||||
|
type: dir
|
||||||
|
file_info:
|
||||||
|
mode: 0755
|
||||||
|
- dst: /usr/local/lib/unpoller/web/static/images
|
||||||
|
type: dir
|
||||||
|
file_info:
|
||||||
|
mode: 0755
|
||||||
|
- dst: /usr/local/lib/unpoller/web/static/js
|
||||||
|
type: dir
|
||||||
|
file_info:
|
||||||
|
mode: 0755
|
||||||
|
- src: init/webserver/index.html
|
||||||
|
dst: /usr/local/lib/unpoller/web/static/index.html
|
||||||
|
type: config
|
||||||
|
- src: init/webserver/static/css/*
|
||||||
|
dst: /usr/local/lib/unpoller/web/static//css
|
||||||
|
type: config
|
||||||
|
- src: init/webserver/static/images/*
|
||||||
|
dst: /usr/local/lib/unpoller/web/static/images
|
||||||
|
type: config
|
||||||
|
- src: init/webserver/static/js/*
|
||||||
|
dst: /usr/local/lib/unpoller/web/static/js
|
||||||
|
type: config
|
||||||
|
|
||||||
|
|
||||||
# signing
|
# signing
|
||||||
scripts:
|
scripts:
|
||||||
postinstall: "scripts/after-install.sh"
|
postinstall: "scripts/after-install.sh"
|
||||||
|
|
|
||||||
239
Makefile
239
Makefile
|
|
@ -73,7 +73,7 @@ all: clean generate build
|
||||||
####################
|
####################
|
||||||
|
|
||||||
# Prepare a release. Called in Travis CI.
|
# Prepare a release. Called in Travis CI.
|
||||||
release: clean linux_packages freebsd_packages windows
|
release: clean windows
|
||||||
# Prepareing a release!
|
# Prepareing a release!
|
||||||
mkdir -p $@
|
mkdir -p $@
|
||||||
mv $(BINARY).*.linux $(BINARY).*.freebsd $@/
|
mv $(BINARY).*.linux $(BINARY).*.freebsd $@/
|
||||||
|
|
@ -93,6 +93,7 @@ dmg: clean macapp
|
||||||
|
|
||||||
# Delete all build assets.
|
# Delete all build assets.
|
||||||
clean:
|
clean:
|
||||||
|
rm -rf dist
|
||||||
rm -f $(BINARY) $(BINARY).*.{macos,freebsd,linux,exe,upx}{,.gz,.zip} $(BINARY).1{,.gz} $(BINARY).rb
|
rm -f $(BINARY) $(BINARY).*.{macos,freebsd,linux,exe,upx}{,.gz,.zip} $(BINARY).1{,.gz} $(BINARY).rb
|
||||||
rm -f $(BINARY){_,-}*.{deb,rpm,txz} v*.tar.gz.sha256 examples/MANUAL .metadata.make rsrc_*.syso
|
rm -f $(BINARY){_,-}*.{deb,rpm,txz} v*.tar.gz.sha256 examples/MANUAL .metadata.make rsrc_*.syso
|
||||||
rm -f cmd/$(BINARY)/README{,.html} README{,.html} ./$(BINARY)_manual.html rsrc.syso $(MACAPP).app.zip
|
rm -f cmd/$(BINARY)/README{,.html} README{,.html} ./$(BINARY)_manual.html rsrc.syso $(MACAPP).app.zip
|
||||||
|
|
@ -137,51 +138,12 @@ $(BINARY): main.go
|
||||||
go build -o $(BINARY) -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
go build -o $(BINARY) -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
||||||
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@
|
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@
|
||||||
|
|
||||||
linux: $(BINARY).amd64.linux
|
|
||||||
$(BINARY).amd64.linux: main.go
|
|
||||||
# Building linux 64-bit x86 binary.
|
|
||||||
GOOS=linux GOARCH=amd64 go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
|
||||||
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@
|
|
||||||
|
|
||||||
linux386: $(BINARY).i386.linux
|
|
||||||
$(BINARY).i386.linux: main.go
|
|
||||||
# Building linux 32-bit x86 binary.
|
|
||||||
GOOS=linux GOARCH=386 go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
|
||||||
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@
|
|
||||||
|
|
||||||
arm: arm64 armhf
|
|
||||||
|
|
||||||
arm64: $(BINARY).arm64.linux
|
|
||||||
$(BINARY).arm64.linux: main.go
|
|
||||||
# Building linux 64-bit ARM binary.
|
|
||||||
GOOS=linux GOARCH=arm64 go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
|
||||||
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@
|
|
||||||
|
|
||||||
armhf: $(BINARY).armhf.linux
|
|
||||||
$(BINARY).armhf.linux: main.go
|
|
||||||
# Building linux 32-bit ARM binary.
|
|
||||||
GOOS=linux GOARCH=arm GOARM=6 go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
|
||||||
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@
|
|
||||||
|
|
||||||
macos: $(BINARY).amd64.macos
|
macos: $(BINARY).amd64.macos
|
||||||
$(BINARY).amd64.macos: main.go
|
$(BINARY).amd64.macos: main.go
|
||||||
# Building darwin 64-bit x86 binary.
|
# Building darwin 64-bit x86 binary.
|
||||||
GOOS=darwin GOARCH=amd64 go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
GOOS=darwin GOARCH=amd64 go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
||||||
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@
|
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@
|
||||||
|
|
||||||
freebsd: $(BINARY).amd64.freebsd
|
|
||||||
$(BINARY).amd64.freebsd: main.go
|
|
||||||
GOOS=freebsd GOARCH=amd64 go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
|
||||||
|
|
||||||
freebsd386: $(BINARY).i386.freebsd
|
|
||||||
$(BINARY).i386.freebsd: main.go
|
|
||||||
GOOS=freebsd GOARCH=386 go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
|
||||||
[ -z "$(UPXPATH)" ] || $(UPXPATH) -q9 $@ || true
|
|
||||||
|
|
||||||
freebsdarm: $(BINARY).armhf.freebsd
|
|
||||||
$(BINARY).armhf.freebsd: main.go
|
|
||||||
GOOS=freebsd GOARCH=arm go build -o $@ -ldflags "-w -s $(VERSION_LDFLAGS) $(EXTRA_LDFLAGS) "
|
|
||||||
|
|
||||||
exe: $(BINARY).amd64.exe
|
exe: $(BINARY).amd64.exe
|
||||||
windows: $(BINARY).amd64.exe
|
windows: $(BINARY).amd64.exe
|
||||||
$(BINARY).amd64.exe: rsrc.syso main.go
|
$(BINARY).amd64.exe: rsrc.syso main.go
|
||||||
|
|
@ -193,206 +155,12 @@ $(BINARY).amd64.exe: rsrc.syso main.go
|
||||||
##### Packages #####
|
##### Packages #####
|
||||||
####################
|
####################
|
||||||
|
|
||||||
linux_packages: rpm deb rpm386 deb386 debarm rpmarm debarmhf rpmarmhf
|
|
||||||
|
|
||||||
freebsd_packages: freebsd_pkg freebsd386_pkg freebsdarm_pkg
|
|
||||||
|
|
||||||
macapp: $(MACAPP).app
|
macapp: $(MACAPP).app
|
||||||
$(MACAPP).app: macos
|
$(MACAPP).app: macos
|
||||||
[ -z "$(MACAPP)" ] || mkdir -p init/macos/$(MACAPP).app/Contents/MacOS
|
[ -z "$(MACAPP)" ] || mkdir -p init/macos/$(MACAPP).app/Contents/MacOS
|
||||||
[ -z "$(MACAPP)" ] || cp $(BINARY).amd64.macos init/macos/$(MACAPP).app/Contents/MacOS/$(MACAPP)
|
[ -z "$(MACAPP)" ] || cp $(BINARY).amd64.macos init/macos/$(MACAPP).app/Contents/MacOS/$(MACAPP)
|
||||||
[ -z "$(MACAPP)" ] || cp -rp init/macos/$(MACAPP).app $(MACAPP).app
|
[ -z "$(MACAPP)" ] || cp -rp init/macos/$(MACAPP).app $(MACAPP).app
|
||||||
|
|
||||||
rpm: $(BINARY)-$(RPMVERSION)-$(ITERATION).x86_64.rpm
|
|
||||||
$(BINARY)-$(RPMVERSION)-$(ITERATION).x86_64.rpm: package_build_linux check_fpm
|
|
||||||
@echo "Building 'rpm' package for $(BINARY) version '$(RPMVERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t rpm $(PACKAGE_ARGS) -a x86_64 -v $(RPMVERSION) -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
[ "$(SIGNING_KEY)" == "" ] || rpmsign --key-id=$(SIGNING_KEY) --resign $(BINARY)-$(RPMVERSION)-$(ITERATION).x86_64.rpm
|
|
||||||
|
|
||||||
deb: $(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb
|
|
||||||
$(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb: package_build_linux check_fpm
|
|
||||||
@echo "Building 'deb' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t deb $(PACKAGE_ARGS) -a amd64 -v $(VERSION) -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
[ "$(SIGNING_KEY)" == "" ] || debsigs --default-key="$(SIGNING_KEY)" --sign=origin $(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb
|
|
||||||
|
|
||||||
rpm386: $(BINARY)-$(RPMVERSION)-$(ITERATION).i386.rpm
|
|
||||||
$(BINARY)-$(RPMVERSION)-$(ITERATION).i386.rpm: package_build_linux_386 check_fpm
|
|
||||||
@echo "Building 32-bit 'rpm' package for $(BINARY) version '$(RPMVERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t rpm $(PACKAGE_ARGS) -a i386 -v $(RPMVERSION) -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
[ "$(SIGNING_KEY)" == "" ] || rpmsign --key-id=$(SIGNING_KEY) --resign $(BINARY)-$(RPMVERSION)-$(ITERATION).i386.rpm
|
|
||||||
|
|
||||||
deb386: $(BINARY)_$(VERSION)-$(ITERATION)_i386.deb
|
|
||||||
$(BINARY)_$(VERSION)-$(ITERATION)_i386.deb: package_build_linux_386 check_fpm
|
|
||||||
@echo "Building 32-bit 'deb' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t deb $(PACKAGE_ARGS) -a i386 -v $(VERSION) -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
[ "$(SIGNING_KEY)" == "" ] || debsigs --default-key="$(SIGNING_KEY)" --sign=origin $(BINARY)_$(VERSION)-$(ITERATION)_i386.deb
|
|
||||||
|
|
||||||
rpmarm: $(BINARY)-$(RPMVERSION)-$(ITERATION).arm64.rpm
|
|
||||||
$(BINARY)-$(RPMVERSION)-$(ITERATION).arm64.rpm: package_build_linux_arm64 check_fpm
|
|
||||||
@echo "Building 64-bit ARM8 'rpm' package for $(BINARY) version '$(RPMVERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t rpm $(PACKAGE_ARGS) -a arm64 -v $(RPMVERSION) -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
[ "$(SIGNING_KEY)" == "" ] || rpmsign --key-id=$(SIGNING_KEY) --resign $(BINARY)-$(RPMVERSION)-$(ITERATION).arm64.rpm
|
|
||||||
|
|
||||||
debarm: $(BINARY)_$(VERSION)-$(ITERATION)_arm64.deb
|
|
||||||
$(BINARY)_$(VERSION)-$(ITERATION)_arm64.deb: package_build_linux_arm64 check_fpm
|
|
||||||
@echo "Building 64-bit ARM8 'deb' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t deb $(PACKAGE_ARGS) -a arm64 -v $(VERSION) -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
[ "$(SIGNING_KEY)" == "" ] || debsigs --default-key="$(SIGNING_KEY)" --sign=origin $(BINARY)_$(VERSION)-$(ITERATION)_arm64.deb
|
|
||||||
|
|
||||||
rpmarmhf: $(BINARY)-$(RPMVERSION)-$(ITERATION).armhf.rpm
|
|
||||||
$(BINARY)-$(RPMVERSION)-$(ITERATION).armhf.rpm: package_build_linux_armhf check_fpm
|
|
||||||
@echo "Building 32-bit ARM6/7 HF 'rpm' package for $(BINARY) version '$(RPMVERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t rpm $(PACKAGE_ARGS) -a armhf -v $(RPMVERSION) -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
[ "$(SIGNING_KEY)" == "" ] || rpmsign --key-id=$(SIGNING_KEY) --resign $(BINARY)-$(RPMVERSION)-$(ITERATION).armhf.rpm
|
|
||||||
|
|
||||||
debarmhf: $(BINARY)_$(VERSION)-$(ITERATION)_armhf.deb
|
|
||||||
$(BINARY)_$(VERSION)-$(ITERATION)_armhf.deb: package_build_linux_armhf check_fpm
|
|
||||||
@echo "Building 32-bit ARM6/7 HF 'deb' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t deb $(PACKAGE_ARGS) -a armhf -v $(VERSION) -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
[ "$(SIGNING_KEY)" == "" ] || debsigs --default-key="$(SIGNING_KEY)" --sign=origin $(BINARY)_$(VERSION)-$(ITERATION)_armhf.deb
|
|
||||||
|
|
||||||
freebsd_pkg: $(BINARY)-$(VERSION)_$(ITERATION).amd64.txz
|
|
||||||
$(BINARY)-$(VERSION)_$(ITERATION).amd64.txz: package_build_freebsd check_fpm
|
|
||||||
@echo "Building 'freebsd pkg' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t freebsd $(PACKAGE_ARGS) -a amd64 -v $(VERSION) -p $(BINARY)-$(VERSION)_$(ITERATION).amd64.txz -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
|
|
||||||
freebsd386_pkg: $(BINARY)-$(VERSION)_$(ITERATION).i386.txz
|
|
||||||
$(BINARY)-$(VERSION)_$(ITERATION).i386.txz: package_build_freebsd_386 check_fpm
|
|
||||||
@echo "Building 32-bit 'freebsd pkg' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t freebsd $(PACKAGE_ARGS) -a 386 -v $(VERSION) -p $(BINARY)-$(VERSION)_$(ITERATION).i386.txz -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
|
|
||||||
freebsdarm_pkg: $(BINARY)-$(VERSION)_$(ITERATION).armhf.txz
|
|
||||||
$(BINARY)-$(VERSION)_$(ITERATION).armhf.txz: package_build_freebsd_arm check_fpm
|
|
||||||
@echo "Building 32-bit ARM6/7 HF 'freebsd pkg' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
|
||||||
fpm -s dir -t freebsd $(PACKAGE_ARGS) -a arm -v $(VERSION) -p $(BINARY)-$(VERSION)_$(ITERATION).armhf.txz -C $< $(EXTRA_FPM_FLAGS)
|
|
||||||
|
|
||||||
# Build an environment that can be packaged for linux.
|
|
||||||
package_build_linux: readme man plugins_linux_amd64 after-install-rendered.sh before-remove-rendered.sh linux
|
|
||||||
# Building package environment for linux.
|
|
||||||
mkdir -p $@/usr/bin $@/etc/$(BINARY) $@/usr/share/man/man1 $@/usr/share/doc/$(BINARY) $@/usr/lib/$(BINARY)
|
|
||||||
# Copying the binary, config file, unit file, and man page into the env.
|
|
||||||
cp $(BINARY).amd64.linux $@/usr/bin/$(BINARY)
|
|
||||||
cp *.1.gz $@/usr/share/man/man1
|
|
||||||
rm -f $@/usr/lib/$(BINARY)/*.so
|
|
||||||
[ ! -f *amd64.so ] || cp *amd64.so $@/usr/lib/$(BINARY)/
|
|
||||||
cp examples/$(CONFIG_FILE).example $@/etc/$(BINARY)/
|
|
||||||
cp examples/$(CONFIG_FILE).example $@/etc/$(BINARY)/$(CONFIG_FILE)
|
|
||||||
cp LICENSE *.html examples/*?.?* $@/usr/share/doc/$(BINARY)/
|
|
||||||
[ "$(FORMULA)" != "service" ] || mkdir -p $@/lib/systemd/system
|
|
||||||
[ "$(FORMULA)" != "service" ] || \
|
|
||||||
sed -e "s/{{BINARY}}/$(BINARY)/g" -e "s/{{DESC}}/$(DESC)/g" \
|
|
||||||
init/systemd/template.unit.service > $@/lib/systemd/system/$(BINARY).service
|
|
||||||
|
|
||||||
after-install-rendered.sh:
|
|
||||||
sed -e "s/{{BINARY}}/$(BINARY)/g" scripts/after-install.sh > after-install-rendered.sh
|
|
||||||
|
|
||||||
before-remove-rendered.sh:
|
|
||||||
sed -e "s/{{BINARY}}/$(BINARY)/g" scripts/before-remove.sh > before-remove-rendered.sh
|
|
||||||
|
|
||||||
package_build_linux_386: package_build_linux linux386
|
|
||||||
mkdir -p $@
|
|
||||||
cp -r $</* $@/
|
|
||||||
[ ! -f *386.so ] || cp *386.so $@/usr/lib/$(BINARY)/
|
|
||||||
cp $(BINARY).i386.linux $@/usr/bin/$(BINARY)
|
|
||||||
|
|
||||||
package_build_linux_arm64: package_build_linux arm64
|
|
||||||
mkdir -p $@
|
|
||||||
cp -r $</* $@/
|
|
||||||
[ ! -f *arm64.so ] || cp *arm64.so $@/usr/lib/$(BINARY)/
|
|
||||||
cp $(BINARY).arm64.linux $@/usr/bin/$(BINARY)
|
|
||||||
|
|
||||||
package_build_linux_armhf: package_build_linux armhf
|
|
||||||
mkdir -p $@
|
|
||||||
cp -r $</* $@/
|
|
||||||
[ ! -f *armhf.so ] || cp *armhf.so $@/usr/lib/$(BINARY)/
|
|
||||||
cp $(BINARY).armhf.linux $@/usr/bin/$(BINARY)
|
|
||||||
|
|
||||||
# Build an environment that can be packaged for freebsd.
|
|
||||||
package_build_freebsd: readme man after-install-rendered.sh before-remove-rendered.sh freebsd
|
|
||||||
mkdir -p $@/usr/local/bin $@/usr/local/etc/$(BINARY) $@/usr/local/share/man/man1 $@/usr/local/share/doc/$(BINARY)
|
|
||||||
cp $(BINARY).amd64.freebsd $@/usr/local/bin/$(BINARY)
|
|
||||||
cp *.1.gz $@/usr/local/share/man/man1
|
|
||||||
cp examples/$(CONFIG_FILE).example $@/usr/local/etc/$(BINARY)/
|
|
||||||
cp examples/$(CONFIG_FILE).example $@/usr/local/etc/$(BINARY)/$(CONFIG_FILE)
|
|
||||||
cp LICENSE *.html examples/*?.?* $@/usr/local/share/doc/$(BINARY)/
|
|
||||||
[ "$(FORMULA)" != "service" ] || mkdir -p $@/usr/local/etc/rc.d
|
|
||||||
[ "$(FORMULA)" != "service" ] || \
|
|
||||||
sed -e "s/{{BINARY}}/$(BINARY)/g" -e "s/{{BINARYU}}/$(BINARYU)/g" -e "s/{{CONFIG_FILE}}/$(CONFIG_FILE)/g" \
|
|
||||||
init/bsd/freebsd.rc.d > $@/usr/local/etc/rc.d/$(BINARY)
|
|
||||||
[ "$(FORMULA)" != "service" ] || chmod +x $@/usr/local/etc/rc.d/$(BINARY)
|
|
||||||
|
|
||||||
package_build_freebsd_386: package_build_freebsd freebsd386
|
|
||||||
mkdir -p $@
|
|
||||||
cp -r $</* $@/
|
|
||||||
cp $(BINARY).i386.freebsd $@/usr/local/bin/$(BINARY)
|
|
||||||
|
|
||||||
package_build_freebsd_arm: package_build_freebsd freebsdarm
|
|
||||||
mkdir -p $@
|
|
||||||
cp -r $</* $@/
|
|
||||||
cp $(BINARY).armhf.freebsd $@/usr/local/bin/$(BINARY)
|
|
||||||
|
|
||||||
check_fpm:
|
|
||||||
@fpm --version > /dev/null || (echo "FPM missing. Install FPM: https://fpm.readthedocs.io/en/latest/installing.html" && false)
|
|
||||||
|
|
||||||
##################
|
|
||||||
##### Extras #####
|
|
||||||
##################
|
|
||||||
|
|
||||||
plugins: $(patsubst %,%.so,$(PLUGINS))
|
|
||||||
$(patsubst %,%.so,$(PLUGINS)):
|
|
||||||
go build -o $@ -ldflags "$(VERSION_LDFLAGS)" -buildmode=plugin ./plugins/$(patsubst %.so,%,$@)
|
|
||||||
|
|
||||||
linux_plugins: plugins_linux_amd64 plugins_linux_i386 plugins_linux_arm64 plugins_linux_armhf
|
|
||||||
plugins_linux_amd64: $(patsubst %,%.linux_amd64.so,$(PLUGINS))
|
|
||||||
$(patsubst %,%.linux_amd64.so,$(PLUGINS)):
|
|
||||||
GOOS=linux GOARCH=amd64 go build -o $@ -ldflags "$(VERSION_LDFLAGS)" -buildmode=plugin ./plugins/$(patsubst %.linux_amd64.so,%,$@)
|
|
||||||
|
|
||||||
plugins_darwin: $(patsubst %,%.darwin.so,$(PLUGINS))
|
|
||||||
$(patsubst %,%.darwin.so,$(PLUGINS)):
|
|
||||||
GOOS=darwin go build -o $@ -ldflags "$(VERSION_LDFLAGS)" -buildmode=plugin ./plugins/$(patsubst %.darwin.so,%,$@)
|
|
||||||
|
|
||||||
# Run code tests and lint.
|
|
||||||
test: # lint
|
|
||||||
# Testing.
|
|
||||||
go test -race -covermode=atomic ./...
|
|
||||||
#lint:
|
|
||||||
# # Checking lint.
|
|
||||||
# GOOS=linux $(shell go env GOPATH)/bin/golangci-lint run $(GOLANGCI_LINT_ARGS)
|
|
||||||
# GOOS=freebsd $(shell go env GOPATH)/bin/golangci-lint run $(GOLANGCI_LINT_ARGS)
|
|
||||||
# GOOS=windows $(shell go env GOPATH)/bin/golangci-lint run $(GOLANGCI_LINT_ARGS)
|
|
||||||
|
|
||||||
# Mockgen and bindata are examples.
|
|
||||||
# Your `go generate` may require other tools; add them!
|
|
||||||
|
|
||||||
mockgen: $(shell go env GOPATH)/bin/mockgen
|
|
||||||
$(shell go env GOPATH)/bin/mockgen:
|
|
||||||
cd /tmp ; go get github.com/golang/mock/mockgen ; go install github.com/golang/mock/mockgen
|
|
||||||
|
|
||||||
bindata: $(shell go env GOPATH)/bin/go-bindata
|
|
||||||
$(shell go env GOPATH)/bin/go-bindata:
|
|
||||||
cd /tmp ; go get -u github.com/go-bindata/go-bindata/... ; go install github.com/go-bindata/go-bindata
|
|
||||||
|
|
||||||
generate: mockgen bindata
|
|
||||||
go generate ./...
|
|
||||||
|
|
||||||
##################
|
|
||||||
##### Docker #####
|
|
||||||
##################
|
|
||||||
|
|
||||||
docker:
|
|
||||||
docker build -f init/docker/Dockerfile \
|
|
||||||
--build-arg "BUILD_DATE=$(DATE)" \
|
|
||||||
--build-arg "COMMIT=$(COMMIT)" \
|
|
||||||
--build-arg "VERSION=$(VERSION)-$(ITERATION)" \
|
|
||||||
--build-arg "LICENSE=$(LICENSE)" \
|
|
||||||
--build-arg "DESC=$(DESC)" \
|
|
||||||
--build-arg "VENDOR=$(VENDOR)" \
|
|
||||||
--build-arg "AUTHOR=$(MAINT)" \
|
|
||||||
--build-arg "BINARY=$(BINARY)" \
|
|
||||||
--build-arg "SOURCE_URL=$(SOURCE_URL)" \
|
|
||||||
--build-arg "CONFIG_FILE=$(CONFIG_FILE)" \
|
|
||||||
--tag $(BINARY) .
|
|
||||||
|
|
||||||
####################
|
####################
|
||||||
##### Homebrew #####
|
##### Homebrew #####
|
||||||
####################
|
####################
|
||||||
|
|
@ -437,3 +205,6 @@ install: man readme $(BINARY) plugins_darwin
|
||||||
/usr/bin/install -m 0644 -cp init/webserver/static/images/* $(PREFIX)/lib/$(BINARY)/web/static/images/
|
/usr/bin/install -m 0644 -cp init/webserver/static/images/* $(PREFIX)/lib/$(BINARY)/web/static/images/
|
||||||
[ -f $(ETC)/$(BINARY)/$(CONFIG_FILE) ] || /usr/bin/install -m 0644 -cp examples/$(CONFIG_FILE).example $(ETC)/$(BINARY)/$(CONFIG_FILE)
|
[ -f $(ETC)/$(BINARY)/$(CONFIG_FILE) ] || /usr/bin/install -m 0644 -cp examples/$(CONFIG_FILE).example $(ETC)/$(BINARY)/$(CONFIG_FILE)
|
||||||
/usr/bin/install -m 0644 -cp LICENSE *.html examples/* $(PREFIX)/share/doc/$(BINARY)/
|
/usr/bin/install -m 0644 -cp LICENSE *.html examples/* $(PREFIX)/share/doc/$(BINARY)/
|
||||||
|
|
||||||
|
goreleaser-test:
|
||||||
|
goreleaser release --rm-dist --skip-validate --skip-publish --skip-sign --debug
|
||||||
|
|
|
||||||
|
|
@ -1,31 +1,31 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
#
|
#
|
||||||
# FreeBSD rc.d startup script for {{BINARY}}.
|
# FreeBSD rc.d startup script for unpoller.
|
||||||
#
|
#
|
||||||
# PROVIDE: {{BINARY}}
|
# PROVIDE: unpoller
|
||||||
# REQUIRE: networking syslog
|
# REQUIRE: networking syslog
|
||||||
# KEYWORD:
|
# KEYWORD:
|
||||||
|
|
||||||
. /etc/rc.subr
|
. /etc/rc.subr
|
||||||
|
|
||||||
name="{{BINARYU}}"
|
name="unpoller"
|
||||||
real_name="{{BINARY}}"
|
real_name="unpoller"
|
||||||
rcvar="{{BINARYU}}_enable"
|
rcvar="unpoller_enable"
|
||||||
{{BINARYU}}_command="/usr/local/bin/${real_name}"
|
unpoller_command="/usr/local/bin/${real_name}"
|
||||||
{{BINARYU}}_user="{{BINARY}}"
|
unpoller_user="unpoller"
|
||||||
{{BINARYU}}_config="/usr/local/etc/${real_name}/{{CONFIG_FILE}}"
|
unpoller_config="/usr/local/etc/${real_name}/{{CONFIG_FILE}}"
|
||||||
pidfile="/var/run/${real_name}/pid"
|
pidfile="/var/run/${real_name}/pid"
|
||||||
|
|
||||||
# This runs `daemon` as the `{{BINARYU}}_user` user.
|
# This runs `daemon` as the `unpoller_user` user.
|
||||||
command="/usr/sbin/daemon"
|
command="/usr/sbin/daemon"
|
||||||
command_args="-P ${pidfile} -r -t ${real_name} -T ${real_name} -l daemon ${{{BINARYU}}_command} -c ${{{BINARYU}}_config}"
|
command_args="-P ${pidfile} -r -t ${real_name} -T ${real_name} -l daemon ${unpoller_command} -c ${unpoller_config}"
|
||||||
|
|
||||||
load_rc_config ${name}
|
load_rc_config ${name}
|
||||||
: ${{{BINARYU}}_enable:=no}
|
: ${unpoller_enable:=no}
|
||||||
|
|
||||||
# Make a place for the pid file.
|
# Make a place for the pid file.
|
||||||
mkdir -p $(dirname ${pidfile})
|
mkdir -p $(dirname ${pidfile})
|
||||||
chown -R ${{BINARYU}}_user $(dirname ${pidfile})
|
chown -R $unpoller_user $(dirname ${pidfile})
|
||||||
|
|
||||||
# Suck in optional exported override variables.
|
# Suck in optional exported override variables.
|
||||||
# ie. add something like the following to this file: export UP_POLLER_DEBUG=true
|
# ie. add something like the following to this file: export UP_POLLER_DEBUG=true
|
||||||
|
|
|
||||||
|
|
@ -1,29 +1,29 @@
|
||||||
# Systemd service unit for {{BINARY}}.
|
# Systemd service unit for unpoller.
|
||||||
# This is part of Application Builder.
|
# This is part of Application Builder.
|
||||||
# https://github.com/golift/application-builder
|
# https://github.com/golift/application-builder
|
||||||
# This file is installed when FORMULA is set to 'service'.
|
# This file is installed when FORMULA is set to 'service'.
|
||||||
|
|
||||||
[Unit]
|
[Unit]
|
||||||
Description={{BINARY}} - {{DESC}}
|
Description=unpoller - Telemetry and Observability for your UniFi Network
|
||||||
After=network.target
|
After=network.target
|
||||||
Requires=network.target
|
Requires=network.target
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
ExecStart=/usr/bin/{{BINARY}} $DAEMON_OPTS
|
ExecStart=/usr/bin/unpoller $DAEMON_OPTS
|
||||||
EnvironmentFile=-/etc/default/{{BINARY}}
|
EnvironmentFile=-/etc/default/unpoller
|
||||||
EnvironmentFile=-/etc/sysconfig/{{BINARY}}
|
EnvironmentFile=-/etc/sysconfig/unpoller
|
||||||
Restart=always
|
Restart=always
|
||||||
RestartSec=10
|
RestartSec=10
|
||||||
StandardOutput=syslog
|
StandardOutput=syslog
|
||||||
StandardError=syslog
|
StandardError=syslog
|
||||||
SyslogIdentifier={{BINARY}}
|
SyslogIdentifier=unpoller
|
||||||
Type=simple
|
Type=simple
|
||||||
WorkingDirectory=/tmp
|
WorkingDirectory=/tmp
|
||||||
|
|
||||||
# These should be set correctly for your environment.
|
# These should be set correctly for your environment.
|
||||||
UMask=0002
|
UMask=0002
|
||||||
User={{BINARY}}
|
User=unpoller
|
||||||
Group={{BINARY}}
|
Group=unpoller
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
||||||
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
|
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
|
||||||
<assemblyIdentity version="1.0.0.0" processorArchitecture="*" name="unifi-poller" type="win32"/>
|
<assemblyIdentity version="1.0.0.0" processorArchitecture="*" name="unpoller" type="win32"/>
|
||||||
<dependency>
|
<dependency>
|
||||||
<dependentAssembly>
|
<dependentAssembly>
|
||||||
<assemblyIdentity type="win32" name="Microsoft.Windows.Common-Controls" version="6.0.0.0" processorArchitecture="*" publicKeyToken="6595b64144ccf1df" language="*"/>
|
<assemblyIdentity type="win32" name="Microsoft.Windows.Common-Controls" version="6.0.0.0" processorArchitecture="*" publicKeyToken="6595b64144ccf1df" language="*"/>
|
||||||
|
|
|
||||||
|
|
@ -9,21 +9,21 @@ OS="$(uname -s)"
|
||||||
|
|
||||||
if [ "${OS}" = "Linux" ]; then
|
if [ "${OS}" = "Linux" ]; then
|
||||||
# Make a user and group for this app, but only if it does not already exist.
|
# Make a user and group for this app, but only if it does not already exist.
|
||||||
id {{BINARY}} >/dev/null 2>&1 || \
|
id unpoller >/dev/null 2>&1 || \
|
||||||
useradd --system --user-group --no-create-home --home-dir /tmp --shell /bin/false {{BINARY}}
|
useradd --system --user-group --no-create-home --home-dir /tmp --shell /bin/false unpoller
|
||||||
elif [ "${OS}" = "OpenBSD" ]; then
|
elif [ "${OS}" = "OpenBSD" ]; then
|
||||||
id {{BINARY}} >/dev/null 2>&1 || \
|
id unpoller >/dev/null 2>&1 || \
|
||||||
useradd -g =uid -d /tmp -s /bin/false {{BINARY}}
|
useradd -g =uid -d /tmp -s /bin/false unpoller
|
||||||
elif [ "${OS}" = "FreeBSD" ]; then
|
elif [ "${OS}" = "FreeBSD" ]; then
|
||||||
id {{BINARY}} >/dev/null 2>&1 || \
|
id unpoller >/dev/null 2>&1 || \
|
||||||
pw useradd {{BINARY}} -d /tmp -w no -s /bin/false
|
pw useradd unpoller -d /tmp -w no -s /bin/false
|
||||||
else
|
else
|
||||||
echo "Unknown OS: ${OS}, please add system user {{BINARY}} manually."
|
echo "Unknown OS: ${OS}, please add system user unpoller manually."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -x "/bin/systemctl" ]; then
|
if [ -x "/bin/systemctl" ]; then
|
||||||
# Reload and restart - this starts the application as user nobody.
|
# Reload and restart - this starts the application as user nobody.
|
||||||
/bin/systemctl daemon-reload
|
/bin/systemctl daemon-reload
|
||||||
/bin/systemctl enable {{BINARY}}
|
/bin/systemctl enable unpoller
|
||||||
/bin/systemctl restart {{BINARY}}
|
/bin/systemctl restart unpoller
|
||||||
fi
|
fi
|
||||||
|
|
|
||||||
|
|
@ -9,9 +9,9 @@ if [ "$1" = "upgrade" ] || [ "$1" = "1" ] ; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -x "/bin/systemctl" ]; then
|
if [ -x "/bin/systemctl" ]; then
|
||||||
/bin/systemctl stop {{BINARY}}
|
/bin/systemctl stop unpoller
|
||||||
/bin/systemctl disable {{BINARY}}
|
/bin/systemctl disable unpoller
|
||||||
elif [ -x /usr/sbin/service ]; then
|
elif [ -x /usr/sbin/service ]; then
|
||||||
/usr/sbin/service {{BINARY}} stop
|
/usr/sbin/service unpoller stop
|
||||||
/usr/sbin/service {{BINARY}} disable
|
/usr/sbin/service unpoller disable
|
||||||
fi
|
fi
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue