initial
This commit is contained in:
commit
75b0374c93
13
.drone.yml
Normal file
13
.drone.yml
Normal file
@ -0,0 +1,13 @@
|
||||
kind: pipeline
|
||||
name: test-docker-build
|
||||
|
||||
steps:
|
||||
- name: test-docker-build
|
||||
image: plugins/docker
|
||||
network_mode: bridge
|
||||
settings:
|
||||
repo: sneak/historyposter
|
||||
dry_run: true
|
||||
tags:
|
||||
- ${DRONE_COMMIT_SHA}
|
||||
- ${DRONE_BRANCH}
|
37
Dockerfile
Normal file
37
Dockerfile
Normal file
@ -0,0 +1,37 @@
|
||||
## build image:
|
||||
ARG GO_VERSION=1.15
|
||||
FROM golang:${GO_VERSION}-alpine AS builder
|
||||
|
||||
RUN mkdir /user && \
|
||||
echo 'nobody:x:65534:65534:nobody:/:' > /user/passwd && \
|
||||
echo 'nobody:x:65534:' > /user/group
|
||||
RUN apk add --no-cache ca-certificates git bzip2 make gcc libc-dev
|
||||
|
||||
RUN mkdir -p /go/src/git.eeqj.de/sneak/historyposter
|
||||
WORKDIR /go/src/git.eeqj.de/sneak/historyposter
|
||||
|
||||
COPY go.mod .
|
||||
COPY go.sum .
|
||||
RUN go mod download
|
||||
|
||||
COPY ./ ./
|
||||
RUN make build
|
||||
RUN tar -c /go | bzip2 > /go.tbz2
|
||||
|
||||
## output image:
|
||||
FROM scratch as final
|
||||
COPY --from=builder /user/group /user/passwd /etc/
|
||||
COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/
|
||||
COPY --from=builder /go/src/git.eeqj.de/sneak/historyposter/historyposter /app/historyposter
|
||||
COPY --from=builder /go.tbz2 /go.tbz2
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
ENV PORT 8080
|
||||
ENV DBURL none
|
||||
|
||||
EXPOSE 8080
|
||||
|
||||
USER nobody:nobody
|
||||
|
||||
ENTRYPOINT ["./historyposter"]
|
56
Makefile
Normal file
56
Makefile
Normal file
@ -0,0 +1,56 @@
|
||||
VERSION := $(shell git rev-parse --short HEAD)
|
||||
BUILDTIME := $(shell date -u '+%Y-%m-%dT%H:%M:%SZ')
|
||||
BUILDTIMEFILENAME := $(shell date -u '+%Y%m%d-%H%M%SZ')
|
||||
BUILDTIMETAG := $(shell date -u '+%Y%m%d%H%M%S')
|
||||
BUILDUSER := $(shell whoami)
|
||||
BUILDHOST := $(shell hostname -s)
|
||||
BUILDARCH := $(shell uname -m)
|
||||
|
||||
FN := historyposter
|
||||
|
||||
UNAME_S := $(shell uname -s)
|
||||
|
||||
GOLDFLAGS += -X main.Version=$(VERSION)
|
||||
GOLDFLAGS += -X main.Buildarch=$(BUILDARCH)
|
||||
|
||||
# osx can't statically link apparently?!
|
||||
ifeq ($(UNAME_S),Darwin)
|
||||
GOFLAGS := -ldflags "$(GOLDFLAGS)"
|
||||
endif
|
||||
|
||||
ifneq ($(UNAME_S),Darwin)
|
||||
GOFLAGS = -ldflags "-linkmode external -extldflags -static $(GOLDFLAGS)"
|
||||
endif
|
||||
|
||||
default: fmt
|
||||
|
||||
fmt:
|
||||
go fmt ./...
|
||||
goimports -l -w .
|
||||
|
||||
debug: build
|
||||
GOTRACEBACK=all DEBUG=1 ./$(FN) 2>&1 | tee -a debug.log
|
||||
|
||||
run: build
|
||||
./$(FN)
|
||||
|
||||
clean:
|
||||
-rm ./$(FN)
|
||||
|
||||
build: ./$(FN)
|
||||
|
||||
docker:
|
||||
docker build .
|
||||
|
||||
go-get:
|
||||
cd cmd/$(FN) && go get -v
|
||||
|
||||
./$(FN): */*.go cmd/*/*.go go-get
|
||||
cd cmd/$(FN) && go build -o ../../$(FN) $(GOFLAGS) .
|
||||
|
||||
vet:
|
||||
go lint ./...
|
||||
go vet ./...
|
||||
bash -c 'test -z "$$(gofmt -l .)"'
|
||||
|
||||
.PHONY: build fmt test is_uncommitted docker dist hub upload-docker-image clean run rundebug default build-docker-image-dist
|
19
README.md
Normal file
19
README.md
Normal file
@ -0,0 +1,19 @@
|
||||
# historyposter
|
||||
|
||||
a daemon that watches local browser history on macOS and POSTs it up to an
|
||||
API somewhere
|
||||
|
||||
i'm going to be using this to send history to an API that uses youtube-dl to
|
||||
download/cache/archive every single youtube video i view
|
||||
|
||||
# author
|
||||
|
||||
sneak
|
||||
|
||||
https://sneak.berlin
|
||||
|
||||
sneak@sneak.berlin
|
||||
|
||||
# license
|
||||
|
||||
wtfpl
|
19
cmd/historyposter/main.go
Normal file
19
cmd/historyposter/main.go
Normal file
@ -0,0 +1,19 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"os"
|
||||
|
||||
"git.eeqj.de/sneak/historyposter/process"
|
||||
)
|
||||
|
||||
// these are filled in at link-time by the build scripts
|
||||
|
||||
// Version is the git version of the app
|
||||
var Version string
|
||||
|
||||
// Buildarch contains the architecture it is compiled for
|
||||
var Buildarch string
|
||||
|
||||
func main() {
|
||||
os.Exit(process.CLIEntry(Version, Buildarch))
|
||||
}
|
84
process/historyposter.go
Normal file
84
process/historyposter.go
Normal file
@ -0,0 +1,84 @@
|
||||
package process
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"github.com/k0kubun/pp"
|
||||
"github.com/mattn/go-isatty"
|
||||
"github.com/rs/zerolog"
|
||||
"github.com/rs/zerolog/log"
|
||||
"github.com/spf13/viper"
|
||||
"os"
|
||||
"time"
|
||||
)
|
||||
|
||||
// CLIEntry is the main entrypoint
|
||||
func CLIEntry(version string, buildarch string) int {
|
||||
|
||||
hp := new(HistoryPoster)
|
||||
hp.version = version
|
||||
hp.buildarch = buildarch
|
||||
hp.startup = time.Now()
|
||||
|
||||
c := make(chan os.Signal, 1)
|
||||
signal.Notify(hp.shutdownChannel, os.Interrupt)
|
||||
|
||||
hp.configure()
|
||||
hp.setupLogging()
|
||||
hp.setupDatabase()
|
||||
|
||||
ctx, cancel := context.WithCancel(context.Background())
|
||||
go func() {
|
||||
sig := <-c
|
||||
log.Info().Msgf("signal received: %+v", sig)
|
||||
// FIXME this might need to be scoped to a specific signal
|
||||
cancel()
|
||||
}()
|
||||
return hp.runForever(ctx)
|
||||
}
|
||||
|
||||
type HistoryPoster struct {
|
||||
version string
|
||||
buildarch string
|
||||
startup time.Time
|
||||
}
|
||||
|
||||
func (hp *HistoryPoster) runForever(ctx context.Context) int {
|
||||
|
||||
}
|
||||
|
||||
func (hp *HistoryPoster) setupLogging() {
|
||||
|
||||
log.Logger = log.With().Caller().Logger()
|
||||
|
||||
tty := isatty.IsTerminal(os.Stdin.Fd()) || isatty.IsCygwinTerminal(os.Stdin.Fd())
|
||||
|
||||
if tty {
|
||||
out := zerolog.NewConsoleWriter(
|
||||
func(w *zerolog.ConsoleWriter) {
|
||||
// Customize time format
|
||||
w.TimeFormat = time.RFC3339
|
||||
},
|
||||
)
|
||||
log.Logger = log.Output(out)
|
||||
}
|
||||
|
||||
// always log in UTC
|
||||
zerolog.TimestampFunc = func() time.Time {
|
||||
return time.Now().UTC()
|
||||
}
|
||||
|
||||
zerolog.SetGlobalLevel(zerolog.InfoLevel)
|
||||
if viper.GetBool("debug") {
|
||||
zerolog.SetGlobalLevel(zerolog.DebugLevel)
|
||||
}
|
||||
|
||||
hp.identify()
|
||||
}
|
||||
|
||||
func (hp *HistoryPoster) identify() {
|
||||
log.Info().
|
||||
Str("version", hp.version).
|
||||
Str("buildarch", hp.buildarch).
|
||||
Msg("starting")
|
||||
}
|
Loading…
Reference in New Issue
Block a user