nws/exit/nostr.go
2024-09-01 21:31:49 +02:00

78 lines
1.7 KiB
Go

package exit
import (
"context"
"errors"
"fmt"
"log/slog"
"strconv"
"time"
"github.com/asmogo/nws/protocol"
"github.com/nbd-wtf/go-nostr"
)
const ten = 10
var errNoPublicKey = errors.New("no public configuration")
func (e *Exit) announceExitNode(ctx context.Context) error {
if !e.config.Public {
return errNoPublicKey
}
go func() {
for {
event := nostr.Event{
PubKey: e.publicKey,
CreatedAt: nostr.Now(),
Kind: protocol.KindAnnouncementEvent,
Tags: nostr.Tags{
nostr.Tag{"expiration", strconv.FormatInt(time.Now().Add(time.Second*ten).Unix(), ten)},
},
}
err := event.Sign(e.config.NostrPrivateKey)
if err != nil {
slog.Error("could not sign event", "error", err)
continue
}
// publish the event
for _, relay := range e.relays {
err = relay.Publish(ctx, event)
if err != nil {
slog.Error("could not publish event", "error", err)
// do not return here, try to publish the event to other relays
}
}
time.Sleep(time.Second * ten)
}
}()
return nil
}
func (e *Exit) DeleteEvent(ctx context.Context, event *nostr.Event) error {
for _, responseRelay := range e.config.NostrRelays {
var relay *nostr.Relay
relay, err := e.pool.EnsureRelay(responseRelay)
if err != nil {
return fmt.Errorf("failed to ensure relay: %w", err)
}
event := nostr.Event{
CreatedAt: nostr.Now(),
PubKey: e.publicKey,
Kind: nostr.KindDeletion,
Tags: nostr.Tags{
nostr.Tag{"e", event.ID},
},
}
err = event.Sign(e.config.NostrPrivateKey)
if err != nil {
return fmt.Errorf("failed to sign event: %w", err)
}
err = relay.Publish(ctx, event)
if err != nil {
return fmt.Errorf("failed to publish event: %w", err)
}
}
return nil
}