- Introduced the `spider` package for relay crawling, including periodic tasks and one-time sync capabilities. - Added `SetMarker`, `GetMarker`, `HasMarker`, and `DeleteMarker` methods in the database for marker management. - Updated configuration with `SpiderMode` and `SpiderFrequency` options to enable and customize spider behavior. - Integrated `spider` initialization into the main application flow. - Improved tag handling, NIP-70 compliance, and protected tag validation in event processing. - Removed unnecessary logging and replaced `errorf` with `fmt.Errorf` for better error handling. - Incremented version to `v0.5.0`.
52 lines
1.3 KiB
Go
52 lines
1.3 KiB
Go
package app
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"lol.mleku.dev/chk"
|
|
"next.orly.dev/pkg/encoders/envelopes"
|
|
"next.orly.dev/pkg/encoders/envelopes/authenvelope"
|
|
"next.orly.dev/pkg/encoders/envelopes/closeenvelope"
|
|
"next.orly.dev/pkg/encoders/envelopes/eventenvelope"
|
|
"next.orly.dev/pkg/encoders/envelopes/noticeenvelope"
|
|
"next.orly.dev/pkg/encoders/envelopes/reqenvelope"
|
|
)
|
|
|
|
func (l *Listener) HandleMessage(msg []byte, remote string) {
|
|
// log.D.F("%s received message:\n%s", remote, msg)
|
|
var err error
|
|
var t string
|
|
var rem []byte
|
|
if t, rem, err = envelopes.Identify(msg); !chk.E(err) {
|
|
switch t {
|
|
case eventenvelope.L:
|
|
// log.D.F("eventenvelope: %s %s", remote, rem)
|
|
err = l.HandleEvent(rem)
|
|
case reqenvelope.L:
|
|
// log.D.F("reqenvelope: %s %s", remote, rem)
|
|
err = l.HandleReq(rem)
|
|
case closeenvelope.L:
|
|
// log.D.F("closeenvelope: %s %s", remote, rem)
|
|
err = l.HandleClose(rem)
|
|
case authenvelope.L:
|
|
// log.D.F("authenvelope: %s %s", remote, rem)
|
|
err = l.HandleAuth(rem)
|
|
default:
|
|
err = fmt.Errorf("unknown envelope type %s\n%s", t, rem)
|
|
}
|
|
}
|
|
if err != nil {
|
|
// log.D.C(
|
|
// func() string {
|
|
// return fmt.Sprintf(
|
|
// "notice->%s %s", remote, err,
|
|
// )
|
|
// },
|
|
// )
|
|
if err = noticeenvelope.NewFrom(err.Error()).Write(l); err != nil {
|
|
return
|
|
}
|
|
}
|
|
|
|
}
|