update dns and target public key in context for public exit nodes

This commit is contained in:
dd dd 2024-11-14 12:14:58 +01:00
parent 1da2eaea9f
commit 1ddfe519f0
2 changed files with 23 additions and 9 deletions

View File

@ -2,6 +2,7 @@ package netstr
import (
"context"
"errors"
"fmt"
"net"
"strings"
@ -11,12 +12,18 @@ import (
"github.com/nbd-wtf/go-nostr"
)
// NostrDNS does not resolve anything
// NostrDNS does not resolve anything.
type NostrDNS struct {
pool *nostr.SimplePool
nostrRelays []string
}
var (
errPoolIsNil = errors.New("pool is nil")
errFailedToFindExitNodeEvent = errors.New("failed to find exit node event")
errExitNodeEventIsExpired = errors.New("exit node event is expired")
)
func NewNostrDNS(pool *nostr.SimplePool, nostrRelays []string) *NostrDNS {
return &NostrDNS{
pool: pool,
@ -31,10 +38,10 @@ func (d NostrDNS) Resolve(ctx context.Context, name string) (context.Context, ne
}
addr, err := net.ResolveIPAddr("ip", name)
if err != nil {
return ctx, nil, err
return ctx, nil, fmt.Errorf("failed to resolve ip address: %w", err)
}
if d.pool == nil {
return ctx, nil, fmt.Errorf("pool is nil")
return ctx, nil, errPoolIsNil
}
since := nostr.Timestamp(time.Now().Add(-time.Second * 10).Unix())
ev := d.pool.QuerySingle(ctx, d.nostrRelays, nostr.Filter{
@ -42,11 +49,15 @@ func (d NostrDNS) Resolve(ctx context.Context, name string) (context.Context, ne
Since: &since,
})
if ev == nil {
return ctx, nil, fmt.Errorf("failed to find exit node event")
return ctx, nil, errFailedToFindExitNodeEvent
}
if ev.CreatedAt < since {
return ctx, nil, fmt.Errorf("exit node event is expired")
return ctx, nil, errExitNodeEventIsExpired
}
ctx = context.WithValue(ctx, "publicKey", ev.PubKey)
return ctx, addr.IP, err
ctx = context.WithValue(ctx, TargetPublicKey, ev.PubKey)
return ctx, addr.IP, nil
}
type ContextKeyTargetPublicKey string
const TargetPublicKey ContextKeyTargetPublicKey = "TargetPublicKey"

View File

@ -137,8 +137,11 @@ func (s *Server) handleRequest(req *Request, conn net.Conn) error {
}
ctx = ctx_
dest.IP = addr
if pubKey := ctx.Value("publicKey"); pubKey != nil {
targetPublicKey = pubKey.(string)
if pubKey := ctx.Value(netstr.TargetPublicKey); pubKey != nil {
var ok bool
if targetPublicKey, ok = pubKey.(string); !ok {
return fmt.Errorf("failed to get target public key: %w", err)
}
}
}