nf/app.go

82 lines
1.4 KiB
Go
Raw Normal View History

2024-01-12 19:18:33 +08:00
package nf
import (
2024-01-13 15:05:46 +08:00
"context"
"crypto/tls"
2024-01-12 19:18:33 +08:00
"errors"
"fmt"
2024-01-13 15:05:46 +08:00
"net"
2024-01-12 19:18:33 +08:00
"net/http"
"strings"
)
type App struct {
*RouterGroup
config *Config
router *router
groups []*RouterGroup
2024-01-13 15:05:46 +08:00
server *http.Server
2024-01-12 19:18:33 +08:00
}
func (a *App) ServeHTTP(writer http.ResponseWriter, request *http.Request) {
c := newContext(a, writer, request)
for _, group := range a.groups {
if strings.HasPrefix(request.URL.Path, group.prefix) {
c.handlers = append(c.handlers, group.middlewares...)
}
}
if err := a.router.handle(c); err != nil {
var ne = &Err{}
if errors.As(err, ne) {
writer.WriteHeader(ne.Status)
} else {
writer.WriteHeader(500)
}
_, _ = writer.Write([]byte(err.Error()))
}
}
2024-01-13 15:05:46 +08:00
func (a *App) run(ln net.Listener) error {
2024-01-12 19:18:33 +08:00
if !a.config.DisableBanner {
2024-01-13 15:05:46 +08:00
fmt.Println(banner + "nf serve at: " + a.server.Addr + "\n")
}
return a.server.Serve(ln)
}
func (a *App) Run(address string) error {
ln, err := net.Listen("tcp", address)
if err != nil {
return err
}
a.server = &http.Server{}
return a.run(ln)
}
func (a *App) RunTLS(address string, tlsConfig *tls.Config) error {
ln, err := tls.Listen("tcp", address, tlsConfig)
if err != nil {
return err
2024-01-12 19:18:33 +08:00
}
2024-01-13 15:05:46 +08:00
a.server = &http.Server{}
return a.run(ln)
}
func (a *App) RunListener(ln net.Listener) error {
a.server = &http.Server{}
return a.run(ln)
}
func (a *App) Shutdown(ctx context.Context) error {
return a.server.Shutdown(ctx)
2024-01-12 19:18:33 +08:00
}