From 844bf987a88355f6428eff27d7570523973af870 Mon Sep 17 00:00:00 2001 From: asmogo Date: Mon, 11 Nov 2024 08:28:43 +0100 Subject: [PATCH] update exit construction (#45) --- cmd/nws/nws.go | 2 +- exit/exit.go | 31 ++++++++++++++++++------------- 2 files changed, 19 insertions(+), 14 deletions(-) diff --git a/cmd/nws/nws.go b/cmd/nws/nws.go index 0893e58..c0cbf4d 100644 --- a/cmd/nws/nws.go +++ b/cmd/nws/nws.go @@ -62,7 +62,7 @@ func startExitNode(cmd *cobra.Command, _ []string) { panic(err) } ctx := cmd.Context() - exitNode := exit.NewExit(ctx, cfg) + exitNode := exit.New(ctx, cfg) exitNode.ListenAndServe(ctx) } diff --git a/exit/exit.go b/exit/exit.go index 2d72703..2f9dde0 100644 --- a/exit/exit.go +++ b/exit/exit.go @@ -53,12 +53,23 @@ type Exit struct { publicKey string } -// NewExit creates a new Exit node with the provided context and config. +func newExit(pool *nostr.SimplePool, pubKey string, profile string) *Exit { + exit := &Exit{ + nostrConnectionMap: xsync.NewMapOf[string, *netstr.NostrConnection](), + pool: pool, + mutexMap: NewMutexMap(), + publicKey: pubKey, + nprofile: profile, + } + return exit +} + +// New creates a newExit Exit node with the provided context and config. // This function will currently panic if there is an error while creating the Exit node. -func NewExit(ctx context.Context, exitNodeConfig *config.ExitConfig) *Exit { - // generate new private key if it is not set +func New(ctx context.Context, exitNodeConfig *config.ExitConfig) *Exit { + // generate newExit private key if it is not set if exitNodeConfig.NostrPrivateKey == "" { - // generate new private key + // generate newExit private key exitNodeConfig.NostrPrivateKey = nostr.GeneratePrivateKey() slog.Warn(generateKeyMessage, "key", exitNodeConfig.NostrPrivateKey) } @@ -74,16 +85,10 @@ func NewExit(ctx context.Context, exitNodeConfig *config.ExitConfig) *Exit { if err != nil { panic(err) } - // create a new pool + // create a newExit pool pool := nostr.NewSimplePool(ctx) - exit := &Exit{ - nostrConnectionMap: xsync.NewMapOf[string, *netstr.NostrConnection](), - pool: pool, - mutexMap: NewMutexMap(), - publicKey: pubKey, - nprofile: profile, - } + exit := newExit(pool, pubKey, profile) // start reverse proxy if https port is set if exitNodeConfig.HttpsPort != 0 { exitNodeConfig.BackendHost = fmt.Sprintf(":%d", exitNodeConfig.HttpsPort) @@ -105,7 +110,7 @@ func NewExit(ctx context.Context, exitNodeConfig *config.ExitConfig) *Exit { continue } exit.relays = append(exit.relays, relay) - slog.Info("added relay connection", "url", relayURL) //nolint:forbidigo + slog.Info("added relay connection", "url", relayURL) } domain, err := exit.getDomain() if err != nil {