aboutsummaryrefslogtreecommitdiff
path: root/forged/internal/common/misc/net.go
diff options
context:
space:
mode:
authorRunxi Yu <me@runxiyu.org>2025-08-17 03:43:08 +0800
committerRunxi Yu <me@runxiyu.org>2025-08-17 03:48:28 +0800
commit6da9e99a221c814c50804783c598ec12f78e38d8 (patch)
treeb118745279163baf8979cfa5b445831b3c4ba4f8 /forged/internal/common/misc/net.go
parentSome mass renaming (diff)
downloadforge-6da9e99a221c814c50804783c598ec12f78e38d8.tar.gz
forge-6da9e99a221c814c50804783c598ec12f78e38d8.tar.zst
forge-6da9e99a221c814c50804783c598ec12f78e38d8.zip
Add some stubs
Diffstat (limited to 'forged/internal/common/misc/net.go')
-rw-r--r--forged/internal/common/misc/net.go38
1 files changed, 38 insertions, 0 deletions
diff --git a/forged/internal/common/misc/net.go b/forged/internal/common/misc/net.go
new file mode 100644
index 0000000..2c6b0a5
--- /dev/null
+++ b/forged/internal/common/misc/net.go
@@ -0,0 +1,38 @@
+package misc
+
+import (
+ "errors"
+ "fmt"
+ "net"
+ "syscall"
+)
+
+func ListenUnixSocket(path string) (listener net.Listener, replaced bool, err error) {
+ listener, err = net.Listen("unix", path)
+ if errors.Is(err, syscall.EADDRINUSE) {
+ replaced = true
+ if unlinkErr := syscall.Unlink(path); unlinkErr != nil {
+ return listener, false, fmt.Errorf("remove existing socket %q: %w", path, unlinkErr)
+ }
+ listener, err = net.Listen("unix", path)
+ }
+ if err != nil {
+ return listener, replaced, fmt.Errorf("listen on unix socket %q: %w", path, err)
+ }
+ return listener, replaced, nil
+}
+
+func Listen(net_, addr string) (listener net.Listener, err error) {
+ if net_ == "unix" {
+ listener, _, err = ListenUnixSocket(addr)
+ if err != nil {
+ return listener, fmt.Errorf("listen unix socket for web: %w", err)
+ }
+ } else {
+ listener, err = net.Listen(net_, addr)
+ if err != nil {
+ return listener, fmt.Errorf("listen %s for web: %w", net_, err)
+ }
+ }
+ return listener, nil
+}