From a7bd17c605e79446d8bf02e474c91986c615b36a Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Sun, 17 Aug 2025 13:31:41 +0800 Subject: Linting --- forged/internal/incoming/lmtp/config.go | 73 -------------------------------- forged/internal/incoming/lmtp/lmtp.go | 75 +++++++++++++++++++++++++++++++++ 2 files changed, 75 insertions(+), 73 deletions(-) delete mode 100644 forged/internal/incoming/lmtp/config.go create mode 100644 forged/internal/incoming/lmtp/lmtp.go (limited to 'forged/internal/incoming/lmtp') diff --git a/forged/internal/incoming/lmtp/config.go b/forged/internal/incoming/lmtp/config.go deleted file mode 100644 index def3ce9..0000000 --- a/forged/internal/incoming/lmtp/config.go +++ /dev/null @@ -1,73 +0,0 @@ -package lmtp - -import ( - "context" - "errors" - "fmt" - "net" - "time" - - "go.lindenii.runxiyu.org/forge/forged/internal/common/misc" -) - -type Server struct { - socket string - domain string - maxSize int64 - writeTimeout uint32 - readTimeout uint32 -} - -type Config struct { - Socket string `scfg:"socket"` - Domain string `scfg:"domain"` - MaxSize int64 `scfg:"max_size"` - WriteTimeout uint32 `scfg:"write_timeout"` - ReadTimeout uint32 `scfg:"read_timeout"` -} - -func New(config Config) (server *Server) { - return &Server{ - socket: config.Socket, - domain: config.Domain, - maxSize: config.MaxSize, - writeTimeout: config.WriteTimeout, - readTimeout: config.ReadTimeout, - } -} - -func (server *Server) Run(ctx context.Context) error { - listener, _, err := misc.ListenUnixSocket(server.socket) - if err != nil { - return fmt.Errorf("listen unix socket for LMTP: %w", err) - } - defer func() { - _ = listener.Close() - }() - - stop := context.AfterFunc(ctx, func() { - _ = listener.Close() - }) - defer stop() - - for { - conn, err := listener.Accept() - if err != nil { - if errors.Is(err, net.ErrClosed) || ctx.Err() != nil { - return nil - } - return fmt.Errorf("accept conn: %w", err) - } - - go server.handleConn(ctx, conn) - } -} - -func (server *Server) handleConn(ctx context.Context, conn net.Conn) { - defer conn.Close() - unblock := context.AfterFunc(ctx, func() { - _ = conn.SetDeadline(time.Now()) - _ = conn.Close() - }) - defer unblock() -} diff --git a/forged/internal/incoming/lmtp/lmtp.go b/forged/internal/incoming/lmtp/lmtp.go new file mode 100644 index 0000000..cf5618c --- /dev/null +++ b/forged/internal/incoming/lmtp/lmtp.go @@ -0,0 +1,75 @@ +package lmtp + +import ( + "context" + "errors" + "fmt" + "net" + "time" + + "go.lindenii.runxiyu.org/forge/forged/internal/common/misc" +) + +type Server struct { + socket string + domain string + maxSize int64 + writeTimeout uint32 + readTimeout uint32 +} + +type Config struct { + Socket string `scfg:"socket"` + Domain string `scfg:"domain"` + MaxSize int64 `scfg:"max_size"` + WriteTimeout uint32 `scfg:"write_timeout"` + ReadTimeout uint32 `scfg:"read_timeout"` +} + +func New(config Config) (server *Server) { + return &Server{ + socket: config.Socket, + domain: config.Domain, + maxSize: config.MaxSize, + writeTimeout: config.WriteTimeout, + readTimeout: config.ReadTimeout, + } +} + +func (server *Server) Run(ctx context.Context) error { + listener, _, err := misc.ListenUnixSocket(server.socket) + if err != nil { + return fmt.Errorf("listen unix socket for LMTP: %w", err) + } + defer func() { + _ = listener.Close() + }() + + stop := context.AfterFunc(ctx, func() { + _ = listener.Close() + }) + defer stop() + + for { + conn, err := listener.Accept() + if err != nil { + if errors.Is(err, net.ErrClosed) || ctx.Err() != nil { + return nil + } + return fmt.Errorf("accept conn: %w", err) + } + + go server.handleConn(ctx, conn) + } +} + +func (server *Server) handleConn(ctx context.Context, conn net.Conn) { + defer func() { + _ = conn.Close() + }() + unblock := context.AfterFunc(ctx, func() { + _ = conn.SetDeadline(time.Now()) + _ = conn.Close() + }) + defer unblock() +} -- cgit v1.2.3