More cleanup. Move uninstall to Makefile.
This commit is contained in:
parent
0c9431d09e
commit
f0aa7db84a
|
|
@ -9,7 +9,8 @@ ITERATION:=$(shell git rev-list --all --count)
|
||||||
all: man build
|
all: man build
|
||||||
|
|
||||||
# Prepare a release. Called in Travis CI.
|
# Prepare a release. Called in Travis CI.
|
||||||
release: clean test rpm deb osxpkg
|
release: clean test $(BINARY)-$(VERSION)-$(ITERATION).x86_64.rpm $(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb $(BINARY)-$(VERSION).pkg
|
||||||
|
# Prepareing a release!
|
||||||
mkdir -p release
|
mkdir -p release
|
||||||
gzip -9 $(BINARY).linux
|
gzip -9 $(BINARY).linux
|
||||||
gzip -9 $(BINARY).macos
|
gzip -9 $(BINARY).macos
|
||||||
|
|
@ -18,6 +19,7 @@ release: clean test rpm deb osxpkg
|
||||||
|
|
||||||
# Delete all build assets.
|
# Delete all build assets.
|
||||||
clean:
|
clean:
|
||||||
|
# Cleaning up.
|
||||||
rm -f $(BINARY){.macos,.linux,.1,}{,.gz}
|
rm -f $(BINARY){.macos,.linux,.1,}{,.gz}
|
||||||
rm -f $(BINARY){_,-}*.{deb,rpm,pkg}
|
rm -f $(BINARY){_,-}*.{deb,rpm,pkg}
|
||||||
rm -rf package_build_* release
|
rm -rf package_build_* release
|
||||||
|
|
@ -25,8 +27,8 @@ clean:
|
||||||
# Build a man page from a markdown file using ronn.
|
# Build a man page from a markdown file using ronn.
|
||||||
man: $(BINARY).1.gz
|
man: $(BINARY).1.gz
|
||||||
$(BINARY).1.gz:
|
$(BINARY).1.gz:
|
||||||
|
# Building man page.
|
||||||
@ronn --version > /dev/null || (echo "Ronn missing. Install ronn: $(URL)/wiki/Ronn" && false)
|
@ronn --version > /dev/null || (echo "Ronn missing. Install ronn: $(URL)/wiki/Ronn" && false)
|
||||||
@echo "Creating Man Page: $(PACKAGE)/README.md -> $(BINARY).1.gz"
|
|
||||||
ronn < "$(PACKAGE)/README.md" | gzip -9 > "$(BINARY).1.gz"
|
ronn < "$(PACKAGE)/README.md" | gzip -9 > "$(BINARY).1.gz"
|
||||||
|
|
||||||
# Binaries
|
# Binaries
|
||||||
|
|
@ -37,15 +39,17 @@ $(BINARY):
|
||||||
|
|
||||||
linux: $(BINARY).linux
|
linux: $(BINARY).linux
|
||||||
$(BINARY).linux:
|
$(BINARY).linux:
|
||||||
|
# Building linux binary.
|
||||||
GOOS=linux go build -o $(BINARY).linux -ldflags "-w -s -X main.Version=$(VERSION)" $(PACKAGE)
|
GOOS=linux go build -o $(BINARY).linux -ldflags "-w -s -X main.Version=$(VERSION)" $(PACKAGE)
|
||||||
|
|
||||||
macos: $(BINARY).macos
|
macos: $(BINARY).macos
|
||||||
$(BINARY).macos:
|
$(BINARY).macos:
|
||||||
|
# Building darwin binary.
|
||||||
GOOS=darwin go build -o $(BINARY).macos -ldflags "-w -s -X main.Version=$(VERSION)" $(PACKAGE)
|
GOOS=darwin go build -o $(BINARY).macos -ldflags "-w -s -X main.Version=$(VERSION)" $(PACKAGE)
|
||||||
|
|
||||||
# Packages
|
# Packages
|
||||||
|
|
||||||
rpm: $(BINARY)-$(VERSION)-$(ITERATION).x86_64.rpm
|
rpm: clean $(BINARY)-$(VERSION)-$(ITERATION).x86_64.rpm
|
||||||
$(BINARY)-$(VERSION)-$(ITERATION).x86_64.rpm: check_fpm package_build_linux
|
$(BINARY)-$(VERSION)-$(ITERATION).x86_64.rpm: check_fpm package_build_linux
|
||||||
@echo "Building 'rpm' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
@echo "Building 'rpm' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
||||||
fpm -s dir -t rpm \
|
fpm -s dir -t rpm \
|
||||||
|
|
@ -60,7 +64,7 @@ $(BINARY)-$(VERSION)-$(ITERATION).x86_64.rpm: check_fpm package_build_linux
|
||||||
--description $(DESC) \
|
--description $(DESC) \
|
||||||
--chdir package_build_linux
|
--chdir package_build_linux
|
||||||
|
|
||||||
deb: $(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb
|
deb: clean $(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb
|
||||||
$(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb: check_fpm package_build_linux
|
$(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb: check_fpm package_build_linux
|
||||||
@echo "Building 'deb' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
@echo "Building 'deb' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
||||||
fpm -s dir -t deb \
|
fpm -s dir -t deb \
|
||||||
|
|
@ -75,7 +79,7 @@ $(BINARY)_$(VERSION)-$(ITERATION)_amd64.deb: check_fpm package_build_linux
|
||||||
--description $(DESC) \
|
--description $(DESC) \
|
||||||
--chdir package_build_linux
|
--chdir package_build_linux
|
||||||
|
|
||||||
osxpkg: $(BINARY)-$(VERSION).pkg
|
osxpkg: clean $(BINARY)-$(VERSION).pkg
|
||||||
$(BINARY)-$(VERSION).pkg: check_fpm package_build_osx
|
$(BINARY)-$(VERSION).pkg: check_fpm package_build_osx
|
||||||
@echo "Building 'osx' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
@echo "Building 'osx' package for $(BINARY) version '$(VERSION)-$(ITERATION)'."
|
||||||
fpm -s dir -t osxpkg \
|
fpm -s dir -t osxpkg \
|
||||||
|
|
@ -92,32 +96,29 @@ $(BINARY)-$(VERSION).pkg: check_fpm package_build_osx
|
||||||
|
|
||||||
# OSX packages use /usr/local because Apple doesn't allow writing many other places.
|
# OSX packages use /usr/local because Apple doesn't allow writing many other places.
|
||||||
package_build_osx: man macos
|
package_build_osx: man macos
|
||||||
# Build package environment for macOS.
|
# Building package environment for macOS.
|
||||||
mkdir -p $@/usr/local/bin $@/usr/local/etc/$(BINARY)
|
mkdir -p $@/usr/local/bin $@/usr/local/etc/$(BINARY) $@/Library/LaunchAgents
|
||||||
mkdir -p $@/usr/local/share/man/man1 $@/usr/local/share/doc/$(BINARY)
|
mkdir -p $@/usr/local/share/man/man1 $@/usr/local/share/doc/$(BINARY) $@/usr/local/var/log
|
||||||
# Copy the binary, config file and man page into the env.
|
# Copying the binary, config file and man page into the env.
|
||||||
cp $(BINARY).macos $@/usr/local/bin/$(BINARY)
|
cp $(BINARY).macos $@/usr/local/bin/$(BINARY)
|
||||||
cp *.1.gz $@/usr/local/share/man/man1
|
cp *.1.gz $@/usr/local/share/man/man1
|
||||||
cp examples/*.conf.example $@/usr/local/etc/$(BINARY)/
|
cp examples/*.conf.example $@/usr/local/etc/$(BINARY)/
|
||||||
cp examples/* $@/usr/local/share/doc/$(BINARY)/
|
cp examples/* $@/usr/local/share/doc/$(BINARY)/
|
||||||
mkdir -p $@/usr/local/var/log
|
|
||||||
mkdir -p $@/Library/LaunchAgents
|
|
||||||
cp init/launchd/com.github.davidnewhall.unifi-poller.plist $@/Library/LaunchAgents/
|
cp init/launchd/com.github.davidnewhall.unifi-poller.plist $@/Library/LaunchAgents/
|
||||||
|
|
||||||
# Build an environment that can be packaged for linux.
|
# Build an environment that can be packaged for linux.
|
||||||
package_build_linux: man linux
|
package_build_linux: man linux
|
||||||
# Build package environment for linux.
|
# Building package environment for linux.
|
||||||
mkdir -p $@/usr/bin $@/etc/$(BINARY)
|
mkdir -p $@/usr/bin $@/etc/$(BINARY) $@/lib/systemd/system
|
||||||
mkdir -p $@/usr/share/man/man1 $@/usr/share/doc/$(BINARY)
|
mkdir -p $@/usr/share/man/man1 $@/usr/share/doc/$(BINARY)
|
||||||
# Copy the binary, config file and man page into the env.
|
# Copying the binary, config file and man page into the env.
|
||||||
cp ${BINARY}.linux $@/usr/bin/$(BINARY)
|
cp $(BINARY).linux $@/usr/bin/$(BINARY)
|
||||||
cp *.1.gz $@/usr/share/man/man1
|
cp *.1.gz $@/usr/share/man/man1
|
||||||
cp examples/*.conf.example $@/etc/$(BINARY)/
|
cp examples/*.conf.example $@/etc/$(BINARY)/
|
||||||
cp examples/* $@/usr/share/doc/$(BINARY)/
|
|
||||||
cp examples/up.conf.example $@/etc/$(BINARY)/up.conf
|
cp examples/up.conf.example $@/etc/$(BINARY)/up.conf
|
||||||
# Fix the paths in the systemd unit file before copying it into the emv.
|
cp examples/* $@/usr/share/doc/$(BINARY)/
|
||||||
mkdir -p $@/lib/systemd/system
|
# Fixing the paths in the systemd unit file before copying it into the emv.
|
||||||
sed "s%ExecStart.*%ExecStart=/usr/bin/$(BINARY) --config=/etc/${BINARY}/up.conf%" \
|
sed "s%ExecStart.*%ExecStart=/usr/bin/$(BINARY) --config=/etc/$(BINARY)/up.conf%" \
|
||||||
init/systemd/unifi-poller.service > $@/lib/systemd/system/$(BINARY).service
|
init/systemd/unifi-poller.service > $@/lib/systemd/system/$(BINARY).service
|
||||||
|
|
||||||
check_fpm:
|
check_fpm:
|
||||||
|
|
@ -127,8 +128,10 @@ check_fpm:
|
||||||
|
|
||||||
# Run code tests and lint.
|
# Run code tests and lint.
|
||||||
test: lint
|
test: lint
|
||||||
|
# Testing.
|
||||||
go test -race -covermode=atomic $(PACKAGE)
|
go test -race -covermode=atomic $(PACKAGE)
|
||||||
lint:
|
lint:
|
||||||
|
# Checking lint.
|
||||||
golangci-lint run --enable-all -D gochecknoglobals
|
golangci-lint run --enable-all -D gochecknoglobals
|
||||||
|
|
||||||
# Install locally into /usr/local. Not recommended.
|
# Install locally into /usr/local. Not recommended.
|
||||||
|
|
@ -136,8 +139,20 @@ install: man
|
||||||
scripts/local_install.sh
|
scripts/local_install.sh
|
||||||
|
|
||||||
# If you installed with `make install` run `make uninstall` before installing a binary package.
|
# If you installed with `make install` run `make uninstall` before installing a binary package.
|
||||||
|
# This will remove the package install from macOS, it will not remove a package install from Linux.
|
||||||
uninstall:
|
uninstall:
|
||||||
scripts/local_uninstall.sh
|
[ -x /bin/systemctl ] && /bin/systemctl disable $(BINARY) || true
|
||||||
|
[ -x /bin/systemctl ] && /bin/systemctl stop $(BINARY) || true
|
||||||
|
[ -x /bin/launchctl ] && [ -f ~/Library/LaunchAgents/com.github.davidnewhall.$(BINARY).plist ] \
|
||||||
|
&& /bin/launchctl unload ~/Library/LaunchAgents/com.github.davidnewhall.$(BINARY).plist || true
|
||||||
|
[ -x /bin/launchctl ] && [ -f /Library/LaunchAgents/com.github.davidnewhall.$(BINARY).plist ] \
|
||||||
|
&& /bin/launchctl unload /Library/LaunchAgents/com.github.davidnewhall.$(BINARY).plist || true
|
||||||
|
rm -rf /usr/local/{etc,bin}/$(BINARY) /usr/local/share/man/man1/$(BINARY).1.gz
|
||||||
|
rm -f ~/Library/LaunchAgents/com.github.davidnewhall.$(BINARY).plist
|
||||||
|
rm -f /etc/systemd/system/$(BINARY).service
|
||||||
|
[ -x /bin/systemctl ] && /bin/systemctl --system daemon-reload || true
|
||||||
|
@[ -x /bin/launchctl ] && [ -f /Library/LaunchAgents/com.github.davidnewhall.$(BINARY).plist ] \
|
||||||
|
&& echo " ==> Delete this file manually: sudo rm -f /Library/LaunchAgents/com.github.davidnewhall.$(BINARY).plist" || true
|
||||||
|
|
||||||
# Don't run this unless you're ready to debug untested vendored dependencies.
|
# Don't run this unless you're ready to debug untested vendored dependencies.
|
||||||
deps:
|
deps:
|
||||||
|
|
|
||||||
|
|
@ -33,7 +33,9 @@ unifi-poller(1) -- Utility to poll UniFi Controller Metrics and store them in In
|
||||||
`sites` default: ["default"]
|
`sites` default: ["default"]
|
||||||
This list of strings should represent the names of sites on the unifi
|
This list of strings should represent the names of sites on the unifi
|
||||||
controller that will be polled for data. Pass `all` in the list to
|
controller that will be polled for data. Pass `all` in the list to
|
||||||
poll all sites.
|
poll all sites. On startup, the application prints out all site names
|
||||||
|
found in the controller; they're cryptic, but they have the human-name
|
||||||
|
next to them. The cryptic names go into the config file `sites` list.
|
||||||
|
|
||||||
`interval` default: 30s
|
`interval` default: 30s
|
||||||
How often to poll the controller for updated client and device data.
|
How often to poll the controller for updated client and device data.
|
||||||
|
|
|
||||||
|
|
@ -1,36 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# This script removes a local installation of unifi-poller.
|
|
||||||
# Recommend using Makefile to invoke: make uninstall
|
|
||||||
# Supports Linux (systemd only) and macOS.
|
|
||||||
|
|
||||||
BINARY=unifi-poller
|
|
||||||
|
|
||||||
echo "Uninstall unifi-poller. You may need sudo on Linux. Do not use sudo on macOS."
|
|
||||||
|
|
||||||
# Stopping the daemon
|
|
||||||
if [ -x /bin/systemctl ]; then
|
|
||||||
/bin/systemctl disable ${BINARY}
|
|
||||||
/bin/systemctl stop ${BINARY}
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -x /bin/launchctl ] && [ -f ~/Library/LaunchAgents/com.github.davidnewhall.${BINARY}.plist ]; then
|
|
||||||
echo Unloading ~/Library/LaunchAgents/com.github.davidnewhall.${BINARY}.plist
|
|
||||||
/bin/launchctl unload ~/Library/LaunchAgents/com.github.davidnewhall.${BINARY}.plist || true
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -x /bin/launchctl ] && [ -f /Library/LaunchAgents/com.github.davidnewhall.${BINARY}.plist ]; then
|
|
||||||
echo Unloading /Library/LaunchAgents/com.github.davidnewhall.${BINARY}.plist
|
|
||||||
/bin/launchctl unload /Library/LaunchAgents/com.github.davidnewhall.${BINARY}.plist || true
|
|
||||||
echo "Delete this file manually: sudo rm -f /Library/LaunchAgents/com.github.davidnewhall.${BINARY}.plist"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Deleting config file, binary, man page, launch agent or unit file.
|
|
||||||
rm -rf /usr/local/{etc,bin}/${BINARY} /usr/local/share/man/man1/${BINARY}.1.gz
|
|
||||||
rm -f ~/Library/LaunchAgents/com.github.davidnewhall.${BINARY}.plist
|
|
||||||
rm -f /etc/systemd/system/${BINARY}.service
|
|
||||||
|
|
||||||
# Making systemd happy by telling it to reload.
|
|
||||||
if [ -x /bin/systemctl ]; then
|
|
||||||
/bin/systemctl --system daemon-reload
|
|
||||||
fi
|
|
||||||
Loading…
Reference in New Issue