summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormo khan <mo@mokhan.ca>2025-03-13 09:16:39 -0600
committermo khan <mo@mokhan.ca>2025-03-13 09:16:39 -0600
commitfa141110137caafd40ab62d33fe8acc3048d4c84 (patch)
tree269219ff5984935e8a1b0182aa536c5eb4ed3d0f
parent6ad85c4bd167c9f114c1d2574f4887826689b76d (diff)
refactor: extract cfg package
-rw-r--r--cmd/gtwy/main.go5
-rw-r--r--pkg/cfg/cfg.go (renamed from pkg/srv/config.go)12
-rw-r--r--pkg/cfg/mux.go9
-rw-r--r--pkg/cfg/option.go3
-rw-r--r--pkg/srv/srv.go12
5 files changed, 24 insertions, 17 deletions
diff --git a/cmd/gtwy/main.go b/cmd/gtwy/main.go
index 8d1baa6..232d2f1 100644
--- a/cmd/gtwy/main.go
+++ b/cmd/gtwy/main.go
@@ -10,6 +10,7 @@ import (
"github.com/casbin/casbin/v2"
"github.com/xlgmokha/x/pkg/env"
"github.com/xlgmokha/x/pkg/x"
+ "gitlab.com/mokhax/spike/pkg/cfg"
"gitlab.com/mokhax/spike/pkg/srv"
)
@@ -54,8 +55,8 @@ func main() {
"api.example.com": "localhost:8284",
}))
- log.Fatal(srv.Run(srv.NewConfig(
+ log.Fatal(srv.Run(cfg.New(
env.Fetch("BIND_ADDR", ":8080"),
- srv.WithMux(mux),
+ cfg.WithMux(mux),
)))
}
diff --git a/pkg/srv/config.go b/pkg/cfg/cfg.go
index c02a9c7..0d7a642 100644
--- a/pkg/srv/config.go
+++ b/pkg/cfg/cfg.go
@@ -1,25 +1,17 @@
-package srv
+package cfg
import (
"crypto/tls"
"net/http"
)
-type Option func(*Config)
-
type Config struct {
BindAddress string
Mux http.Handler
TLS *tls.Config
}
-func WithMux(mux http.Handler) Option {
- return func(config *Config) {
- config.Mux = mux
- }
-}
-
-func NewConfig(addr string, options ...Option) *Config {
+func New(addr string, options ...Option) *Config {
if addr == "" {
addr = ":0"
}
diff --git a/pkg/cfg/mux.go b/pkg/cfg/mux.go
new file mode 100644
index 0000000..694ee9e
--- /dev/null
+++ b/pkg/cfg/mux.go
@@ -0,0 +1,9 @@
+package cfg
+
+import "net/http"
+
+func WithMux(mux http.Handler) Option {
+ return func(config *Config) {
+ config.Mux = mux
+ }
+}
diff --git a/pkg/cfg/option.go b/pkg/cfg/option.go
new file mode 100644
index 0000000..0f3e87d
--- /dev/null
+++ b/pkg/cfg/option.go
@@ -0,0 +1,3 @@
+package cfg
+
+type Option func(*Config)
diff --git a/pkg/srv/srv.go b/pkg/srv/srv.go
index a2be363..a6261ef 100644
--- a/pkg/srv/srv.go
+++ b/pkg/srv/srv.go
@@ -4,13 +4,15 @@ import (
"log"
"net/http"
"time"
+
+ "gitlab.com/mokhax/spike/pkg/cfg"
)
-func New(cfg *Config) *http.Server {
+func New(c *cfg.Config) *http.Server {
return &http.Server{
- Addr: cfg.BindAddress,
- Handler: cfg.Mux,
- TLSConfig: cfg.TLS,
+ Addr: c.BindAddress,
+ Handler: c.Mux,
+ TLSConfig: c.TLS,
ReadHeaderTimeout: 10 * time.Second,
ReadTimeout: 30 * time.Second,
WriteTimeout: 2 * time.Minute,
@@ -19,6 +21,6 @@ func New(cfg *Config) *http.Server {
}
}
-func Run(c *Config) error {
+func Run(c *cfg.Config) error {
return c.Run(New(c))
}