55 lines
1.5 KiB
Go
55 lines
1.5 KiB
Go
package server
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"fmt"
|
|
"os"
|
|
|
|
"github.com/qdm12/gluetun/internal/httpserver"
|
|
"github.com/qdm12/gluetun/internal/models"
|
|
"github.com/qdm12/gluetun/internal/server/middlewares/auth"
|
|
)
|
|
|
|
func New(ctx context.Context, address string, logEnabled bool, logger Logger,
|
|
authConfigPath string, buildInfo models.BuildInformation, openvpnLooper VPNLooper,
|
|
pfGetter PortForwardedGetter, dnsLooper DNSLoop,
|
|
updaterLooper UpdaterLooper, publicIPLooper PublicIPLoop, storage Storage,
|
|
ipv6Supported bool) (
|
|
server *httpserver.Server, err error,
|
|
) {
|
|
authSettings, err := auth.Read(authConfigPath)
|
|
switch {
|
|
case errors.Is(err, os.ErrNotExist): // no auth file present
|
|
case err != nil:
|
|
return nil, fmt.Errorf("reading auth settings: %w", err)
|
|
default:
|
|
logger.Infof("read %d roles from authentication file", len(authSettings.Roles))
|
|
}
|
|
authSettings.SetDefaults()
|
|
err = authSettings.Validate()
|
|
if err != nil {
|
|
return nil, fmt.Errorf("validating auth settings: %w", err)
|
|
}
|
|
|
|
handler, err := newHandler(ctx, logger, logEnabled, authSettings, buildInfo,
|
|
openvpnLooper, pfGetter, dnsLooper, updaterLooper, publicIPLooper,
|
|
storage, ipv6Supported)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("creating handler: %w", err)
|
|
}
|
|
|
|
httpServerSettings := httpserver.Settings{
|
|
Address: address,
|
|
Handler: handler,
|
|
Logger: logger,
|
|
}
|
|
|
|
server, err = httpserver.New(httpServerSettings)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("creating server: %w", err)
|
|
}
|
|
|
|
return server, nil
|
|
}
|