aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShulhan <m.shulhan@gmail.com>2026-02-04 06:19:53 +0700
committerShulhan <m.shulhan@gmail.com>2026-04-09 22:18:08 +0700
commit0ae9942a08d70aa998ec7c0b41b9ba43fe83cc6c (patch)
tree7534898f0abde9df46900b96ac31170ada3d67f4
parentda9dcca05cea2ab6349e4d2451213fa676fcd3ab (diff)
downloadgo-x-proposal-0ae9942a08d70aa998ec7c0b41b9ba43fe83cc6c.tar.xz
cmd/www-go-proposal: enable socket based activation using systemd
-rw-r--r--cmd/www-go-proposal/main.go16
1 files changed, 16 insertions, 0 deletions
diff --git a/cmd/www-go-proposal/main.go b/cmd/www-go-proposal/main.go
index 9456949..6d8df0c 100644
--- a/cmd/www-go-proposal/main.go
+++ b/cmd/www-go-proposal/main.go
@@ -11,6 +11,7 @@ import (
"git.sr.ht/~shulhan/ciigo"
"git.sr.ht/~shulhan/pakakeh.go/lib/memfs"
+ "git.sr.ht/~shulhan/pakakeh.go/lib/systemd"
)
var memFS *memfs.MemFS
@@ -46,6 +47,21 @@ func main() {
case `embed`:
err = ciigo.GoEmbed(embedOpts)
default:
+ listeners, err := systemd.Listeners(true)
+ if err != nil {
+ log.Fatal(err)
+ }
+ if len(listeners) > 1 {
+ log.Fatal(`too many listeners received for activation`)
+ }
+ if len(listeners) == 1 {
+ serveOpts.Listener = listeners[0]
+ gotAddr := serveOpts.Listener.Addr().String()
+ if gotAddr != serveOpts.Address {
+ log.Fatalf(`invalid Listener address, got %s, want %s`,
+ gotAddr, serveOpts.Address)
+ }
+ }
err = ciigo.Serve(serveOpts)
}
if err != nil {